mapnik/src/fs.cpp

154 lines
4.3 KiB
C++
Raw Normal View History

/*****************************************************************************
*
* This file is part of Mapnik (c++ mapping toolkit)
*
* Copyright (C) 2013 Artem Pavlenko
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*
*****************************************************************************/
//#define BOOST_FILESYSTEM_VERSION 2
// mapnik
2013-06-03 05:04:51 +02:00
#include <mapnik/utils.hpp>
#include <mapnik/util/fs.hpp>
// boost
#include <boost/filesystem/convenience.hpp>
2013-06-03 05:19:33 +02:00
// stl
#include <stdexcept>
#if (BOOST_FILESYSTEM_VERSION <= 2)
#include <boost/scoped_array.hpp>
namespace boost {
namespace filesystem {
path read_symlink(const path& p)
{
path symlink_path;
#ifdef BOOST_POSIX_API
for (std::size_t path_max = 64;; path_max *= 2)// loop 'til buffer is large enough
{
boost::scoped_array<char> buf(new char[path_max]);
ssize_t result;
if ((result=::readlink(p.string().c_str(), buf.get(), path_max))== -1)
{
throw std::runtime_error("could not read symlink");
}
else
{
if(result != static_cast<ssize_t>(path_max))
{
symlink_path.assign(buf.get(), buf.get() + result);
break;
}
}
}
#endif
return symlink_path;
}
}
}
#endif
namespace mapnik {
namespace util {
bool exists(std::string const& filepath)
{
#ifdef _WINDOWS
return boost::filesystem::exists(mapnik::utf8_to_utf16(filepath));
#else
return boost::filesystem::exists(filepath);
#endif
}
bool is_directory(std::string const& filepath)
{
#ifdef _WINDOWS
return boost::filesystem::is_directory(mapnik::utf8_to_utf16(filepath));
#else
return boost::filesystem::is_directory(filepath);
#endif
}
bool remove(std::string const& filepath)
{
#ifdef _WINDOWS
return boost::filesystem::remove(mapnik::utf8_to_utf16(filepath));
#else
return boost::filesystem::remove(filepath);
#endif
}
bool is_relative(std::string const& filepath)
{
#ifdef _WINDOWS
boost::filesystem::path child_path(mapnik::utf8_to_utf16(filepath));
#else
boost::filesystem::path child_path(filepath);
#endif
return (! child_path.has_root_directory() && ! child_path.has_root_name());
}
std::string make_relative(std::string const& filepath, std::string const& base)
{
#ifdef _WINDOWS
boost::filesystem::path absolute_path(mapnik::utf8_to_utf16(base));
#else
boost::filesystem::path absolute_path(base);
#endif
// support symlinks
if (boost::filesystem::is_symlink(absolute_path))
{
absolute_path = boost::filesystem::read_symlink(absolute_path);
}
#if (BOOST_FILESYSTEM_VERSION == 3)
return boost::filesystem::absolute(absolute_path.parent_path() / filepath).string();
#else
return boost::filesystem::complete(absolute_path.branch_path() / filepath).normalize().string();
#endif
}
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
}
std::string dirname(std::string const& filepath)
{
boost::filesystem::path bp(filepath);
#if (BOOST_FILESYSTEM_VERSION == 3)
return bp.parent_path().string();
#else // v2
return bp.branch_path().string();
#endif
}
} // end namespace util
} // end namespace mapnik