/*========================================================================= Program: GDCM (Grassroots DICOM). A DICOM library Copyright (c) 2006-2011 Mathieu Malaterre All rights reserved. See Copyright.txt or http://gdcm.sourceforge.net/Copyright.html for details. This software is distributed WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the above copyright notice for more information. =========================================================================*/ #ifndef GDCMDIRECTORY_H #define GDCMDIRECTORY_H #include "gdcmTypes.h" #include #include #include #include namespace gdcm { /** * \brief Class for manipulation directories * * \note This implementation provide a cross platform implementation * for manipulating directores: basically traversing directories * and harvesting files * * \note * will not take into account unix type hidden file * recursive option will not look into UNIX type hidden directory (those starting with a '.') * * \note * Since python or C# provide there own equivalent implementation, * in which case gdcm::Directory does not make much sense. */ //----------------------------------------------------------------------------- class GDCM_EXPORT Directory { friend std::ostream& operator<<(std::ostream &_os, const Directory &d); public : Directory() = default; ~Directory() = default; typedef std::string FilenameType; typedef std::vector FilenamesType; /// Print void Print(std::ostream &os = std::cout) const; /// Get the name of the toplevel directory FilenameType const &GetToplevel() const { return Toplevel; } /// Set/Get the file names within the directory FilenamesType const &GetFilenames() const { assert( !(Toplevel.empty()) && "Need to call Explore first" ); return Filenames; } /// Return the Directories traversed FilenamesType const &GetDirectories() const { return Directories; } /// construct a list of filenames and subdirectory beneath directory: name /// \warning: hidden file and hidden directory are not loaded. unsigned int Load(FilenameType const &name, bool recursive = false); // \todo later: GLOB // The glob() function searches for all the pathnames matching pattern according to // the rules used by the shell (see glob(7)). No tilde expansion or parameter // substitution is done; if you want these, use wordexp(3). // int Glob(...); protected: /// Return number of file found when 'recursive'ly exploring directory `name` unsigned int Explore(FilenameType const &name, bool recursive); private : /// List of file names FilenamesType Filenames; FilenamesType Directories; /// name of the toplevel directory to explore FilenameType Toplevel; }; //----------------------------------------------------------------------------- inline std::ostream& operator<<(std::ostream &os, const Directory &d) { d.Print( os ); return os; } } // end namespace gdcm //----------------------------------------------------------------------------- #endif //GDCMDIRECTORY_H