]> git.saurik.com Git - apt.git/blame - apt-pkg/contrib/fileutl.h
split up the OpenMode into OpenMode and CompressionMode and
[apt.git] / apt-pkg / contrib / fileutl.h
CommitLineData
578bfd0a
AL
1// -*- mode: cpp; mode: fold -*-
2// Description /*{{{*/
233b185f 3// $Id: fileutl.h,v 1.26 2001/05/07 05:06:52 jgg Exp $
578bfd0a
AL
4/* ######################################################################
5
6 File Utilities
7
8 CopyFile - Buffered copy of a single file
9 GetLock - dpkg compatible lock file manipulation (fcntl)
10 FileExists - Returns true if the file exists
11 SafeGetCWD - Returns the CWD in a string with overrun protection
12
13 The file class is a handy abstraction for various functions+classes
14 that need to accept filenames.
15
16 This source is placed in the Public Domain, do with it what you will
17 It was originally written by Jason Gunthorpe.
18
19 ##################################################################### */
20 /*}}}*/
578bfd0a
AL
21#ifndef PKGLIB_FILEUTL_H
22#define PKGLIB_FILEUTL_H
23
1cd1c398 24#include <apt-pkg/macros.h>
6c139d6e 25
578bfd0a 26#include <string>
46e39c8e 27#include <vector>
578bfd0a 28
a3a03f5d 29#include <zlib.h>
30
144c0969
JAK
31/* Define this for python-apt */
32#define APT_HAS_GZIP 1
33
8e06abb2 34class FileFd
578bfd0a
AL
35{
36 protected:
37 int iFd;
38
ddc1d8d0 39 enum LocalFlags {AutoClose = (1<<0),Fail = (1<<1),DelOnFail = (1<<2),
3010fb0e 40 HitEof = (1<<3), Replace = (1<<4) };
578bfd0a 41 unsigned long Flags;
8f3ba4e8
DK
42 std::string FileName;
43 std::string TemporaryFileName;
a3a03f5d 44 gzFile gz;
3184b4cf 45
578bfd0a 46 public:
257e8d66
DK
47 enum OpenMode {
48 ReadOnly = (1 << 0),
49 WriteOnly = (1 << 1),
50 ReadWrite = ReadOnly | WriteOnly,
51
52 Create = (1 << 2),
53 Exclusive = (1 << 3),
54 Atomic = Exclusive | (1 << 4),
55 Empty = (1 << 5),
56
57 WriteEmpty = ReadWrite | Create | Empty,
58 WriteExists = ReadWrite,
59 WriteAny = ReadWrite | Create,
60 WriteTemp = ReadWrite | Create | Exclusive,
61 ReadOnlyGzip,
62 WriteAtomic = ReadWrite | Create | Atomic
63 };
64 enum CompressMode { Auto, None, Gzip, Bzip2, Lzma, Xz };
578bfd0a 65
650faab0 66 inline bool Read(void *To,unsigned long long Size,bool AllowEof)
f604cf55 67 {
650faab0 68 unsigned long long Jnk;
f604cf55
AL
69 if (AllowEof)
70 return Read(To,Size,&Jnk);
71 return Read(To,Size);
72 }
650faab0
DK
73 bool Read(void *To,unsigned long long Size,unsigned long long *Actual = 0);
74 bool Write(const void *From,unsigned long long Size);
75 bool Seek(unsigned long long To);
76 bool Skip(unsigned long long To);
77 bool Truncate(unsigned long long To);
78 unsigned long long Tell();
79 unsigned long long Size();
80 unsigned long long FileSize();
81
82 /* You want to use 'unsigned long long' if you are talking about a file
83 to be able to support large files (>2 or >4 GB) properly.
84 This shouldn't happen all to often for the indexes, but deb's might be…
85 And as the auto-conversation converts a 'unsigned long *' to a 'bool'
86 instead of 'unsigned long long *' we need to provide this explicitely -
87 otherwise applications magically start to fail… */
88 __deprecated bool Read(void *To,unsigned long long Size,unsigned long *Actual)
89 {
90 unsigned long long R;
91 bool const T = Read(To, Size, &R);
92 *Actual = R;
93 return T;
94 }
95
257e8d66
DK
96 bool Open(std::string FileName,OpenMode Mode,CompressMode Compress,unsigned long Perms = 0666);
97 inline bool Open(std::string const &FileName,OpenMode Mode,unsigned long Perms = 0666) {
98 return Open(FileName, Mode, None, Perms);
99 };
100 bool OpenDescriptor(int Fd, OpenMode Mode, CompressMode Compress, bool AutoClose=false);
101 inline bool OpenDescriptor(int Fd, OpenMode Mode, bool AutoClose=false) {
102 return OpenDescriptor(Fd, Mode, None, AutoClose);
103 };
578bfd0a 104 bool Close();
b2e465d6
AL
105 bool Sync();
106
578bfd0a
AL
107 // Simple manipulators
108 inline int Fd() {return iFd;};
869f717a 109 inline void Fd(int fd) {iFd = fd;};
caffd480 110 inline gzFile gzFd() {return gz;};
578bfd0a
AL
111 inline bool IsOpen() {return iFd >= 0;};
112 inline bool Failed() {return (Flags & Fail) == Fail;};
113 inline void EraseOnFailure() {Flags |= DelOnFail;};
114 inline void OpFail() {Flags |= Fail;};
ddc1d8d0 115 inline bool Eof() {return (Flags & HitEof) == HitEof;};
8f3ba4e8 116 inline std::string &Name() {return FileName;};
c7b5ce1c 117
8f3ba4e8 118 FileFd(std::string FileName,OpenMode Mode,unsigned long Perms = 0666) : iFd(-1),
a3a03f5d 119 Flags(0), gz(NULL)
13d87e2e
AL
120 {
121 Open(FileName,Mode,Perms);
122 };
a3a03f5d 123 FileFd(int Fd = -1) : iFd(Fd), Flags(AutoClose), gz(NULL) {};
124 FileFd(int Fd,bool) : iFd(Fd), Flags(0), gz(NULL) {};
8e06abb2 125 virtual ~FileFd();
578bfd0a
AL
126};
127
614adaa0 128bool RunScripts(const char *Cnf);
8b89e57f 129bool CopyFile(FileFd &From,FileFd &To);
8f3ba4e8
DK
130int GetLock(std::string File,bool Errors = true);
131bool FileExists(std::string File);
132bool RealFileExists(std::string File);
133bool DirectoryExists(std::string const &Path) __attrib_const;
134bool CreateDirectory(std::string const &Parent, std::string const &Path);
135time_t GetModificationTime(std::string const &Path);
b29c3712
DK
136
137/** \brief Ensure the existence of the given Path
138 *
139 * \param Parent directory of the Path directory - a trailing
140 * /apt/ will be removed before CreateDirectory call.
141 * \param Path which should exist after (successful) call
142 */
8f3ba4e8 143bool CreateAPTDirectoryIfNeeded(std::string const &Parent, std::string const &Path);
b29c3712 144
8f3ba4e8 145std::vector<std::string> GetListOfFilesInDir(std::string const &Dir, std::string const &Ext,
b3793d41 146 bool const &SortList, bool const &AllowNoExt=false);
8f3ba4e8 147std::vector<std::string> GetListOfFilesInDir(std::string const &Dir, std::vector<std::string> const &Ext,
b39c1859 148 bool const &SortList);
8f3ba4e8 149std::string SafeGetCWD();
3b5421b4
AL
150void SetCloseExec(int Fd,bool Close);
151void SetNonBlock(int Fd,bool Block);
1084d58a 152bool WaitFd(int Fd,bool write = false,unsigned long timeout = 0);
75ef8f14 153pid_t ExecFork();
3826564e 154bool ExecWait(pid_t Pid,const char *Name,bool Reap = false);
578bfd0a 155
8ce4327b 156// File string manipulators
8f3ba4e8
DK
157std::string flNotDir(std::string File);
158std::string flNotFile(std::string File);
159std::string flNoLink(std::string File);
160std::string flExtension(std::string File);
161std::string flCombine(std::string Dir,std::string File);
8ce4327b 162
578bfd0a 163#endif