2016-02-26 14:45:43 +08:00
|
|
|
#pragma once
|
|
|
|
|
2016-11-02 23:05:02 +08:00
|
|
|
// !! DEPRICATED !!
|
|
|
|
|
2016-02-26 14:45:43 +08:00
|
|
|
#include <string>
|
|
|
|
|
2016-11-02 23:05:02 +08:00
|
|
|
#include "query/util.hpp"
|
2016-07-17 08:22:43 +08:00
|
|
|
|
2016-11-02 23:05:02 +08:00
|
|
|
class Code
|
2016-02-26 14:45:43 +08:00
|
|
|
{
|
2016-11-02 23:05:02 +08:00
|
|
|
public:
|
2016-02-26 14:45:43 +08:00
|
|
|
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-10-19 23:07:40 +08:00
|
|
|
const std::string write_vertex_accessor =
|
|
|
|
" stream.write_record();\n"
|
|
|
|
" stream.write_list_header(1);\n"
|
|
|
|
" stream.write(vertex_accessor);\n"
|
|
|
|
" stream.chunk();\n";
|
|
|
|
|
2016-09-05 17:02:48 +08:00
|
|
|
const std::string write_all_vertices =
|
|
|
|
"stream.write_field(\"{0}\");\n"
|
2016-10-19 23:07:40 +08:00
|
|
|
" iter::for_all(t.vertex_access(), [&](auto vertex_accessor) {{\n"
|
|
|
|
" if (vertex_accessor.fill()) {{\n"
|
|
|
|
+ write_vertex_accessor +
|
2016-09-05 17:02:48 +08:00
|
|
|
" }}\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"
|
2016-10-19 23:07:40 +08:00
|
|
|
" label.index().for_range(t).for_all([&](auto vertex_accessor) {{\n"
|
|
|
|
+ write_vertex_accessor +
|
|
|
|
" }});\n"
|
|
|
|
" stream.write_meta(\"rw\");\n";
|
|
|
|
|
|
|
|
const std::string find_and_write_vertices_by_label_and_properties =
|
2016-11-04 08:49:21 +08:00
|
|
|
"{{\n"
|
|
|
|
" DbAccessor _t(db);\n"
|
|
|
|
" {0}\n"
|
|
|
|
" auto properties = query_properties(indices, args);\n"
|
|
|
|
" auto &label = _t.label_find_or_create(\"{1}\");\n"
|
|
|
|
" stream.write_field(\"{2}\");\n"
|
|
|
|
" label.index().for_range(_t).properties_filter(_t, properties).for_all(\n"
|
|
|
|
" [&](auto vertex_accessor) -> void {{\n"
|
|
|
|
" "+ write_vertex_accessor +
|
|
|
|
" }});\n"
|
|
|
|
" stream.write_meta(\"rw\");\n"
|
|
|
|
" _t.commit();"
|
|
|
|
"}}\n";
|
|
|
|
|
|
|
|
// -- LABELS
|
|
|
|
const std::string set_vertex_element =
|
|
|
|
"{{\n"
|
|
|
|
" DbAccessor _t(db);" // TODO: HACK (set labels should somehow persist the state)
|
|
|
|
" {0}\n"
|
|
|
|
" auto properties = query_properties(indices, args);\n"
|
|
|
|
" auto &label = _t.label_find_or_create(\"{1}\");\n"
|
|
|
|
" label.index().for_range(_t).properties_filter(_t, properties).for_all(\n"
|
2016-10-19 23:07:40 +08:00
|
|
|
" [&](auto vertex_accessor) -> void {{\n"
|
2016-11-04 08:49:21 +08:00
|
|
|
" auto {2} = _t.vertex_property_key(\"{2}\", args[{3}].key.flags());\n"
|
|
|
|
" vertex_accessor.set({2}, std::move(args[{3}]));\n"
|
|
|
|
" }}\n"
|
|
|
|
" );\n"
|
|
|
|
" _t.commit();\n"
|
|
|
|
"}}";
|
|
|
|
|
|
|
|
const std::string set_labels_start =
|
|
|
|
" {{\n"
|
|
|
|
" DbAccessor _t(db);" // TODO: HACK (set labels should somehow persist the state)
|
|
|
|
" {0}\n"
|
|
|
|
" auto properties = query_properties(indices, args);\n"
|
|
|
|
" auto &label = _t.label_find_or_create(\"{1}\");\n"
|
|
|
|
" label.index().for_range(_t).properties_filter(_t, properties).for_all(\n"
|
|
|
|
" [&](auto vertex_accessor) -> void {{\n";
|
|
|
|
const std::string set_label =
|
|
|
|
" auto &{0} = _t.label_find_or_create(\"{0}\");\n"
|
|
|
|
" vertex_accessor.add_label({0});\n";
|
|
|
|
const std::string set_labels_end =
|
|
|
|
" }}\n"
|
|
|
|
" );\n"
|
|
|
|
" _t.commit();"
|
|
|
|
" }}";
|
|
|
|
|
|
|
|
const std::string return_labels =
|
|
|
|
"{{\n"
|
|
|
|
" DbAccessor _t(db);" // TODO: HACK (set labels should somehow persist the state)
|
|
|
|
" {0}\n"
|
|
|
|
" auto properties = query_properties(indices, args);\n"
|
|
|
|
" auto &label = _t.label_find_or_create(\"{1}\");\n"
|
|
|
|
" stream.write_field(\"labels({2})\");\n"
|
|
|
|
" label.index().for_range(_t).properties_filter(_t, properties).for_all(\n"
|
|
|
|
" [&](auto vertex_accessor) -> void {{\n"
|
|
|
|
" auto &labels = vertex_accessor.labels();\n"
|
|
|
|
" stream.write_record();\n"
|
|
|
|
" stream.write_list_header(1);\n" // TODO: figure out why
|
|
|
|
" stream.write_list_header(labels.size());\n"
|
|
|
|
" for (auto &label : labels) {{\n"
|
|
|
|
" stream.write(label.get().str());\n"
|
|
|
|
" }}\n"
|
|
|
|
" stream.chunk();\n"
|
|
|
|
" }}\n"
|
|
|
|
" );\n"
|
|
|
|
" stream.write_meta(\"rw\");\n"
|
|
|
|
" _t.commit();\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
|
2016-11-02 23:05:02 +08:00
|
|
|
const std::string delete_all_detached_nodes =
|
|
|
|
"t.vertex_access().fill().isolated().for_all(\n"
|
|
|
|
" [&](auto a) {{ a.remove(); }});\n"
|
|
|
|
" stream.write_empty_fields();\n"
|
|
|
|
" stream.write_meta(\"w\");\n";
|
|
|
|
const std::string delete_whole_graph =
|
|
|
|
"t.edge_access().fill().for_all(\n"
|
|
|
|
" [&](auto e) { e.remove(); }\n"
|
|
|
|
");\n" + delete_all_detached_nodes;
|