#include "vcpkg_Files.h" #include #include #include namespace fs = std::tr2::sys; namespace vcpkg {namespace Files { static const std::regex FILESYSTEM_INVALID_CHARACTERS_REGEX = std::regex(R"([\/:*?"<>|])"); void check_is_directory(const fs::path& dirpath) { Checks::check_throw(fs::is_directory(dirpath), "The path %s is not a directory", dirpath.string()); } bool has_invalid_chars_for_filesystem(const std::string s) { return std::regex_search(s, FILESYSTEM_INVALID_CHARACTERS_REGEX); } expected get_contents(const fs::path& file_path) noexcept { std::fstream file_stream(file_path, std::ios_base::in | std::ios_base::binary); if (file_stream.fail()) { return std::errc::no_such_file_or_directory; } file_stream.seekg(0, file_stream.end); auto length = file_stream.tellg(); file_stream.seekg(0, file_stream.beg); if (length > SIZE_MAX) { return std::errc::file_too_large; } std::string output; output.resize(static_cast(length)); file_stream.read(&output[0], length); file_stream.close(); return std::move(output); } fs::path find_file_recursively_up(const fs::path& starting_dir, const std::string& filename) { fs::path current_dir = starting_dir; for (; !current_dir.empty(); current_dir = current_dir.parent_path()) { const fs::path candidate = current_dir / filename; if (fs::exists(candidate)) { break; } } return current_dir; } void recursive_find_files_with_extension_in_dir(const fs::path& dir, const std::string& extension, std::vector* output) { recursive_find_matching_paths_in_dir(dir, [&extension](const fs::path& current) { return !fs::is_directory(current) && current.extension() == extension; }, output); } std::vector recursive_find_files_with_extension_in_dir(const fs::path& dir, const std::string& extension) { std::vector v; recursive_find_files_with_extension_in_dir(dir, extension, &v); return v; } }}