2010-08-20 10:56:46 +00:00
|
|
|
#ifndef FILE_FINDER_MAIN_H
|
|
|
|
#define FILE_FINDER_MAIN_H
|
|
|
|
|
|
|
|
#include "search.hpp"
|
|
|
|
#include "filename_less.hpp"
|
|
|
|
#include <map>
|
|
|
|
|
|
|
|
namespace FileFinder
|
|
|
|
{
|
|
|
|
|
2010-08-20 12:20:05 +00:00
|
|
|
template <typename LESS>
|
|
|
|
class FileFinderT
|
2010-08-20 10:56:46 +00:00
|
|
|
{
|
2010-08-20 12:20:05 +00:00
|
|
|
std::map<std::string, std::string, LESS> table;
|
2010-08-20 10:56:46 +00:00
|
|
|
|
|
|
|
struct Inserter : ReturnPath
|
|
|
|
{
|
2010-08-20 12:20:05 +00:00
|
|
|
FileFinderT<LESS> *owner;
|
2010-08-20 10:56:46 +00:00
|
|
|
int cut;
|
|
|
|
|
|
|
|
void add(const boost::filesystem::path &pth)
|
|
|
|
{
|
2011-03-28 15:36:05 +00:00
|
|
|
std::string file = pth.string();
|
2010-08-20 10:56:46 +00:00
|
|
|
std::string key = file.substr(cut);
|
2011-06-12 00:01:21 +00:00
|
|
|
owner->table[key] = file;
|
2010-08-20 10:56:46 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
Inserter inserter;
|
|
|
|
|
|
|
|
public:
|
2010-08-20 12:20:05 +00:00
|
|
|
FileFinderT(const boost::filesystem::path &path, bool recurse=true)
|
2010-08-20 10:56:46 +00:00
|
|
|
{
|
|
|
|
inserter.owner = this;
|
|
|
|
|
|
|
|
// Remember the original path length, so we can cut it away from
|
|
|
|
// the relative paths used as keys
|
2011-03-28 15:36:05 +00:00
|
|
|
std::string pstring = path.string();
|
2010-08-20 10:56:46 +00:00
|
|
|
inserter.cut = pstring.size();
|
|
|
|
|
|
|
|
// If the path does not end in a slash, then boost will add one
|
|
|
|
// later, which means one more character we have to remove.
|
|
|
|
char last = pstring[pstring.size()-1];
|
|
|
|
if(last != '\\' && last != '/')
|
|
|
|
inserter.cut++;
|
|
|
|
|
|
|
|
// Fill the map
|
|
|
|
find(path, inserter, recurse);
|
|
|
|
}
|
|
|
|
|
|
|
|
bool has(const std::string& file) const
|
|
|
|
{
|
2011-06-12 00:01:21 +00:00
|
|
|
return table.find(file) != table.end();
|
2010-08-20 10:56:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Find the full path from a relative path.
|
|
|
|
const std::string &lookup(const std::string& file) const
|
|
|
|
{
|
2011-06-12 00:01:21 +00:00
|
|
|
return table.find(file)->second;
|
2010-08-20 10:56:46 +00:00
|
|
|
}
|
|
|
|
};
|
2010-08-20 12:20:05 +00:00
|
|
|
|
|
|
|
// The default is to use path_less for equality checks
|
|
|
|
typedef FileFinderT<path_less> FileFinder;
|
2011-06-12 00:01:21 +00:00
|
|
|
typedef FileFinderT<path_slash> FileFinderStrict;
|
2010-08-20 10:56:46 +00:00
|
|
|
}
|
|
|
|
#endif
|