// Copyright 2021 Memgraph Ltd. // // Use of this software is governed by the Business Source License // included in the file licenses/BSL.txt; by using this file, you agree to be bound by the terms of the Business Source // License, and you may not use this file except in compliance with the Business Source License. // // As of the Change Date specified in that file, in accordance with // the Business Source License, use of this software will be governed // by the Apache License, Version 2.0, included in the file // licenses/APL.txt. #pragma once #include #include #include #include #include #include "query/db_accessor.hpp" #include "query/frontend/semantic/symbol_table.hpp" #include "query/plan/operator.hpp" namespace database { class GraphDbAccessor; } struct InteractivePlan { // Original plan after going only through the RuleBasedPlanner. std::unique_ptr unoptimized_plan; // Storage for the AST used in unoptimized_plan query::AstStorage ast_storage; // Final plan after being rewritten and optimized. std::unique_ptr final_plan; // Cost of the final plan. double cost; }; typedef std::vector PlansWithCost; // Encapsulates a consoles command function. struct Command { typedef std::vector Args; // Function of this command std::function function; // Number of arguments the function works with. int arg_count; // Explanation of the command. std::string documentation; }; #define DEFCOMMAND(Name) \ void Name##Command(query::DbAccessor &dba, const query::SymbolTable &symbol_table, PlansWithCost &plans, \ const Command::Args &args, const query::AstStorage &ast_storage) void AddCommand(const std::string &name, const Command &command); void RunInteractivePlanning(query::DbAccessor *dba);