1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
|
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
#include "collectdircontent.hxx"
#include <rtl/character.hxx>
using namespace std;
PathFilePair IncludesCollection::split_path(const string& filePath) {
string sepU = "/";
string sepW = "\\";
string::size_type pos = filePath.rfind (sepU);
string::size_type posW = filePath.rfind (sepW);
if ((posW != string::npos) && ((posW > pos) || (pos == string::npos))) pos = posW;
if (pos != string::npos) {
string dirName = filePath.substr(0, pos);
return PathFilePair(dirName, filePath.substr(pos + 1, filePath.length()));
} else
return PathFilePair(".", filePath);
}
void IncludesCollection::add_to_collection(const string& dirPath) {
DirContent dirContent;
#if defined(_WIN32)
WIN32_FIND_DATA FindFileData;
HANDLE hFind;
hFind = FindFirstFile((dirPath + "\\*").c_str(), &FindFileData);
if (hFind == INVALID_HANDLE_VALUE) {
// Invalid File Handle - no need to try it anymore
allIncludes.insert(EntriesPair(dirPath, DirContent()));
return;
}
do {
string winFileName(FindFileData.cFileName);
transform(
winFileName.begin(), winFileName.end(), winFileName.begin(),
[](char c) {
return rtl::toAsciiLowerCase(static_cast<unsigned char>(c));
});
dirContent.insert(winFileName);
} while (FindNextFile(hFind, &FindFileData));
#else
DIR *pdir;
dirent *pent;
pdir = opendir(dirPath.c_str()); //"." refers to the current dir
if (!pdir) {
// Invalid File Handle - no need to try it anymore
allIncludes.insert(EntriesPair(dirPath, DirContent()));
return;
}
while ((pent = readdir(pdir))) {
dirContent.insert(pent->d_name);
}
closedir(pdir);
#endif // defined( _WIN32 )
allIncludes.insert(EntriesPair(dirPath, dirContent));
}
bool IncludesCollection::exists(string filePath) {
#if defined(_WIN32)
transform(
filePath.begin(), filePath.end(), filePath.begin(),
[](char c) {
return rtl::toAsciiLowerCase(static_cast<unsigned char>(c));
});
#endif // defined( _WIN32 )
PathFilePair dirFile = split_path(filePath);
string dirPath = dirFile.first;
string fileName = dirFile.second;
DirMap::iterator mapIter = allIncludes.find(dirPath);
if (mapIter == allIncludes.end()) {
add_to_collection(dirPath);
mapIter = allIncludes.find(dirPath);
}
DirContent dirContent = (*mapIter).second;
DirContent::iterator dirIter = dirContent.find(fileName);
return dirIter != dirContent.end();
}
extern "C" {
IncludesCollection * create_IncludesCollection() {
return new IncludesCollection;
}
void delete_IncludesCollection(IncludesCollection *m) {
delete m;
}
int call_IncludesCollection_exists(IncludesCollection* m, const char * filePath) {
return m->exists(filePath);
}
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|