#include "vcpkg_Files.h" #include #include #include "vcpkg_System.h" 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_exit(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); } expected> read_all_lines(const fs::path& file_path) { 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; } std::vector output; std::string line; while (std::getline(file_stream, line)) { output.push_back(line); } file_stream.close(); return std::move(output); } void write_all_lines(const fs::path& file_path, const std::vector& lines) { std::fstream output(file_path, std::ios_base::out | std::ios_base::binary | std::ios_base::trunc); for (const std::string& line : lines) { output << line << "\n"; } output.close(); } 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; } void recursive_find_all_files_in_dir(const fs::path& dir, std::vector* output) { recursive_find_matching_paths_in_dir(dir, [&](const fs::path& current) { return !fs::is_directory(current); }, output); } std::vector recursive_find_all_files_in_dir(const fs::path& dir) { std::vector v; recursive_find_all_files_in_dir(dir, &v); return v; } void non_recursive_find_all_files_in_dir(const fs::path& dir, std::vector* output) { non_recursive_find_matching_paths_in_dir(dir, [&](const fs::path& current) { return !fs::is_directory(current); }, output); } std::vector non_recursive_find_all_files_in_dir(const fs::path& dir) { std::vector v; non_recursive_find_all_files_in_dir(dir, &v); return v; } void print_paths(const std::vector& paths) { System::println(""); for (const fs::path& p : paths) { System::println(" %s", p.generic_string()); } System::println(""); } }}