2016-01-27 06:40:11 +08:00
|
|
|
#pragma once
|
|
|
|
|
2016-01-28 07:29:38 +08:00
|
|
|
#include "cypher/ast/ast.hpp"
|
2016-01-31 01:57:18 +08:00
|
|
|
#include "cypher/compiler.hpp"
|
|
|
|
#include "traverser/node_traverser.hpp"
|
|
|
|
|
|
|
|
// The purpose of this class is to find out has
|
|
|
|
// the query already been compiled into the machine code / c++ code
|
|
|
|
// in the same pass query arguments should be extracted (e.g. poperties
|
|
|
|
// or node names)
|
|
|
|
|
|
|
|
// if the query has already been comiled into the machine code
|
|
|
|
// than it shouldn't be compiled again
|
2016-01-28 07:29:38 +08:00
|
|
|
|
2016-01-27 06:40:11 +08:00
|
|
|
class QueryTraverser
|
|
|
|
{
|
2016-01-28 07:29:38 +08:00
|
|
|
public:
|
|
|
|
QueryTraverser() = default;
|
|
|
|
|
|
|
|
void build_tree(const std::string& query)
|
|
|
|
{
|
|
|
|
tree = compiler.syntax_tree(query);
|
|
|
|
}
|
|
|
|
|
|
|
|
void traverse()
|
|
|
|
{
|
|
|
|
tree.root->accept(traverser);
|
2016-01-31 01:57:18 +08:00
|
|
|
for (auto& kv : traverser.json) {
|
|
|
|
cout << "Key: " << kv.first << ", Value: " << kv.second << endl;
|
|
|
|
}
|
2016-01-28 07:29:38 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
ast::Ast tree;
|
|
|
|
cypher::Compiler compiler;
|
2016-01-31 01:57:18 +08:00
|
|
|
NodeTraverser traverser;
|
2016-01-27 06:40:11 +08:00
|
|
|
};
|