memgraph/include/query_engine/code_compiler.hpp

83 lines
2.2 KiB
C++
Raw Normal View History

#pragma once
#include <string>
#include "exceptions/exceptions.hpp"
#include "logging/default.hpp"
#include "utils/string/join.hpp"
2016-07-18 01:32:35 +08:00
// 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
2016-08-30 12:34:08 +08:00
#ifdef BARRIER
flags += " -DBARRIER";
#endif
#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
2016-07-18 01:32:35 +08:00
// 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../",
2016-08-30 12:34:08 +08:00
#ifdef BARRIER
"-lbarrier_pic",
2016-08-30 12:34:08 +08:00
#endif
"-lmemgraph_pic",
"-shared -fPIC" // shared library flags
);
2016-02-11 06:34:49 +08:00
logger.debug("compile command -> {}", compile_command);
2016-02-11 06:34:49 +08:00
// synchronous call
2016-07-18 01:32:35 +08:00
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");
2016-07-18 01:32:35 +08:00
}
logger.debug("SUCCESS: Query Code Compilation: {} -> {}", in_file,
out_file);
}
protected:
Logger logger;
};