2017-02-28 01:23:38 +08:00
|
|
|
//
|
|
|
|
// Created by buda on 27/02/17.
|
|
|
|
//
|
|
|
|
|
|
|
|
#include <experimental/filesystem>
|
|
|
|
namespace fs = std::experimental::filesystem;
|
2017-04-11 20:55:57 +08:00
|
|
|
|
2017-02-28 01:23:38 +08:00
|
|
|
#include "logging/streams/stdout.hpp"
|
|
|
|
#include "query/preprocessor.hpp"
|
|
|
|
#include "utils/command_line/arguments.hpp"
|
2017-04-19 21:52:20 +08:00
|
|
|
#include "utils/exceptions.hpp"
|
2017-04-11 20:55:57 +08:00
|
|
|
#include "utils/file.hpp"
|
2017-04-18 18:11:25 +08:00
|
|
|
#include "utils/string.hpp"
|
2017-04-11 20:55:57 +08:00
|
|
|
|
2017-04-18 18:11:25 +08:00
|
|
|
/**
|
|
|
|
* Reads a query from the file specified by the path argument.
|
|
|
|
* The first line of a query should start with "// Query: ". Query can be
|
|
|
|
* in more than one line but every line has to start with "//".
|
|
|
|
*
|
|
|
|
* @param path to the query file.
|
|
|
|
* @return query as a string.
|
|
|
|
*/
|
|
|
|
|
|
|
|
std::string ExtractQuery(const fs::path &path) {
|
2017-04-11 20:55:57 +08:00
|
|
|
auto comment_mark = std::string("// ");
|
|
|
|
auto query_mark = comment_mark + std::string("Query: ");
|
2017-04-18 18:11:25 +08:00
|
|
|
auto lines = utils::ReadLines(path);
|
2017-04-11 20:55:57 +08:00
|
|
|
// find the line with a query (the query can be split across multiple
|
|
|
|
// lines)
|
2017-04-18 18:11:25 +08:00
|
|
|
for (int i = 0; i < static_cast<int>(lines.size()); ++i) {
|
2017-04-11 20:55:57 +08:00
|
|
|
// find query in the line
|
|
|
|
auto &line = lines[i];
|
|
|
|
auto pos = line.find(query_mark);
|
|
|
|
// if query doesn't exist pass
|
|
|
|
if (pos == std::string::npos) continue;
|
2017-04-18 18:11:25 +08:00
|
|
|
auto query = utils::Trim(line.substr(pos + query_mark.size()));
|
|
|
|
while (i + 1 < static_cast<int>(lines.size()) &&
|
2017-04-11 20:55:57 +08:00
|
|
|
lines[i + 1].find(comment_mark) != std::string::npos) {
|
|
|
|
query += lines[i + 1].substr(lines[i + 1].find(comment_mark) +
|
|
|
|
comment_mark.length());
|
|
|
|
++i;
|
|
|
|
}
|
|
|
|
return query;
|
|
|
|
}
|
|
|
|
|
2017-04-19 21:52:20 +08:00
|
|
|
throw utils::BasicException("Unable to find query!");
|
2017-04-11 20:55:57 +08:00
|
|
|
}
|
2017-02-28 01:23:38 +08:00
|
|
|
|
|
|
|
int main(int argc, char **argv) {
|
|
|
|
logging::init_sync();
|
|
|
|
logging::log->pipe(std::make_unique<Stdout>());
|
|
|
|
|
|
|
|
auto logger = logging::log->logger("CopyHardcodedQueries");
|
|
|
|
logger.info("{}", logging::log->type());
|
|
|
|
|
|
|
|
REGISTER_ARGS(argc, argv);
|
|
|
|
|
|
|
|
auto src_path = fs::path(
|
|
|
|
GET_ARG("--src", "tests/integration/hardcoded_queries").get_string());
|
|
|
|
logger.info("Src path is: {}", src_path);
|
|
|
|
permanent_assert(fs::exists(src_path), "src folder must exist");
|
|
|
|
|
|
|
|
auto dst_path =
|
|
|
|
fs::path(GET_ARG("--dst", "build/compiled/hardcode").get_string());
|
|
|
|
logger.info("Dst path is: {}", dst_path);
|
|
|
|
fs::create_directories(dst_path);
|
|
|
|
|
|
|
|
auto src_files = utils::LoadFilePaths(src_path, "cpp");
|
|
|
|
|
|
|
|
QueryPreprocessor preprocessor;
|
|
|
|
for (auto &src_file : src_files) {
|
2017-04-18 18:11:25 +08:00
|
|
|
auto query = ExtractQuery(src_file);
|
2017-02-28 01:23:38 +08:00
|
|
|
auto query_hash = preprocessor.preprocess(query).hash;
|
|
|
|
auto dst_file = dst_path / fs::path(std::to_string(query_hash) + ".cpp");
|
|
|
|
fs::copy(src_file, dst_file, fs::copy_options::overwrite_existing);
|
|
|
|
logger.info("{} - (copy) -> {}", src_file, dst_file);
|
|
|
|
}
|
|
|
|
|
|
|
|
auto hpp_files = utils::LoadFilePaths(src_path, "hpp");
|
|
|
|
for (auto &hpp_file : hpp_files) {
|
|
|
|
fs::copy(hpp_file, dst_path / hpp_file.filename(),
|
|
|
|
fs::copy_options::overwrite_existing);
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
2017-04-11 20:55:57 +08:00
|
|
|
}
|