lbug 0.15.4

An in-process property graph database management system built for query speed and scalability
Documentation
#include "binder/expression/rel_expression.h"
#include "common/exception/binder.h"
#include "function/rewrite_function.h"
#include "function/schema/vector_node_rel_functions.h"
#include <format>

using namespace lbug::common;
using namespace lbug::binder;

namespace lbug {
namespace function {

static std::shared_ptr<Expression> rewriteFunc(const RewriteFunctionBindInput& input) {
    DASSERT(input.arguments.size() == 1);
    auto param = input.arguments[0].get();
    DASSERT(param->getDataType().getLogicalTypeID() == LogicalTypeID::RECURSIVE_REL);
    auto recursiveInfo = param->ptrCast<RelExpression>()->getRecursiveInfo();
    if (recursiveInfo->bindData->weightOutputExpr == nullptr) {
        throw BinderException(
            std::format("Cost function is not defined for {}", param->toString()));
    }
    return recursiveInfo->bindData->weightOutputExpr;
}

function_set CostFunction::getFunctionSet() {
    function_set functionSet;
    auto function = std::make_unique<RewriteFunction>(name,
        std::vector<LogicalTypeID>{LogicalTypeID::RECURSIVE_REL}, rewriteFunc);
    functionSet.push_back(std::move(function));
    return functionSet;
}

} // namespace function
} // namespace lbug