|
|
@ -2,6 +2,7 @@
|
|
|
|
|
|
|
|
|
|
|
|
#include <iostream>
|
|
|
|
#include <iostream>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#include <boost/filesystem.hpp>
|
|
|
|
#include <boost/algorithm/string.hpp>
|
|
|
|
#include <boost/algorithm/string.hpp>
|
|
|
|
|
|
|
|
|
|
|
|
namespace Files
|
|
|
|
namespace Files
|
|
|
@ -22,13 +23,24 @@ namespace Files
|
|
|
|
void FileLibrary::add(const boost::filesystem::path &root, bool recursive, bool strict,
|
|
|
|
void FileLibrary::add(const boost::filesystem::path &root, bool recursive, bool strict,
|
|
|
|
const StringVector &acceptableExtensions)
|
|
|
|
const StringVector &acceptableExtensions)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
PathContainer list;
|
|
|
|
if (!boost::filesystem::exists(root))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
std::cout << "Warning " << root.string() << " does not exist.\n";
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
std::string fileExtension;
|
|
|
|
std::string fileExtension;
|
|
|
|
std::string type;
|
|
|
|
std::string type;
|
|
|
|
FileLister(root, list, recursive);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
for (PathContainer::iterator listIter = list.begin();
|
|
|
|
// remember the last location of the priority list when listing new items
|
|
|
|
listIter != list.end(); ++listIter)
|
|
|
|
int length = mPriorityList.size();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// First makes a list of all candidate files
|
|
|
|
|
|
|
|
FileLister(root, mPriorityList, recursive);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Then sort these files into sections according to the folder they belong to
|
|
|
|
|
|
|
|
for (PathContainer::iterator listIter = mPriorityList.begin() + length;
|
|
|
|
|
|
|
|
listIter != mPriorityList.end(); ++listIter)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if( !acceptableExtensions.empty() )
|
|
|
|
if( !acceptableExtensions.empty() )
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -43,7 +55,7 @@ namespace Files
|
|
|
|
boost::algorithm::to_lower(type);
|
|
|
|
boost::algorithm::to_lower(type);
|
|
|
|
|
|
|
|
|
|
|
|
mMap[type].push_back(*listIter);
|
|
|
|
mMap[type].push_back(*listIter);
|
|
|
|
//std::cout << "Added path: " << listIter->string() << " in section "<< type <<std::endl;
|
|
|
|
// std::cout << "Added path: " << listIter->string() << " in section "<< type <<std::endl;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -82,12 +94,7 @@ namespace Files
|
|
|
|
boost::filesystem::path result("");
|
|
|
|
boost::filesystem::path result("");
|
|
|
|
if (sectionName == "")
|
|
|
|
if (sectionName == "")
|
|
|
|
{
|
|
|
|
{
|
|
|
|
for(StringPathContMap::iterator iter = mMap.begin(); iter != mMap.end(); iter++)
|
|
|
|
return FileListLocator(mPriorityList, boost::filesystem::path(item), strict);
|
|
|
|
{
|
|
|
|
|
|
|
|
result = FileListLocator(iter->second, boost::filesystem::path(item), strict);
|
|
|
|
|
|
|
|
if (result != boost::filesystem::path(""))
|
|
|
|
|
|
|
|
return result;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|