// // Copyright 2011 The Android Open Source Project // // Defines an abstraction for opening a directory on the filesystem and // iterating through it. #ifndef DIRECTORYWALKER_H #define DIRECTORYWALKER_H #include #include #include #include #include #include #include using namespace android; // Directory Walker // This is an abstraction for walking through a directory and getting files // and descriptions. class DirectoryWalker { public: virtual ~DirectoryWalker() {}; virtual bool openDir(String8 path) = 0; virtual bool openDir(const char* path) = 0; // Advance to next directory entry virtual struct dirent* nextEntry() = 0; // Get the stats for the current entry virtual struct stat* entryStats() = 0; // Clean Up virtual void closeDir() = 0; // This class is able to replicate itself on the heap virtual DirectoryWalker* clone() = 0; // DATA MEMBERS // Current directory entry struct dirent mEntry; // Stats for that directory entry struct stat mStats; // Base path String8 mBasePath; }; // System Directory Walker // This is an implementation of the above abstraction that calls // real system calls and is fully functional. // functions are inlined since they're very short and simple class SystemDirectoryWalker : public DirectoryWalker { // Default constructor, copy constructor, and destructor are fine public: virtual bool openDir(String8 path) { mBasePath = path; dir = NULL; dir = opendir(mBasePath.string() ); if (dir == NULL) return false; return true; }; virtual bool openDir(const char* path) { String8 p(path); openDir(p); return true; }; // Advance to next directory entry virtual struct dirent* nextEntry() { struct dirent* entryPtr = readdir(dir); if (entryPtr == NULL) return NULL; mEntry = *entryPtr; // Get stats String8 fullPath = mBasePath.appendPathCopy(mEntry.d_name); stat(fullPath.string(),&mStats); return &mEntry; }; // Get the stats for the current entry virtual struct stat* entryStats() { return &mStats; }; virtual void closeDir() { closedir(dir); }; virtual DirectoryWalker* clone() { return new SystemDirectoryWalker(*this); }; private: DIR* dir; }; #endif // DIRECTORYWALKER_H