lbug 0.16.1

An in-process property graph database management system built for query speed and scalability
Documentation
#pragma once

#include "join_tree.h"
#include "planner/planner.h"

namespace lbug {
namespace planner {

class JoinPlanSolver {
public:
    explicit JoinPlanSolver(Planner* planner) : planner{planner} {}

    LogicalPlan solve(const JoinTree& joinTree);

private:
    LogicalPlan solveTreeNode(const JoinTreeNode& current, const JoinTreeNode* parent);

    LogicalPlan solveNodeScanTreeNode(const JoinTreeNode& treeNode);
    LogicalPlan solveRelScanTreeNode(const JoinTreeNode& treeNode, const JoinTreeNode& parent);
    LogicalPlan solveBinaryJoinTreeNode(const JoinTreeNode& treeNode);
    LogicalPlan solveMultiwayJoinTreeNode(const JoinTreeNode& treeNode);

private:
    Planner* planner;
};

} // namespace planner
} // namespace lbug