2016-01-27 06:40:11 +08:00
|
|
|
#pragma once
|
|
|
|
|
2016-02-08 05:56:52 +08:00
|
|
|
#include <string>
|
|
|
|
|
2016-07-24 10:47:48 +08:00
|
|
|
#include "exceptions/exceptions.hpp"
|
2016-08-11 11:47:30 +08:00
|
|
|
#include "logging/default.hpp"
|
2016-02-08 05:56:52 +08:00
|
|
|
#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
|
|
|
|
|
2016-01-27 06:40:11 +08:00
|
|
|
class CodeCompiler
|
|
|
|
{
|
2016-02-08 05:56:52 +08:00
|
|
|
public:
|
2016-08-11 11:47:30 +08:00
|
|
|
CodeCompiler() : logger(logging::log->logger("CodeCompiler")) {}
|
|
|
|
|
2016-06-06 17:29:52 +08:00
|
|
|
void compile(const std::string &in_file, const std::string &out_file)
|
2016-02-08 05:56:52 +08:00
|
|
|
{
|
2016-08-19 00:47:49 +08:00
|
|
|
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
|
|
|
|
|
2016-07-18 01:32:35 +08:00
|
|
|
// generate compile command
|
2016-08-11 11:47:30 +08:00
|
|
|
auto compile_command = utils::prints(
|
2016-08-19 00:47:49 +08:00
|
|
|
"clang++" + flags,
|
2016-08-11 11:47:30 +08:00
|
|
|
// "-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../libs/fmt", // TODO: load from config
|
|
|
|
"-L./ -lmemgraph_pic",
|
|
|
|
"-shared -fPIC" // shared library flags
|
|
|
|
);
|
2016-02-11 06:34:49 +08:00
|
|
|
|
2016-08-19 00:47: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) {
|
2016-07-24 10:47:48 +08:00
|
|
|
throw QueryEngineException("Code compilation error. Generated code "
|
|
|
|
"is not compilable or compilation "
|
|
|
|
"settings are wrong");
|
2016-07-18 01:32:35 +08:00
|
|
|
}
|
|
|
|
|
2016-08-11 11:47:30 +08:00
|
|
|
logger.debug("SUCCESS: Query Code Compilation: {} -> {}", in_file,
|
|
|
|
out_file);
|
2016-02-08 05:56:52 +08:00
|
|
|
}
|
2016-08-11 11:47:30 +08:00
|
|
|
|
|
|
|
protected:
|
|
|
|
Logger logger;
|
2016-01-27 06:40:11 +08:00
|
|
|
};
|