cppgen test
This commit is contained in:
parent
bce9762add
commit
e5d2c3af86
@ -3,13 +3,25 @@
|
|||||||
|
|
||||||
#include "cypher/visitor/traverser.hpp"
|
#include "cypher/visitor/traverser.hpp"
|
||||||
|
|
||||||
|
#include <iostream>
|
||||||
|
using std::cout;
|
||||||
|
using std::endl;
|
||||||
|
|
||||||
class CppGen : public Traverser
|
class CppGen : public Traverser
|
||||||
{
|
{
|
||||||
struct CreateGen : public Traverser
|
struct CreateGen : public Traverser
|
||||||
{
|
{
|
||||||
void visit(ast::Pattern& pattern) override
|
void visit(ast::Pattern& pattern) override
|
||||||
{
|
{
|
||||||
|
Traverser::visit(pattern);
|
||||||
|
}
|
||||||
|
|
||||||
|
void visit(ast::Node& node) override
|
||||||
|
{
|
||||||
|
auto next_node = node.props->next;
|
||||||
|
cout << next_node->value->idn->name;
|
||||||
|
|
||||||
|
Traverser::visit(node);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -17,10 +29,10 @@ public:
|
|||||||
|
|
||||||
void visit(ast::Start& start) override
|
void visit(ast::Start& start) override
|
||||||
{
|
{
|
||||||
|
Traverser::visit(start);
|
||||||
}
|
}
|
||||||
|
|
||||||
void visit(ast::Create create) override
|
void visit(ast::Create& create) override
|
||||||
{
|
{
|
||||||
auto create_gen = CreateGen();
|
auto create_gen = CreateGen();
|
||||||
create.accept(create_gen);
|
create.accept(create_gen);
|
||||||
|
@ -4,8 +4,6 @@
|
|||||||
#include "cypher_lexer.hpp"
|
#include "cypher_lexer.hpp"
|
||||||
#include "parser.hpp"
|
#include "parser.hpp"
|
||||||
|
|
||||||
#include "debug/tree_print.hpp"
|
|
||||||
|
|
||||||
namespace cypher
|
namespace cypher
|
||||||
{
|
{
|
||||||
|
|
||||||
@ -14,14 +12,12 @@ class Compiler
|
|||||||
public:
|
public:
|
||||||
Compiler() = default;
|
Compiler() = default;
|
||||||
|
|
||||||
void compile(const std::string& input)
|
ast::Ast syntax_tree(const std::string& input)
|
||||||
{
|
{
|
||||||
auto parser = cypher::Parser();
|
auto parser = cypher::Parser();
|
||||||
auto tokenizer = lexer.tokenize(input);
|
auto tokenizer = lexer.tokenize(input);
|
||||||
auto tree = parser.parse(tokenizer);
|
auto tree = parser.parse(tokenizer);
|
||||||
|
return std::move(tree);
|
||||||
PrintVisitor printer(std::cout);
|
|
||||||
tree.root->accept(printer);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -97,7 +97,7 @@ pattern(P) ::= node(N). {
|
|||||||
|
|
||||||
%type rel {ast::Relationship*}
|
%type rel {ast::Relationship*}
|
||||||
|
|
||||||
rel(R) ::= MINUS rel_spec(S) MINUS. { // unidirectional
|
rel(R) ::= MINUS rel_spec(S) MINUS. { // bidirectional
|
||||||
R = ast->create<ast::Relationship>(S, ast::Relationship::Both);
|
R = ast->create<ast::Relationship>(S, ast::Relationship::Both);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -15,7 +15,7 @@ public:
|
|||||||
Printer(std::ostream& stream, const std::string& header)
|
Printer(std::ostream& stream, const std::string& header)
|
||||||
: stream(stream)
|
: stream(stream)
|
||||||
{
|
{
|
||||||
stream << header;
|
// stream << header;
|
||||||
}
|
}
|
||||||
|
|
||||||
~Printer()
|
~Printer()
|
||||||
|
@ -3,52 +3,62 @@
|
|||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include "compiler.hpp"
|
#include "compiler.hpp"
|
||||||
|
#include "debug/tree_print.hpp"
|
||||||
|
#include "codegen/cppgen.hpp"
|
||||||
|
|
||||||
int main()
|
using std::cout;
|
||||||
|
using std::endl;
|
||||||
|
using vector_str = std::vector<std::string>;
|
||||||
|
|
||||||
|
// 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;
|
||||||
|
}
|
||||||
|
|
||||||
|
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];
|
||||||
|
}
|
||||||
|
|
||||||
|
// * 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"
|
||||||
|
|
||||||
|
// * INPUT ARGUMENTS *
|
||||||
|
// -q -> query
|
||||||
|
// -v -> visitor
|
||||||
|
|
||||||
|
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}
|
||||||
|
};
|
||||||
|
|
||||||
cypher::Compiler compiler;
|
cypher::Compiler compiler;
|
||||||
|
auto tree = compiler.syntax_tree(cypher_query);
|
||||||
|
|
||||||
//std::string input("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");
|
auto t = traversers[traverser];
|
||||||
|
tree.root->accept(*t);
|
||||||
std::string input("create (n { name: 'Dominik', age: 24 }) return n");
|
|
||||||
|
|
||||||
compiler.compile(input);
|
|
||||||
|
|
||||||
/* void* parser = cy */
|
|
||||||
/* CypherLexer lexer; */
|
|
||||||
|
|
||||||
/* //std::string input("matcH (user:User { name: 'Dominik', age: 8 + 4})-[has:HAS|IS|CAN { duration: 'PERMANENT'}]->(item:Item)--(shop)"); */
|
|
||||||
|
|
||||||
/* std::string input("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"); */
|
|
||||||
|
|
||||||
/* auto tokenizer = lexer.tokenize(input); */
|
|
||||||
|
|
||||||
/* std::vector<Token> v; */
|
|
||||||
|
|
||||||
/* while(true) */
|
|
||||||
/* { */
|
|
||||||
/* v.push_back(tokenizer.lookup()); */
|
|
||||||
/* auto token = v.back(); */
|
|
||||||
|
|
||||||
/* //std::cout << token->id << " -> " << token->value << std::endl; */
|
|
||||||
|
|
||||||
/* auto ast = new ast::Ast(); */
|
|
||||||
|
|
||||||
/* try */
|
|
||||||
/* { */
|
|
||||||
/* cypher_parser(parser, token.id, &token, ast); */
|
|
||||||
/* } */
|
|
||||||
/* catch(...) */
|
|
||||||
/* { */
|
|
||||||
/* std::cout << "caught exception." << std::endl; */
|
|
||||||
/* exit(0); */
|
|
||||||
/* } */
|
|
||||||
|
|
||||||
/* if(token.id == 0) */
|
|
||||||
/* break; */
|
|
||||||
/* } */
|
|
||||||
|
|
||||||
/* cypher_parserFree(parser, free); */
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -36,7 +36,7 @@ public:
|
|||||||
{
|
{
|
||||||
tokens.emplace_back(tokenizer.lookup());
|
tokens.emplace_back(tokenizer.lookup());
|
||||||
auto& token = tokens.back();
|
auto& token = tokens.back();
|
||||||
std::cout << token << std::endl;
|
// std::cout << token << std::endl;
|
||||||
cypher_parser(parser, token.id, &token, &tree);
|
cypher_parser(parser, token.id, &token, &tree);
|
||||||
|
|
||||||
} while(tokens.back().id != 0);
|
} while(tokens.back().id != 0);
|
||||||
|
@ -1,10 +0,0 @@
|
|||||||
#include <iostream>
|
|
||||||
|
|
||||||
#include "ast/float.hpp"
|
|
||||||
|
|
||||||
int main(void)
|
|
||||||
{
|
|
||||||
auto f = new Float(3);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
@ -8,6 +8,9 @@ class Traverser : public ast::AstVisitor
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
||||||
|
using uptr = std::unique_ptr<Traverser>;
|
||||||
|
using sptr = std::shared_ptr<Traverser>;
|
||||||
|
|
||||||
void visit(ast::Start& start) override
|
void visit(ast::Start& start) override
|
||||||
{
|
{
|
||||||
accept(start.read_query);
|
accept(start.read_query);
|
||||||
|
Loading…
Reference in New Issue
Block a user