#include #include #include "query/backend/cpp/typed_value.hpp" #include "query/plan_interface.hpp" #include "storage/edge_accessor.hpp" #include "storage/vertex_accessor.hpp" #include "using.hpp" #include "query/parameters.hpp" using std::cout; using std::endl; // Query: MATCH (g:garment {garment_id: 1234}) RETURN g class CPUPlan : public PlanInterface { public: bool run(GraphDbAccessor &db_accessor, const Parameters &args, Stream &stream) { stream.write_field("g"); for (auto vertex : db_accessor.vertices()) { if (vertex.has_label(db_accessor.label("garment"))) { TypedValue prop = vertex.PropsAt(db_accessor.property("garment_id")); if (prop.type() == TypedValue::Type::Null) continue; auto cmp = prop == args.At(0); if (cmp.type() != TypedValue::Type::Bool) continue; if (cmp.Value() != true) continue; stream.write_vertex_record(vertex); } } stream.write_meta("r"); db_accessor.commit(); return true; } ~CPUPlan() {} }; extern "C" PlanInterface *produce() { return new CPUPlan(); } extern "C" void destruct(PlanInterface *p) { delete p; }