diff options
| author | 2011-07-20 17:45:11 -0700 | |
|---|---|---|
| committer | 2011-07-20 17:45:11 -0700 | |
| commit | 84be06e4ce0778fbf0c1ac72f94795ef8433439b (patch) | |
| tree | ea9b35882420896cfba281f17293bce74e564089 /tools/aapt/FileFinder.cpp | |
| parent | a125c937de06b1cc43368743592f47513eb88b76 (diff) | |
| parent | ea9e6d24a458c06df6237fddd22b6165b2f92cb5 (diff) | |
resolved conflicts for merge of ea9e6d24 to honeycomb-plus-aosp
Change-Id: I8e047147a4d2c899b6654c03a5f32b04d929e602
Diffstat (limited to 'tools/aapt/FileFinder.cpp')
| -rw-r--r-- | tools/aapt/FileFinder.cpp | 92 | 
1 files changed, 92 insertions, 0 deletions
| diff --git a/tools/aapt/FileFinder.cpp b/tools/aapt/FileFinder.cpp new file mode 100644 index 000000000000..a1f64d017bb0 --- /dev/null +++ b/tools/aapt/FileFinder.cpp @@ -0,0 +1,92 @@ +// +// Copyright 2011 The Android Open Source Project +// + +// File Finder implementation. +// Implementation for the functions declared and documented in FileFinder.h + +#include <utils/Vector.h> +#include <utils/String8.h> +#include <utils/KeyedVector.h> + + +#include <iostream> + +#include "DirectoryWalker.h" +#include "FileFinder.h" + +//#define DEBUG + +using android::String8; +using std::cout; +using std::endl; + +bool SystemFileFinder::findFiles(String8 basePath, Vector<String8>& extensions, +                                 KeyedVector<String8,time_t>& fileStore, +                                 DirectoryWalker* dw) +{ +    // Scan the directory pointed to by basePath +    // check files and recurse into subdirectories. +    if (!dw->openDir(basePath)) { +        return false; +    } +#ifdef DEBUG +    cout << "FileFinder looking in " << basePath << endl; +#endif // DEBUG +    /* +     *  Go through all directory entries. Check each file using checkAndAddFile +     *  and recurse into sub-directories. +     */ +    struct dirent* entry; +    while ((entry = dw->nextEntry()) != NULL) { +        String8 entryName(entry->d_name); +        if (entry->d_name[0] == '.') // Skip hidden files and directories +            continue; + +        String8 fullPath = basePath.appendPathCopy(entryName); +        // If this entry is a directory we'll recurse into it +        if (entry->d_type == DT_DIR) { +            DirectoryWalker* copy = dw->clone(); +            findFiles(fullPath, extensions, fileStore,copy); +            delete copy; +        } + +        // If this entry is a file, we'll pass it over to checkAndAddFile +        if (entry->d_type == DT_REG) { +            checkAndAddFile(fullPath,dw->entryStats(),extensions,fileStore); +        } +    } + +    // Clean up +    dw->closeDir(); + +    return true; +} + +void SystemFileFinder::checkAndAddFile(String8 path, const struct stat* stats, +                                       Vector<String8>& extensions, +                                       KeyedVector<String8,time_t>& fileStore) +{ +#ifdef DEBUG +    cout << "Checking file " << path << "..."; +#endif // DEBUG +    // Loop over the extensions, checking for a match +    bool done = false; +    String8 ext(path.getPathExtension()); +    ext.toLower(); +    for (size_t i = 0; i < extensions.size() && !done; ++i) { +        String8 ext2 = extensions[i].getPathExtension(); +        ext2.toLower(); +        // Compare the extensions. If a match is found, add to storage. +        if (ext == ext2) { +#ifdef DEBUG +            cout << "Match"; +#endif // DEBUG +            done = true; +            fileStore.add(path,stats->st_mtime); +        } +    } +#ifdef DEBUG +    cout << endl; +#endif //DEBUG +}
\ No newline at end of file |