Compare commits

...

3 commits

Author SHA1 Message Date
Dane Springmeyer
84c70ba767 fix is_relative 2014-10-07 21:43:33 -07:00
Dane Springmeyer
ca0bc3ce5b comment debug line 2014-10-07 18:35:39 -07:00
Dane Springmeyer
a45c4055fe try realpath instead of boost::filesystem for making paths absolute 2014-10-07 18:33:04 -07:00

View file

@ -28,9 +28,14 @@
// boost
#include <boost/filesystem/convenience.hpp>
#ifdef _WINDOWS
#include <boost/regex.hpp>
#endif
// stl
#include <stdexcept>
#include <cstdlib>
#include <iostream>
#if (BOOST_FILESYSTEM_VERSION <= 2)
@ -108,13 +113,13 @@ namespace util {
bool is_relative(std::string const& filepath)
{
if (filepath.empty()) return true;
#ifdef _WINDOWS
boost::filesystem::path child_path(mapnik::utf8_to_utf16(filepath));
static const boost::regex expression("^[a-zA-Z]:");
return (filepath[0] != '\\') && (filepath[0] != '/') && boost::regex_search(filepath,expression);
#else
boost::filesystem::path child_path(filepath);
return (filepath[0] != '/');
#endif
return (! child_path.has_root_directory() && ! child_path.has_root_name());
}
@ -139,12 +144,29 @@ namespace util {
std::string make_absolute(std::string const& filepath, std::string const& base)
{
#if (BOOST_FILESYSTEM_VERSION == 3)
// TODO - normalize is now deprecated, use make_preferred?
return boost::filesystem::absolute(boost::filesystem::path(base)/filepath).string();
#else // v2
return boost::filesystem::complete(boost::filesystem::path(base)/filepath).normalize().string();
#endif
// http://insanecoding.blogspot.com/2007/11/directory-safety-when-working-with.html
char * _base = realpath(base.c_str(),NULL);
if (_base != nullptr) {
std::string absolute(_base);
free(_base);
absolute += "/" + filepath;
return absolute;
/*
char * res = realpath(absolute.c_str(),NULL);
if (res == nullptr) // get here for files that do not exist like ../[this].png
{
return absolute;
}
else
{
std::string result(res);
std::clog << "res " << result << "\n";
free(res);
return result;
}
*/
}
return filepath;
}
std::string dirname(std::string const& filepath)