xlnt/tests/helpers/path_helper.hpp

164 lines
4.1 KiB
C++
Raw Normal View History

2014-05-19 09:29:19 +08:00
#pragma once
2014-05-20 08:47:15 +08:00
#include <array>
2014-05-21 22:20:30 +08:00
#include <fstream>
2015-10-14 12:03:48 +08:00
#include <string>
#include <sstream>
2014-05-20 08:47:15 +08:00
#include <detail/include_windows.hpp>
2014-05-19 09:29:19 +08:00
#ifdef __APPLE__
#include <mach-o/dyld.h>
2014-05-21 22:20:30 +08:00
#include <sys/stat.h>
#elif defined(_MSC_VER)
2014-05-21 22:20:30 +08:00
#include <Shlwapi.h>
#elif defined(__linux)
2014-05-31 06:42:25 +08:00
#include <unistd.h>
#include <linux/limits.h>
#include <sys/types.h>
2014-05-22 07:17:56 +08:00
#include <sys/stat.h>
2014-05-19 09:29:19 +08:00
#endif
class path_helper
2014-05-19 09:29:19 +08:00
{
public:
2015-11-11 08:46:57 +08:00
static std::string read_file(const std::string &filename)
2015-10-14 12:03:48 +08:00
{
2015-11-11 08:46:57 +08:00
std::ifstream f(filename);
2015-10-14 12:03:48 +08:00
std::ostringstream ss;
ss << f.rdbuf();
2015-11-11 08:46:57 +08:00
return ss.str();
2015-10-14 12:03:48 +08:00
}
static std::string windows_to_universal_path(const std::string &windows_path)
2014-05-20 08:47:15 +08:00
{
2015-11-11 08:46:57 +08:00
std::string fixed;
std::stringstream ss(windows_path);
2014-05-20 08:47:15 +08:00
std::string part;
2014-05-20 08:47:15 +08:00
while(std::getline(ss, part, '\\'))
{
if(fixed == "")
{
2015-11-11 08:46:57 +08:00
fixed = part;
2014-05-20 08:47:15 +08:00
}
else
{
2015-11-11 08:46:57 +08:00
fixed += "/" + part;
2014-05-20 08:47:15 +08:00
}
}
2014-05-20 08:47:15 +08:00
return fixed;
}
2014-05-21 22:20:30 +08:00
static std::string get_executable_directory()
2014-05-19 09:29:19 +08:00
{
2014-05-21 22:20:30 +08:00
2014-05-19 09:29:19 +08:00
#ifdef __APPLE__
std::array<char, 1024> path;
uint32_t size = static_cast<uint32_t>(path.size());
2014-05-19 09:29:19 +08:00
if (_NSGetExecutablePath(path.data(), &size) == 0)
{
2015-11-11 08:46:57 +08:00
return std::string(path.begin(), std::find(path.begin(), path.end(), '\0') - 9);
2014-05-19 09:29:19 +08:00
}
2014-05-19 09:29:19 +08:00
throw std::runtime_error("buffer too small, " + std::to_string(path.size()) + ", should be: " + std::to_string(size));
#elif defined(_MSC_VER)
2014-05-21 22:20:30 +08:00
2014-05-20 08:47:15 +08:00
std::array<TCHAR, MAX_PATH> buffer;
2014-06-11 05:12:15 +08:00
DWORD result = GetModuleFileName(nullptr, buffer.data(), (DWORD)buffer.size());
2014-05-21 22:20:30 +08:00
2014-05-20 08:47:15 +08:00
if(result == 0 || result == buffer.size())
2014-05-19 09:29:19 +08:00
{
throw std::runtime_error("GetModuleFileName failed or buffer was too small");
}
return windows_to_universal_path(std::string(buffer.begin(), buffer.begin() + result - 13)) + "/";
2014-05-19 09:29:19 +08:00
#else
char arg1[20];
char exepath[PATH_MAX + 1] = {0};
sprintf(arg1, "/proc/%d/exe", getpid());
auto bytes_written = readlink(arg1, exepath, 1024);
return std::string(exepath).substr(0, bytes_written - 9);
2014-05-19 09:29:19 +08:00
#endif
}
2016-07-20 10:28:12 +08:00
static std::string get_working_directory()
2016-07-20 10:28:12 +08:00
{
#ifdef _WIN32
TCHAR buffer[MAX_PATH];
GetCurrentDirectory(MAX_PATH, buffer);
std::basic_string<TCHAR> working_directory(buffer);
return windows_to_universal_path(std::string(working_directory.begin(), working_directory.end()));
2016-07-20 10:28:12 +08:00
#else
2016-07-21 07:16:51 +08:00
char buffer[PATH_MAX];
if (getcwd(buffer, 2048) == nullptr)
{
throw std::runtime_error("getcwd failed");
}
2016-07-20 10:28:12 +08:00
return std::string(buffer);
#endif
}
2014-05-19 09:29:19 +08:00
static std::string get_data_directory(const std::string &append = "")
2014-05-19 09:29:19 +08:00
{
2016-07-30 05:50:33 +08:00
auto path = get_executable_directory() + "../../tests/data";
if (!append.empty())
{
if (append.front() != '/')
{
path.push_back('/');
}
path.append(append);
}
return path;
2014-05-19 09:29:19 +08:00
}
2014-05-21 22:20:30 +08:00
static void copy_file(const std::string &source, const std::string &destination, bool overwrite)
2014-05-21 22:20:30 +08:00
{
if(!overwrite && file_exists(destination))
2014-05-21 22:20:30 +08:00
{
throw std::runtime_error("destination file already exists and overwrite==false");
}
2015-11-11 08:46:57 +08:00
std::ifstream src(source, std::ios::binary);
std::ofstream dst(destination, std::ios::binary);
2014-05-21 22:20:30 +08:00
dst << src.rdbuf();
}
2014-06-05 06:42:17 +08:00
static void delete_file(const std::string &path)
2014-06-05 06:42:17 +08:00
{
2015-11-11 08:46:57 +08:00
std::remove(path.c_str());
2014-06-05 06:42:17 +08:00
}
2014-05-21 22:20:30 +08:00
static bool file_exists(const std::string &path)
{
#ifdef _MSC_VER
2015-11-11 08:46:57 +08:00
std::wstring path_wide(path.begin(), path.end());
2014-05-21 22:20:30 +08:00
return PathFileExists(path_wide.c_str()) && !PathIsDirectory(path_wide.c_str());
#else
2014-06-06 05:42:15 +08:00
try
{
struct stat fileAtt;
if (stat(path.c_str(), &fileAtt) == 0)
{
return S_ISREG(fileAtt.st_mode);
}
}
catch(...) {}
2014-06-06 05:42:15 +08:00
return false;
2014-05-21 22:20:30 +08:00
#endif
}
2014-05-22 07:17:56 +08:00
};