Skip to content

Commit

Permalink
refactor deduceProps
Browse files Browse the repository at this point in the history
  • Loading branch information
nevermore3 committed Dec 9, 2021
1 parent 19417bd commit fa0180a
Show file tree
Hide file tree
Showing 14 changed files with 81 additions and 86 deletions.
22 changes: 2 additions & 20 deletions src/graph/validator/FetchEdgesValidator.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -136,18 +136,6 @@ Status FetchEdgesValidator::validateEdgeKey() {
return Status::OK();
}

void FetchEdgesValidator::extractEdgeProp(ExpressionProps &exprProps) {
exprProps.insertEdgeProp(edgeType_, kSrc);
exprProps.insertEdgeProp(edgeType_, kDst);
exprProps.insertEdgeProp(edgeType_, kRank);
exprProps.insertEdgeProp(edgeType_, kType);

for (std::size_t i = 0; i < edgeSchema_->getNumFields(); ++i) {
const auto propName = edgeSchema_->getFieldName(i);
exprProps.insertEdgeProp(edgeType_, propName);
}
}

Status FetchEdgesValidator::validateYield(const YieldClause *yield) {
if (yield == nullptr) {
return Status::SemanticError("Missing yield clause.");
Expand All @@ -158,12 +146,6 @@ Status FetchEdgesValidator::validateYield(const YieldClause *yield) {
exprProps.insertEdgeProp(edgeType_, nebula::kDst);
exprProps.insertEdgeProp(edgeType_, nebula::kRank);

for (const auto &col : yield->columns()) {
if (ExpressionUtils::hasAny(col->expr(), {Expression::Kind::kEdge})) {
extractEdgeProp(exprProps);
break;
}
}
auto size = yield->columns().size();
outputs_.reserve(size);

Expand All @@ -182,8 +164,8 @@ Status FetchEdgesValidator::validateYield(const YieldClause *yield) {
NG_RETURN_IF_ERROR(typeStatus);
outputs_.emplace_back(col->name(), typeStatus.value());
newCols->addColumn(col->clone().release());

NG_RETURN_IF_ERROR(deduceProps(colExpr, exprProps));
std::vector<EdgeType> edgeTypes{edgeType_};
NG_RETURN_IF_ERROR(deduceProps(colExpr, exprProps, nullptr, &edgeTypes));
}

if (exprProps.hasInputVarProperty()) {
Expand Down
2 changes: 0 additions & 2 deletions src/graph/validator/FetchEdgesValidator.h
Original file line number Diff line number Diff line change
Expand Up @@ -26,8 +26,6 @@ class FetchEdgesValidator final : public Validator {

Status validateEdgeKey();

void extractEdgeProp(ExpressionProps& exprProps);

Status validateYield(const YieldClause* yieldClause);

AstContext* getAstContext() override { return fetchCtx_.get(); }
Expand Down
19 changes: 3 additions & 16 deletions src/graph/validator/FetchVerticesValidator.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ Status FetchVerticesValidator::validateTag(const NameLabelList *nameLabels) {
NG_RETURN_IF_ERROR(tagStatus);
for (const auto &tag : tagStatus.value()) {
tagsSchema_.emplace(tag.first, tag.second);
tagIds_.emplace_back(tag.first);
}
} else {
auto labels = nameLabels->labels();
Expand All @@ -43,6 +44,7 @@ Status FetchVerticesValidator::validateTag(const NameLabelList *nameLabels) {
return Status::SemanticError("no schema found for `%s'", label->c_str());
}
tagsSchema_.emplace(tagID, tagSchema);
tagIds_.emplace_back(tagID);
}
}
return Status::OK();
Expand Down Expand Up @@ -76,12 +78,8 @@ Status FetchVerticesValidator::validateYield(YieldClause *yield) {
col->setAlias(col->name());
col->setExpr(InputPropertyExpression::make(pool, nebula::kVid));
}
if (ExpressionUtils::hasAny(colExpr, {Expression::Kind::kVertex})) {
extractVertexProp(exprProps);
}
newCols->addColumn(col->clone().release());

NG_RETURN_IF_ERROR(deduceProps(colExpr, exprProps));
NG_RETURN_IF_ERROR(deduceProps(colExpr, exprProps, &tagIds_));
}
if (exprProps.tagProps().empty()) {
for (const auto &tagSchema : tagsSchema_) {
Expand All @@ -105,16 +103,5 @@ Status FetchVerticesValidator::validateYield(YieldClause *yield) {
return Status::OK();
}

void FetchVerticesValidator::extractVertexProp(ExpressionProps &exprProps) {
for (const auto &tagSchema : tagsSchema_) {
auto tagID = tagSchema.first;
exprProps.insertTagProp(tagID, nebula::kTag);
for (std::size_t i = 0; i < tagSchema.second->getNumFields(); ++i) {
const auto propName = tagSchema.second->getFieldName(i);
exprProps.insertTagProp(tagID, propName);
}
}
}

} // namespace graph
} // namespace nebula
3 changes: 1 addition & 2 deletions src/graph/validator/FetchVerticesValidator.h
Original file line number Diff line number Diff line change
Expand Up @@ -27,10 +27,9 @@ class FetchVerticesValidator final : public Validator {

AstContext* getAstContext() override { return fetchCtx_.get(); }

void extractVertexProp(ExpressionProps& exprProps);

private:
std::map<TagID, std::shared_ptr<const meta::SchemaProviderIf>> tagsSchema_;
std::vector<TagID> tagIds_;

std::unique_ptr<FetchVerticesContext> fetchCtx_;
};
Expand Down
2 changes: 1 addition & 1 deletion src/graph/validator/FindPathValidator.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@ Status FindPathValidator::validateWhere(WhereClause* where) {
return Status::SemanticError(ss.str());
}

NG_RETURN_IF_ERROR(deduceProps(filter, pathCtx_->exprProps));
NG_RETURN_IF_ERROR(deduceProps(filter, pathCtx_->exprProps, {}, {}));
pathCtx_->filter = filter;
return Status::OK();
}
Expand Down
26 changes: 4 additions & 22 deletions src/graph/validator/GoValidator.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -89,7 +89,7 @@ Status GoValidator::validateWhere(WhereClause* where) {
return Status::SemanticError(ss.str());
}

NG_RETURN_IF_ERROR(deduceProps(filter, goCtx_->exprProps));
NG_RETURN_IF_ERROR(deduceProps(filter, goCtx_->exprProps, nullptr, &goCtx_->over.edgeTypes));
goCtx_->filter = filter;
return Status::OK();
}
Expand Down Expand Up @@ -140,23 +140,20 @@ Status GoValidator::validateYield(YieldClause* yield) {
}

auto vertexExpr = ExpressionUtils::findAny(col->expr(), {Expression::Kind::kVertex});
if (static_cast<const VertexExpression*>(vertexExpr)->name() == "VERTEX") {
if (vertexExpr != nullptr &&
static_cast<const VertexExpression*>(vertexExpr)->name() == "VERTEX") {
return Status::SemanticError("`%s' is not support in go sentence.", col->toString().c_str());
}

col->setExpr(ExpressionUtils::rewriteLabelAttr2EdgeProp(col->expr()));
NG_RETURN_IF_ERROR(ValidateUtil::invalidLabelIdentifiers(col->expr()));

auto* colExpr = col->expr();
if (ExpressionUtils::hasAny(colExpr, {Expression::Kind::kEdge})) {
extractEdgeProp(exprProps);
}

auto typeStatus = deduceExprType(colExpr);
NG_RETURN_IF_ERROR(typeStatus);
auto type = typeStatus.value();
outputs_.emplace_back(col->name(), type);
NG_RETURN_IF_ERROR(deduceProps(colExpr, exprProps));
NG_RETURN_IF_ERROR(deduceProps(colExpr, exprProps, nullptr, &goCtx_->over.edgeTypes));
}

const auto& over = goCtx_->over;
Expand All @@ -171,21 +168,6 @@ Status GoValidator::validateYield(YieldClause* yield) {
return Status::OK();
}

Status GoValidator::extractEdgeProp(ExpressionProps& exprProps) {
const auto& edgeTypes = goCtx_->over.edgeTypes;
for (const auto& edgeType : edgeTypes) {
const auto& edgeSchema = qctx_->schemaMng()->getEdgeSchema(space_.id, std::abs(edgeType));
exprProps.insertEdgeProp(edgeType, kType);
exprProps.insertEdgeProp(edgeType, kSrc);
exprProps.insertEdgeProp(edgeType, kDst);
exprProps.insertEdgeProp(edgeType, kRank);
for (size_t i = 0; i < edgeSchema->getNumFields(); ++i) {
exprProps.insertEdgeProp(edgeType, edgeSchema->getFieldName(i));
}
}
return Status::OK();
}

void GoValidator::extractPropExprs(const Expression* expr,
std::unordered_set<std::string>& uniqueExpr) {
ExtractPropExprVisitor visitor(vctx_,
Expand Down
2 changes: 0 additions & 2 deletions src/graph/validator/GoValidator.h
Original file line number Diff line number Diff line change
Expand Up @@ -36,8 +36,6 @@ class GoValidator final : public Validator {

Expression* rewrite2VarProp(const Expression* expr);

Status extractEdgeProp(ExpressionProps& exprProps);

private:
std::unique_ptr<GoContext> goCtx_;

Expand Down
11 changes: 8 additions & 3 deletions src/graph/validator/LookupValidator.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,7 @@ Status LookupValidator::validateFrom() {
NG_RETURN_IF_ERROR(ret);
lookupCtx_->isEdge = ret.value().first;
lookupCtx_->schemaId = ret.value().second;
schemaIds_.emplace_back(ret.value().second);
return Status::OK();
}

Expand Down Expand Up @@ -124,7 +125,7 @@ Status LookupValidator::validateYieldEdge() {
NG_RETURN_IF_ERROR(typeStatus);
outputs_.emplace_back(col->name(), typeStatus.value());
yieldExpr->addColumn(col->clone().release());
NG_RETURN_IF_ERROR(deduceProps(colExpr, exprProps_));
NG_RETURN_IF_ERROR(deduceProps(colExpr, exprProps_, nullptr, &schemaIds_));
}
return Status::OK();
}
Expand Down Expand Up @@ -154,7 +155,7 @@ Status LookupValidator::validateYieldTag() {
NG_RETURN_IF_ERROR(typeStatus);
outputs_.emplace_back(col->name(), typeStatus.value());
yieldExpr->addColumn(col->clone().release());
NG_RETURN_IF_ERROR(deduceProps(colExpr, exprProps_));
NG_RETURN_IF_ERROR(deduceProps(colExpr, exprProps_, &schemaIds_));
}
return Status::OK();
}
Expand Down Expand Up @@ -211,7 +212,11 @@ Status LookupValidator::validateFilter() {
// Make sure the type of the rewritted filter expr is right
NG_RETURN_IF_ERROR(deduceExprType(lookupCtx_->filter));
}
NG_RETURN_IF_ERROR(deduceProps(lookupCtx_->filter, exprProps_));
if (lookupCtx_->isEdge) {
NG_RETURN_IF_ERROR(deduceProps(lookupCtx_->filter, exprProps_, nullptr, &schemaIds_));
} else {
NG_RETURN_IF_ERROR(deduceProps(lookupCtx_->filter, exprProps_, &schemaIds_));
}
return Status::OK();
}

Expand Down
1 change: 1 addition & 0 deletions src/graph/validator/LookupValidator.h
Original file line number Diff line number Diff line change
Expand Up @@ -60,6 +60,7 @@ class LookupValidator final : public Validator {
std::vector<nebula::plugin::HttpClient> tsClients_;
ExpressionProps exprProps_;
std::vector<std::string> idxReturnCols_;
std::vector<int32_t> schemaIds_;
};

} // namespace graph
Expand Down
8 changes: 6 additions & 2 deletions src/graph/validator/Validator.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -352,8 +352,12 @@ StatusOr<Value::Type> Validator::deduceExprType(const Expression* expr) const {
return visitor.type();
}

Status Validator::deduceProps(const Expression* expr, ExpressionProps& exprProps) {
DeducePropsVisitor visitor(qctx_, space_.id, &exprProps, &userDefinedVarNameList_);
Status Validator::deduceProps(const Expression* expr,
ExpressionProps& exprProps,
std::vector<TagID>* tagIds,
std::vector<EdgeType>* edgeTypes) {
DeducePropsVisitor visitor(
qctx_, space_.id, &exprProps, &userDefinedVarNameList_, tagIds, edgeTypes);
const_cast<Expression*>(expr)->accept(&visitor);
return std::move(visitor).status();
}
Expand Down
5 changes: 4 additions & 1 deletion src/graph/validator/Validator.h
Original file line number Diff line number Diff line change
Expand Up @@ -107,7 +107,10 @@ class Validator {

StatusOr<Value::Type> deduceExprType(const Expression* expr) const;

Status deduceProps(const Expression* expr, ExpressionProps& exprProps);
Status deduceProps(const Expression* expr,
ExpressionProps& exprProps,
std::vector<TagID>* tagIds = nullptr,
std::vector<EdgeType>* edgeTypes = nullptr);

static StatusOr<size_t> checkPropNonexistOrDuplicate(const ColsDef& cols,
folly::StringPiece prop,
Expand Down
2 changes: 1 addition & 1 deletion src/graph/validator/YieldValidator.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,7 @@ Status YieldValidator::makeOutputColumn(YieldColumn *column) {
DCHECK(colExpr != nullptr);

auto expr = colExpr->clone();
NG_RETURN_IF_ERROR(deduceProps(expr, exprProps_));
NG_RETURN_IF_ERROR(deduceProps(expr, exprProps_, {}, {}));

auto status = deduceExprType(expr);
NG_RETURN_IF_ERROR(status);
Expand Down
58 changes: 45 additions & 13 deletions src/graph/visitor/DeducePropsVisitor.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -108,11 +108,15 @@ void ExpressionProps::unionProps(ExpressionProps exprProps) {
DeducePropsVisitor::DeducePropsVisitor(QueryContext *qctx,
GraphSpaceID space,
ExpressionProps *exprProps,
std::set<std::string> *userDefinedVarNameList)
std::set<std::string> *userDefinedVarNameList,
std::vector<TagID> *tagIds,
std::vector<EdgeType> *edgeTypes)
: qctx_(qctx),
space_(space),
exprProps_(exprProps),
userDefinedVarNameList_(userDefinedVarNameList) {
userDefinedVarNameList_(userDefinedVarNameList),
tagIds_(tagIds),
edgeTypes_(edgeTypes) {
DCHECK(qctx != nullptr);
DCHECK(exprProps != nullptr);
DCHECK(userDefinedVarNameList != nullptr);
Expand Down Expand Up @@ -177,31 +181,59 @@ void DeducePropsVisitor::visit(LabelAttributeExpression *expr) { reportError(exp

void DeducePropsVisitor::visit(ConstantExpression *expr) { UNUSED(expr); }

void DeducePropsVisitor::visit(ColumnExpression *expr) { UNUSED(expr); }

void DeducePropsVisitor::visit(VertexExpression *expr) {
const auto &colName = expr->name();
auto tagStatus = qctx_->schemaMng()->getAllLatestVerTagSchema(space_);
if (!tagStatus.ok()) {
status_ = std::move(tagStatus).status();
return;
std::vector<TagID> tagIds;
if (tagIds_ == nullptr) {
auto tagStatus = qctx_->schemaMng()->getAllLatestVerTagSchema(space_);
if (!tagStatus.ok()) {
status_ = std::move(tagStatus).status();
return;
}
for (const auto &tag : tagStatus.value()) {
tagIds.emplace_back(tag.first);
}
tagIds_ = &tagIds;
}
for (const auto &tag : tagStatus.value()) {
auto tagID = tag.first;
const auto &tagSchema = tag.second;
const auto &colName = expr->name();
for (const auto &tagID : *tagIds_) {
const auto &tagSchema = qctx_->schemaMng()->getTagSchema(space_, tagID);
if (colName == "$^") {
exprProps_->insertSrcTagProp(tagID, nebula::kTag);
for (size_t i = 0; i < tagSchema->getNumFields(); ++i) {
exprProps_->insertSrcTagProp(tagID, tagSchema->getFieldName(i));
}
} else if (colName == "$$") {
exprProps_->insertDstTagProp(tagID, nebula::kTag);
for (size_t i = 0; i < tagSchema->getNumFields(); ++i) {
exprProps_->insertDstTagProp(tagID, tagSchema->getFieldName(i));
}
} else {
exprProps_->insertTagProp(tagID, nebula::kTag);
for (size_t i = 0; i < tagSchema->getNumFields(); ++i) {
exprProps_->insertTagProp(tagID, tagSchema->getFieldName(i));
}
}
}
}

void DeducePropsVisitor::visit(EdgeExpression *expr) { UNUSED(expr); }

void DeducePropsVisitor::visit(ColumnExpression *expr) { UNUSED(expr); }
void DeducePropsVisitor::visit(EdgeExpression *expr) {
if (edgeTypes_ == nullptr) {
UNUSED(expr);
return;
}
for (const auto &edgeType : *edgeTypes_) {
const auto &edgeSchema = qctx_->schemaMng()->getEdgeSchema(space_, std::abs(edgeType));
exprProps_->insertEdgeProp(edgeType, kType);
exprProps_->insertEdgeProp(edgeType, kSrc);
exprProps_->insertEdgeProp(edgeType, kDst);
exprProps_->insertEdgeProp(edgeType, kRank);
for (size_t i = 0; i < edgeSchema->getNumFields(); ++i) {
exprProps_->insertEdgeProp(edgeType, edgeSchema->getFieldName(i));
}
}
}

void DeducePropsVisitor::visitEdgePropExpr(PropertyExpression *expr) {
auto status = qctx_->schemaMng()->toEdgeType(space_, expr->sym());
Expand Down
6 changes: 5 additions & 1 deletion src/graph/visitor/DeducePropsVisitor.h
Original file line number Diff line number Diff line change
Expand Up @@ -71,7 +71,9 @@ class DeducePropsVisitor : public ExprVisitorImpl {
DeducePropsVisitor(QueryContext* qctx,
GraphSpaceID space,
ExpressionProps* exprProps,
std::set<std::string>* userDefinedVarNameList);
std::set<std::string>* userDefinedVarNameList,
std::vector<TagID>* tagIds,
std::vector<EdgeType>* edgeTypes);

bool ok() const override { return status_.ok(); }

Expand Down Expand Up @@ -106,6 +108,8 @@ class DeducePropsVisitor : public ExprVisitorImpl {
GraphSpaceID space_;
ExpressionProps* exprProps_{nullptr};
std::set<std::string>* userDefinedVarNameList_{nullptr};
std::vector<TagID>* tagIds_{nullptr};
std::vector<EdgeType>* edgeTypes_{nullptr};
Status status_;
};

Expand Down

0 comments on commit fa0180a

Please sign in to comment.