1 ///////////////////////////////////////////////////////////////////////////// 
   3 // Purpose:     wxDir is a class for enumerating the files in a directory 
   4 // Author:      Vadim Zeitlin 
   8 // Copyright:   (c) 1999 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr> 
   9 // Licence:     wxWindows licence 
  10 ///////////////////////////////////////////////////////////////////////////// 
  15 #include "wx/longlong.h" 
  16 #include "wx/string.h" 
  18 class WXDLLIMPEXP_BASE wxArrayString
; 
  20 // ---------------------------------------------------------------------------- 
  22 // ---------------------------------------------------------------------------- 
  24 // these flags define what kind of filenames is included in the list of files 
  25 // enumerated by GetFirst/GetNext 
  28     wxDIR_FILES     
= 0x0001,       // include files 
  29     wxDIR_DIRS      
= 0x0002,       // include directories 
  30     wxDIR_HIDDEN    
= 0x0004,       // include hidden files 
  31     wxDIR_DOTDOT    
= 0x0008,       // include '.' and '..' 
  33     // by default, enumerate everything except '.' and '..' 
  34     wxDIR_DEFAULT   
= wxDIR_FILES 
| wxDIR_DIRS 
| wxDIR_HIDDEN
 
  37 // these constants are possible return value of wxDirTraverser::OnDir() 
  38 enum wxDirTraverseResult
 
  40     wxDIR_IGNORE 
= -1,      // ignore this directory but continue with others 
  41     wxDIR_STOP
,             // stop traversing 
  42     wxDIR_CONTINUE          
// continue into this directory 
  45 // ---------------------------------------------------------------------------- 
  46 // wxDirTraverser: helper class for wxDir::Traverse() 
  47 // ---------------------------------------------------------------------------- 
  49 class WXDLLIMPEXP_BASE wxDirTraverser
 
  52     /// a virtual dtor has been provided since this class has virtual members 
  53     virtual ~wxDirTraverser() { } 
  54     // called for each file found by wxDir::Traverse() 
  56     // return wxDIR_STOP or wxDIR_CONTINUE from here (wxDIR_IGNORE doesn't 
  58     virtual wxDirTraverseResult 
OnFile(const wxString
& filename
) = 0; 
  60     // called for each directory found by wxDir::Traverse() 
  62     // return one of the enum elements defined above 
  63     virtual wxDirTraverseResult 
OnDir(const wxString
& dirname
) = 0; 
  65     // called for each directory which we couldn't open during our traversal 
  66     // of the directory tyree 
  68     // this method can also return either wxDIR_STOP, wxDIR_IGNORE or 
  69     // wxDIR_CONTINUE but the latter is treated specially: it means to retry 
  70     // opening the directory and so may lead to infinite loop if it is 
  71     // returned unconditionally, be careful with this! 
  73     // the base class version always returns wxDIR_IGNORE 
  74     virtual wxDirTraverseResult 
OnOpenError(const wxString
& dirname
); 
  77 // ---------------------------------------------------------------------------- 
  78 // wxDir: portable equivalent of {open/read/close}dir functions 
  79 // ---------------------------------------------------------------------------- 
  81 class WXDLLIMPEXP_BASE wxDirData
; 
  83 class WXDLLIMPEXP_BASE wxDir
 
  86     // test for existence of a directory with the given name 
  87     static bool Exists(const wxString
& dir
); 
  92     // default, use Open() 
  93     wxDir() { m_data 
= NULL
; } 
  95     // opens the directory for enumeration, use IsOpened() to test success 
  96     wxDir(const wxString
& dir
); 
  98     // dtor cleans up the associated ressources 
 101     // open the directory for enumerating 
 102     bool Open(const wxString
& dir
); 
 104     // returns true if the directory was successfully opened 
 105     bool IsOpened() const; 
 107     // get the full name of the directory (without '/' at the end) 
 108     wxString 
GetName() const; 
 110     // file enumeration routines 
 111     // ------------------------- 
 113     // start enumerating all files matching filespec (or all files if it is 
 114     // empty) and flags, return true on success 
 115     bool GetFirst(wxString 
*filename
, 
 116                   const wxString
& filespec 
= wxEmptyString
, 
 117                   int flags 
= wxDIR_DEFAULT
) const; 
 119     // get next file in the enumeration started with GetFirst() 
 120     bool GetNext(wxString 
*filename
) const; 
 122     // return true if this directory has any files in it 
 123     bool HasFiles(const wxString
& spec 
= wxEmptyString
); 
 125     // return true if this directory has any subdirectories 
 126     bool HasSubDirs(const wxString
& spec 
= wxEmptyString
); 
 128     // enumerate all files in this directory and its subdirectories 
 130     // return the number of files found 
 131     size_t Traverse(wxDirTraverser
& sink
, 
 132                     const wxString
& filespec 
= wxEmptyString
, 
 133                     int flags 
= wxDIR_DEFAULT
) const; 
 135     // simplest version of Traverse(): get the names of all files under this 
 136     // directory into filenames array, return the number of files 
 137     static size_t GetAllFiles(const wxString
& dirname
, 
 138                               wxArrayString 
*files
, 
 139                               const wxString
& filespec 
= wxEmptyString
, 
 140                               int flags 
= wxDIR_DEFAULT
); 
 142     // check if there any files matching the given filespec under the given 
 143     // directory (i.e. searches recursively), return the file path if found or 
 144     // empty string otherwise 
 145     static wxString 
FindFirst(const wxString
& dirname
, 
 146                               const wxString
& filespec
, 
 147                               int flags 
= wxDIR_DEFAULT
); 
 149     // returns the size of all directories recursively found in given path 
 150     static wxULongLong 
GetTotalSize(const wxString 
&dir
, wxArrayString 
*filesSkipped 
= NULL
); 
 153     friend class wxDirData
; 
 157     DECLARE_NO_COPY_CLASS(wxDir
)