7778d9f51b
...that would implicitly be sign extended (for plain char only if it is signed), so non-ASCII char values would trigger the isUnicodeCodePoint assert. Change-Id: Iaf8024ad509e64525558e882fe3fd078cfb4ea91 Reviewed-on: https://gerrit.libreoffice.org/35523 Tested-by: Jenkins <ci@libreoffice.org> Reviewed-by: Stephan Bergmann <sbergman@redhat.com>
97 lines
3.1 KiB
C++
97 lines
3.1 KiB
C++
/* -*- 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( WNT )
|
|
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( WNT )
|
|
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);
|
|
if (dirIter == dirContent.end()) {
|
|
return false;
|
|
} else {
|
|
return true;
|
|
};
|
|
}
|
|
|
|
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: */
|