]> git.saurik.com Git - apt.git/blobdiff - ftparchive/multicompress.h
Fix handling of autoclosing for compressed files (Closes: #741685)
[apt.git] / ftparchive / multicompress.h
index 3ac3b8fb28640c60f952879d025378876dd170be..ddd1815a3bccb235211c5d37546d0cee4aae6c42 100644 (file)
 #ifndef MULTICOMPRESS_H
 #define MULTICOMPRESS_H
 
 #ifndef MULTICOMPRESS_H
 #define MULTICOMPRESS_H
 
-
+#include <apt-pkg/fileutl.h>
+#include <apt-pkg/aptconfiguration.h>
 
 #include <string>
 
 #include <string>
-#include <apt-pkg/fileutl.h>
 #include <stdio.h>
 #include <sys/types.h>
 #include <stdio.h>
 #include <sys/types.h>
-    
+#include <time.h>
+
 class MultiCompress
 {
 class MultiCompress
 {
-   // Enumeration of all supported compressors
-   struct CompType
-   {
-      const char *Name;
-      const char *Extension;
-      const char *Binary;
-      const char *CompArgs;
-      const char *UnCompArgs;
-      unsigned char Cost;
-   };
-
    // An output file
    struct Files
    {
    // An output file
    struct Files
    {
-      string Output;
-      const CompType *CompressProg;
-      Files *Next;      
+      std::string Output;
+      APT::Configuration::Compressor CompressProg;
+      Files *Next;
       FileFd TmpFile;
       pid_t CompressProc;
       time_t OldMTime;
       FileFd TmpFile;
       pid_t CompressProc;
       time_t OldMTime;
-      int Fd;
    };
    
    Files *Outputs;
    pid_t Outputter;
    mode_t Permissions;
    };
    
    Files *Outputs;
    pid_t Outputter;
    mode_t Permissions;
-   static const CompType Compressors[];
 
 
-   bool OpenCompress(const CompType *Prog,pid_t &Pid,int const &FileFd,
-                    int &OutFd,bool const &Comp);
    bool Child(int const &Fd);
    bool Start();
    bool Die();
    bool Child(int const &Fd);
    bool Start();
    bool Die();
@@ -65,12 +51,11 @@ class MultiCompress
    FILE *Input;
    unsigned long UpdateMTime;
    
    FILE *Input;
    unsigned long UpdateMTime;
    
-   bool Finalize(unsigned long &OutSize);
-   bool OpenOld(int &Fd,pid_t &Proc);
-   bool CloseOld(int Fd,pid_t Proc);
-   static bool GetStat(string const &Output,string const &Compress,struct stat &St);
+   bool Finalize(unsigned long long &OutSize);
+   bool OpenOld(FileFd &Fd);
+   static bool GetStat(std::string const &Output,std::string const &Compress,struct stat &St);
    
    
-   MultiCompress(string const &Output,string const &Compress,
+   MultiCompress(std::string const &Output,std::string const &Compress,
                 mode_t const &Permissions, bool const &Write = true);
    ~MultiCompress();
 };
                 mode_t const &Permissions, bool const &Write = true);
    ~MultiCompress();
 };