#pragma once #include #include "exceptions/exceptions.hpp" #include "logging/default.hpp" #include "utils/string/join.hpp" // TODO: // * all libraries have to be compiled in the server compile time // * compile command has to be generated class CodeCompiler { public: CodeCompiler() : logger(logging::log->logger("CodeCompiler")) {} void compile(const std::string &in_file, const std::string &out_file) { std::string flags; // TODO: sync this with cmake configuration #ifdef NDEBUG flags += " -DNDEBUG -O2"; #endif #ifdef LOG_NO_TRACE flags += " -DLOG_NO_TRACE"; #endif #ifdef LOG_NO_DEBUG flags += " -DLOG_NO_DEBUG"; #endif #ifdef LOG_NO_INFO flags += " -DLOG_NO_INFO"; #endif #ifdef LOG_NO_WARN flags += " -DLOG_NO_WARN"; #endif #ifdef LOG_NO_ERROR flags += " -DLOG_NO_ERROR"; #endif // generate compile command auto compile_command = utils::prints( "clang++" + flags, // "-std=c++1y -O2 -DNDEBUG", // compile flags "-std=c++1y", // compile flags // TODO: load from config file in_file, // input file "-o", out_file, // ouput file "-I./include", // include paths (TODO: parameter) "-I../include", "-I../libs/fmt", // TODO: load from config "-I../../libs/fmt", "-L./ -L../", "-lmemgraph_pic", "-shared -fPIC" // shared library flags ); logger.debug("compile command -> {}", compile_command); // synchronous call auto compile_status = system(compile_command.c_str()); // if compilation has failed throw exception if (compile_status == -1) { throw QueryEngineException("Code compilation error. Generated code " "is not compilable or compilation " "settings are wrong"); } logger.debug("SUCCESS: Query Code Compilation: {} -> {}", in_file, out_file); } protected: Logger logger; };