lbug 0.16.1

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

#include "common/types/value/value.h"
#include "processor/operator/physical_operator.h"

namespace lbug {
namespace main {
struct Option;
}
namespace processor {

struct StandaloneCallPrintInfo final : OPPrintInfo {
    std::string functionName;

    explicit StandaloneCallPrintInfo(std::string functionName)
        : functionName(std::move(functionName)) {}

    std::string toString() const override;

    std::unique_ptr<OPPrintInfo> copy() const override {
        return std::unique_ptr<StandaloneCallPrintInfo>(new StandaloneCallPrintInfo(*this));
    }

private:
    StandaloneCallPrintInfo(const StandaloneCallPrintInfo& other)
        : OPPrintInfo(other), functionName(other.functionName) {}
};

struct StandaloneCallInfo {
    const main::Option* option;
    common::Value optionValue;
    // TODO: we should remove this.
    bool hasExecuted = false;

    StandaloneCallInfo(const main::Option* option, common::Value optionValue)
        : option{option}, optionValue{std::move(optionValue)} {}
    EXPLICIT_COPY_DEFAULT_MOVE(StandaloneCallInfo);

private:
    StandaloneCallInfo(const StandaloneCallInfo& other)
        : option{other.option}, optionValue{other.optionValue} {}
};

class StandaloneCall final : public PhysicalOperator {
    static constexpr PhysicalOperatorType type_ = PhysicalOperatorType::STANDALONE_CALL;

public:
    StandaloneCall(StandaloneCallInfo info, uint32_t id, std::unique_ptr<OPPrintInfo> printInfo)
        : PhysicalOperator{type_, id, std::move(printInfo)}, standaloneCallInfo{std::move(info)} {}

    bool isSource() const override { return true; }
    bool isParallel() const override { return false; }

    bool getNextTuplesInternal(ExecutionContext* context) override;

    std::unique_ptr<PhysicalOperator> copy() override {
        return std::make_unique<StandaloneCall>(standaloneCallInfo.copy(), id, printInfo->copy());
    }

private:
    StandaloneCallInfo standaloneCallInfo;
};

} // namespace processor
} // namespace lbug