2016-02-26 14:45:43 +08:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <string>
|
|
|
|
|
2016-07-17 08:22:43 +08:00
|
|
|
#include "query_engine/util.hpp"
|
|
|
|
|
2016-02-26 14:45:43 +08:00
|
|
|
struct Code
|
|
|
|
{
|
|
|
|
std::string code;
|
2016-08-30 08:01:03 +08:00
|
|
|
|
|
|
|
void reset() { code = ""; }
|
2016-02-26 14:45:43 +08:00
|
|
|
};
|
2016-07-17 08:22:43 +08:00
|
|
|
|
|
|
|
namespace code
|
|
|
|
{
|
|
|
|
|
2016-08-30 08:01:03 +08:00
|
|
|
// TODO: one more abstraction level
|
2016-07-17 08:22:43 +08:00
|
|
|
// TODO: UNIT tests
|
|
|
|
|
2016-08-20 01:40:04 +08:00
|
|
|
const std::string transaction_begin = "DbAccessor t(db);";
|
2016-07-17 08:22:43 +08:00
|
|
|
|
|
|
|
const std::string transaction_commit = "t.commit();";
|
|
|
|
|
2016-09-05 17:02:48 +08:00
|
|
|
const std::string set_property = "{}.set({}, std::move(args[{}]));";
|
2016-08-01 01:58:12 +08:00
|
|
|
|
2016-07-25 09:09:40 +08:00
|
|
|
// create vertex e.g. CREATE (n:PERSON {name: "Test", age: 23})
|
2016-08-20 01:40:04 +08:00
|
|
|
const std::string create_vertex = "auto {} = t.vertex_insert();";
|
|
|
|
const std::string create_label = "auto &{0} = t.label_find_or_create(\"{0}\");";
|
2016-07-25 09:09:40 +08:00
|
|
|
const std::string add_label = "{}.add_label({});";
|
2016-07-17 08:22:43 +08:00
|
|
|
|
2016-08-20 01:40:04 +08:00
|
|
|
const std::string vertex_property_key =
|
2016-09-05 17:02:48 +08:00
|
|
|
"auto {}=t.vertex_property_key(\"{}\",args[{}].key.flags());";
|
2016-08-20 01:40:04 +08:00
|
|
|
const std::string edge_property_key =
|
2016-09-05 17:02:48 +08:00
|
|
|
"auto {}=t.edge_property_key(\"{}\",args[{}].key.flags());";
|
2016-08-20 01:40:04 +08:00
|
|
|
|
2016-08-01 01:58:12 +08:00
|
|
|
// create edge e.g CREATE (n1)-[r:COST {cost: 100}]->(n2)
|
2016-08-20 01:40:04 +08:00
|
|
|
const std::string create_edge = "auto {} = t.edge_insert({},{});";
|
|
|
|
const std::string find_type = "auto &{0} = t.type_find_or_create(\"{0}\");";
|
2016-08-01 01:58:12 +08:00
|
|
|
const std::string set_type = "{}.edge_type({});";
|
|
|
|
|
2016-09-05 17:02:48 +08:00
|
|
|
const std::string args_id = "Int32 id = args[{}].as<Int32>();";
|
2016-07-17 08:22:43 +08:00
|
|
|
|
|
|
|
const std::string vertex_accessor_args_id =
|
2016-09-05 17:02:48 +08:00
|
|
|
"auto vertex_accessor = t.vertex_find(id.value());";
|
2016-07-17 08:22:43 +08:00
|
|
|
|
2016-07-24 10:47:48 +08:00
|
|
|
const std::string match_vertex_by_id =
|
2016-09-05 17:02:48 +08:00
|
|
|
"auto option_{0} = t.vertex_find(args[{1}].as<Int64>().value());\n"
|
2016-08-20 01:40:04 +08:00
|
|
|
" if (!option_fill(option_{0})) return t.commit(), false;\n"
|
|
|
|
" auto {0}=option_{0}.take();";
|
2016-07-25 09:09:40 +08:00
|
|
|
const std::string match_edge_by_id =
|
2016-09-05 17:02:48 +08:00
|
|
|
"auto option_{0} = t.edge_find(args[{1}].as<Int64>().value());\n"
|
2016-08-20 01:40:04 +08:00
|
|
|
" if (!option_fill(option_{0})) return t.commit(), false;\n"
|
|
|
|
" auto {0}=option_{0}.take();";
|
2016-07-24 10:47:48 +08:00
|
|
|
|
2016-08-20 01:40:04 +08:00
|
|
|
const std::string write_entity = "stream.write_field(\"{0}\");\n"
|
|
|
|
" stream.write_record();\n"
|
|
|
|
" stream.write_list_header(1);\n"
|
|
|
|
" stream.write({0});\n"
|
2016-08-29 01:50:54 +08:00
|
|
|
" stream.chunk();"
|
|
|
|
" stream.write_meta(\"rw\");\n";
|
2016-08-11 11:47:30 +08:00
|
|
|
|
2016-09-05 17:02:48 +08:00
|
|
|
const std::string write_all_vertices =
|
|
|
|
"stream.write_field(\"{0}\");\n"
|
|
|
|
" iter::for_all(t.vertex_access(), [&](auto vertex) {{\n"
|
|
|
|
" if (vertex.fill()) {{\n"
|
|
|
|
" stream.write_record();\n"
|
|
|
|
" stream.write_list_header(1);\n"
|
|
|
|
" stream.write(vertex);\n"
|
|
|
|
" stream.chunk();\n"
|
|
|
|
" }}\n"
|
|
|
|
" }});\n"
|
|
|
|
" stream.write_meta(\"rw\");\n";
|
2016-08-30 08:01:03 +08:00
|
|
|
|
2016-08-31 03:52:46 +08:00
|
|
|
const std::string find_and_write_vertices_by_label =
|
2016-09-05 17:02:48 +08:00
|
|
|
"auto &label = t.label_find_or_create(\"{1}\");\n"
|
|
|
|
" stream.write_field(\"{0}\");\n"
|
|
|
|
" label.index().for_range(t).for_all([&](auto vertex) {{\n"
|
|
|
|
" stream.write_record();\n"
|
|
|
|
" stream.write_list_header(1);\n"
|
|
|
|
" stream.write(vertex);\n"
|
|
|
|
" stream.chunk();\n"
|
|
|
|
" }});\n"
|
|
|
|
" stream.write_meta(\"rw\");\n";
|
2016-08-30 12:34:08 +08:00
|
|
|
|
|
|
|
const std::string write_all_edges =
|
2016-09-05 17:02:48 +08:00
|
|
|
"stream.write_field(\"{0}\");\n"
|
|
|
|
" iter::for_all(t.edge_access(), [&](auto edge) {{\n"
|
|
|
|
" if (edge.fill()) {{\n"
|
|
|
|
" stream.write_record();\n"
|
|
|
|
" stream.write_list_header(1);\n"
|
|
|
|
" stream.write(edge);\n"
|
|
|
|
" stream.chunk();\n"
|
|
|
|
" }}\n"
|
|
|
|
" }});\n"
|
|
|
|
" stream.write_meta(\"rw\");\n";
|
2016-08-30 12:34:08 +08:00
|
|
|
|
2016-08-31 03:52:46 +08:00
|
|
|
const std::string find_and_write_edges_by_type =
|
2016-09-05 17:02:48 +08:00
|
|
|
"auto &type = t.type_find_or_create(\"{1}\");\n"
|
|
|
|
" stream.write_field(\"{0}\");\n"
|
|
|
|
" type.index().for_range(t).for_all([&](auto edge) {{\n"
|
|
|
|
" stream.write_record();\n"
|
|
|
|
" stream.write_list_header(1);\n"
|
|
|
|
" stream.write(edge);\n"
|
|
|
|
" stream.chunk();\n"
|
|
|
|
" }});\n"
|
|
|
|
" stream.write_meta(\"rw\");\n";
|
2016-08-31 03:52:46 +08:00
|
|
|
|
2016-10-13 21:42:19 +08:00
|
|
|
const std::string count_vertices_for_one_label =
|
|
|
|
"size_t count = 0;\n"
|
|
|
|
"auto &label = t.label_find_or_create(\"{1}\");\n"
|
|
|
|
" label.index().for_range(t).for_all([&](auto vertex) {{\n"
|
|
|
|
" count++;\n"
|
|
|
|
" }});\n"
|
|
|
|
" stream.write_field(\"count({0})\");\n"
|
|
|
|
" stream.write_record();\n"
|
|
|
|
" stream.write_list_header(1);\n"
|
|
|
|
" stream.write(Int64(count));\n"
|
|
|
|
" stream.chunk();\n"
|
|
|
|
" stream.write_meta(\"r\");\n";
|
|
|
|
|
2016-09-14 19:19:56 +08:00
|
|
|
// TODO: vertices and edges
|
|
|
|
const std::string count =
|
|
|
|
"size_t count = 0;\n"
|
|
|
|
" t.vertex_access().fill().for_all(\n"
|
|
|
|
" [&](auto vertex) {{ ++count; }});\n"
|
|
|
|
" stream.write_field(\"count({0})\");\n"
|
|
|
|
" stream.write_record();\n"
|
|
|
|
" stream.write_list_header(1);\n"
|
|
|
|
" stream.write(Int64(count));\n"
|
|
|
|
" stream.chunk();\n"
|
|
|
|
" stream.write_meta(\"r\");\n";
|
|
|
|
|
2016-08-11 11:47:30 +08:00
|
|
|
const std::string return_true = "return true;";
|
2016-07-17 08:22:43 +08:00
|
|
|
|
|
|
|
const std::string todo = "// TODO: {}";
|
2016-08-02 22:41:53 +08:00
|
|
|
const std::string print_properties =
|
|
|
|
"cout << \"{0}\" << endl;\n"
|
|
|
|
" cout_properties({0}.properties());";
|
|
|
|
const std::string print_property =
|
|
|
|
"cout_property(\"{0}\", {0}.property(\"{1}\"));";
|
2016-07-17 08:22:43 +08:00
|
|
|
}
|
2016-10-11 08:43:41 +08:00
|
|
|
|
|
|
|
// DELETE
|
|
|
|
const std::string detach_delete_all_nodes =
|
|
|
|
"t.vertex_access().fill().isolated().for_all("
|
|
|
|
" [&](auto a) {{ a.remove(); }});";
|