lbug 0.15.4

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

#include "planner/operator/logical_operator.h"

namespace lbug {
namespace planner {

class LogicalUnwind : public LogicalOperator {
public:
    LogicalUnwind(std::shared_ptr<binder::Expression> inExpr,
        std::shared_ptr<binder::Expression> outExpr, std::shared_ptr<binder::Expression> idExpr,
        std::shared_ptr<LogicalOperator> childOperator)
        : LogicalOperator{LogicalOperatorType::UNWIND, std::move(childOperator)},
          inExpr{std::move(inExpr)}, outExpr{std::move(outExpr)}, idExpr{std::move(idExpr)} {}

    f_group_pos_set getGroupsPosToFlatten();

    void computeFactorizedSchema() override;
    void computeFlatSchema() override;

    std::shared_ptr<binder::Expression> getInExpr() const { return inExpr; }
    std::shared_ptr<binder::Expression> getOutExpr() const { return outExpr; }
    bool hasIDExpr() const { return idExpr != nullptr; }
    std::shared_ptr<binder::Expression> getIDExpr() const { return idExpr; }

    std::string getExpressionsForPrinting() const override { return inExpr->toString(); }

    std::unique_ptr<LogicalOperator> copy() override {
        return make_unique<LogicalUnwind>(inExpr, outExpr, idExpr, children[0]->copy());
    }

private:
    std::shared_ptr<binder::Expression> inExpr;
    std::shared_ptr<binder::Expression> outExpr;
    std::shared_ptr<binder::Expression> idExpr;
};

} // namespace planner
} // namespace lbug