memgraph/cypher/parser.cpp

66 lines
1.8 KiB
C++
Raw Normal View History

#include <cstdlib>
#include <vector>
#include <vector>
2015-10-19 01:44:00 +08:00
#include "compiler.hpp"
2015-10-30 08:24:01 +08:00
#include "debug/tree_print.hpp"
#include "codegen/cppgen.hpp"
2015-10-30 08:24:01 +08:00
using std::cout;
using std::endl;
using vector_str = std::vector<std::string>;
2015-10-30 08:24:01 +08:00
// TODO: extract from here
// TODO: write more safe and optimal
vector_str all_arguments(int argc, char *argv[])
{
vector_str args(argv + 1, argv + argc);
return args;
}
2015-10-30 08:24:01 +08:00
std::string get_argument(const vector_str& all,
const std::string& flag,
const std::string& default_value)
{
auto it = std::find(all.begin(), all.end(), flag);
if (it == all.end()) {
return default_value;
}
auto pos = std::distance(all.begin(), it);
return all[pos + 1];
}
2015-10-30 08:24:01 +08:00
// * QUERY EXAMPLES *
// "CREATE (n { name: 'Dominik', age: 24, role: 'CEO' }) return n"
// "MATCH (user:User { name: 'Dominik', age: 8 + 4})-[has:HAS|IS|CAN { duration: 'PERMANENT'}]->(item:Item)--(shop)"
// "MATCH (user:User { name: 'Dominik', age: 24})-[has:HAS]->(item:Item) WHERE item.name = 'XPS 13' AND item.price = 11999.99 RETURN user, has, item"
2015-10-30 08:24:01 +08:00
// * INPUT ARGUMENTS *
// -q -> query
// -v -> visitor
2015-10-30 08:24:01 +08:00
int main(int argc, char *argv[])
{
// arguments parsing
auto arguments = all_arguments(argc, argv);
auto cypher_query = get_argument(arguments, "-q", "CREATE (n {name: 'Domko', age: 24}) return n");
auto traverser = get_argument(arguments, "-t", "print");
// traversers
auto print_traverser = Traverser::sptr(new PrintVisitor(cout));
auto cppgen_traverser = Traverser::sptr(new CppGen());
std::map<std::string, Traverser::sptr> traversers = {
{"print", print_traverser},
{"code", cppgen_traverser}
};
2015-10-30 08:24:01 +08:00
cypher::Compiler compiler;
auto tree = compiler.syntax_tree(cypher_query);
2015-10-19 01:44:00 +08:00
2015-10-30 08:24:01 +08:00
auto t = traversers[traverser];
tree.root->accept(*t);
return 0;
}