From 4350dacd31d3fe1adf51a07cf3d59406fa2351e3 Mon Sep 17 00:00:00 2001 From: Ben Shteinfeld Date: Tue, 27 Dec 2022 18:38:00 +0000 Subject: SERVER-71943 Move ABT translation to new visitor mechanism --- .../db/pipeline/visitors/document_source_visitor.h | 140 --------------------- .../document_source_visitor_registry_mongod.h | 10 +- .../pipeline/visitors/document_source_walker.cpp | 114 ----------------- .../db/pipeline/visitors/document_source_walker.h | 22 ---- 4 files changed, 8 insertions(+), 278 deletions(-) delete mode 100644 src/mongo/db/pipeline/visitors/document_source_visitor.h (limited to 'src/mongo/db/pipeline/visitors') diff --git a/src/mongo/db/pipeline/visitors/document_source_visitor.h b/src/mongo/db/pipeline/visitors/document_source_visitor.h deleted file mode 100644 index 13180f1f42d..00000000000 --- a/src/mongo/db/pipeline/visitors/document_source_visitor.h +++ /dev/null @@ -1,140 +0,0 @@ -/** - * Copyright (C) 2022-present MongoDB, Inc. - * - * This program is free software: you can redistribute it and/or modify - * it under the terms of the Server Side Public License, version 1, - * as published by MongoDB, Inc. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * Server Side Public License for more details. - * - * You should have received a copy of the Server Side Public License - * along with this program. If not, see - * . - * - * As a special exception, the copyright holders give permission to link the - * code of portions of this program with the OpenSSL library under certain - * conditions as described in each individual source file and distribute - * linked combinations including the program with the OpenSSL library. You - * must comply with the Server Side Public License in all respects for - * all of the code used other than as permitted herein. If you modify file(s) - * with this exception, you may extend this exception to your version of the - * file(s), but you are not obligated to do so. If you do not wish to do so, - * delete this exception statement from your version. If you delete this - * exception statement from all source files in the program, then also delete - * it in the license file. - */ - -#pragma once - -#include "mongo/db/query/tree_walker.h" - -namespace mongo { - -class DocumentSourceBucketAuto; -class DocumentSourceCollStats; -class DocumentSourceCurrentOp; -class DocumentSourceCursor; -class DocumentSourceExchange; -class DocumentSourceFacet; -class DocumentSourceGeoNear; -class DocumentSourceGeoNearCursor; -class DocumentSourceGraphLookUp; -class DocumentSourceGroup; -class DocumentSourceIndexStats; -class DocumentSourceInternalInhibitOptimization; -class DocumentSourceInternalShardFilter; -class DocumentSourceInternalSplitPipeline; -class DocumentSourceInternalUnpackBucket; -class DocumentSourceLimit; -class DocumentSourceListCachedAndActiveUsers; -class DocumentSourceListLocalSessions; -class DocumentSourceListSessions; -class DocumentSourceLookUp; -class DocumentSourceMatch; -class DocumentSourceMerge; -class DocumentSourceMergeCursors; -class DocumentSourceOperationMetrics; -class DocumentSourceOut; -class DocumentSourcePlanCacheStats; -class DocumentSourceQueue; -class DocumentSourceRedact; -class DocumentSourceSample; -class DocumentSourceSampleFromRandomCursor; -class DocumentSourceSequentialDocumentCache; -class DocumentSourceSingleDocumentTransformation; -class DocumentSourceSkip; -class DocumentSourceSort; -class DocumentSourceTeeConsumer; -class DocumentSourceTelemetry; -class DocumentSourceUnionWith; -class DocumentSourceUnwind; - -/** - * Visitor pattern for pipeline document sources. - * - * This code is not responsible for traversing the tree, only for performing the double-dispatch. - * - * If the visitor doesn't intend to modify the tree, then the template argument 'IsConst' should be - * set to 'true'. In this case all 'visit()' methods will take a const pointer to a visiting node. - */ -template -class DocumentSourceVisitor { -public: - virtual void visit(tree_walker::MaybeConstPtr source) = 0; - virtual void visit(tree_walker::MaybeConstPtr source) = 0; - virtual void visit(tree_walker::MaybeConstPtr source) = 0; - virtual void visit(tree_walker::MaybeConstPtr source) = 0; - virtual void visit(tree_walker::MaybeConstPtr source) = 0; - virtual void visit(tree_walker::MaybeConstPtr source) = 0; - virtual void visit(tree_walker::MaybeConstPtr source) = 0; - virtual void visit(tree_walker::MaybeConstPtr source) = 0; - virtual void visit(tree_walker::MaybeConstPtr source) = 0; - virtual void visit(tree_walker::MaybeConstPtr source) = 0; - virtual void visit(tree_walker::MaybeConstPtr source) = 0; - virtual void visit( - tree_walker::MaybeConstPtr source) = 0; - virtual void visit( - tree_walker::MaybeConstPtr source) = 0; - virtual void visit( - tree_walker::MaybeConstPtr source) = 0; - virtual void visit( - tree_walker::MaybeConstPtr source) = 0; - virtual void visit(tree_walker::MaybeConstPtr source) = 0; - virtual void visit( - tree_walker::MaybeConstPtr source) = 0; - virtual void visit( - tree_walker::MaybeConstPtr source) = 0; - virtual void visit(tree_walker::MaybeConstPtr source) = 0; - virtual void visit(tree_walker::MaybeConstPtr source) = 0; - virtual void visit(tree_walker::MaybeConstPtr source) = 0; - virtual void visit(tree_walker::MaybeConstPtr source) = 0; - virtual void visit(tree_walker::MaybeConstPtr source) = 0; - virtual void visit( - tree_walker::MaybeConstPtr source) = 0; - virtual void visit(tree_walker::MaybeConstPtr source) = 0; - virtual void visit( - tree_walker::MaybeConstPtr source) = 0; - virtual void visit(tree_walker::MaybeConstPtr source) = 0; - virtual void visit(tree_walker::MaybeConstPtr source) = 0; - virtual void visit(tree_walker::MaybeConstPtr source) = 0; - virtual void visit( - tree_walker::MaybeConstPtr source) = 0; - virtual void visit( - tree_walker::MaybeConstPtr source) = 0; - virtual void visit( - tree_walker::MaybeConstPtr source) = 0; - virtual void visit(tree_walker::MaybeConstPtr source) = 0; - virtual void visit(tree_walker::MaybeConstPtr source) = 0; - virtual void visit(tree_walker::MaybeConstPtr source) = 0; - virtual void visit(tree_walker::MaybeConstPtr source) = 0; - virtual void visit(tree_walker::MaybeConstPtr source) = 0; - virtual void visit(tree_walker::MaybeConstPtr source) = 0; -}; - -using DocumentSourceMutableVisitor = DocumentSourceVisitor; -using DocumentSourceConstVisitor = DocumentSourceVisitor; - -} // namespace mongo diff --git a/src/mongo/db/pipeline/visitors/document_source_visitor_registry_mongod.h b/src/mongo/db/pipeline/visitors/document_source_visitor_registry_mongod.h index b586feffa5f..3056584979e 100644 --- a/src/mongo/db/pipeline/visitors/document_source_visitor_registry_mongod.h +++ b/src/mongo/db/pipeline/visitors/document_source_visitor_registry_mongod.h @@ -109,6 +109,14 @@ template void registerMongodVisitor(ServiceContext* service) { auto& registry = getDocumentSourceVisitorRegistry(service); registerVisitFuncs -bool DocumentSourceWalkerLegacy::visitHelper(const DocumentSource* source) { - const T* concrete = dynamic_cast(source); - if (concrete == nullptr) { - return false; - } - - _postVisitor->visit(concrete); - return true; -} - -void DocumentSourceWalkerLegacy::walk(const Pipeline& pipeline) { - const Pipeline::SourceContainer& sources = pipeline.getSources(); - - if (_postVisitor != nullptr) { - for (auto it = sources.begin(); it != sources.end(); it++) { - // TODO: use acceptVisitor method when DocumentSources get ability to visit. - // source->acceptVisitor(*_preVisitor); - // - // For now, however, we use a crutch walker which performs a series of dynamic casts. - // Some types are commented out because of dependency issues (e.g. not in pipeline - // target but in query_exec target) - const DocumentSource* ds = it->get(); - const bool visited = visitHelper(ds) || - visitHelper(ds) || - visitHelper(ds) || - visitHelper(ds) || - // TODO: uncomment after fixing dependency - // visitHelper(ds) || - visitHelper(ds) || visitHelper(ds) || - visitHelper(ds) || - - // TODO: uncomment after fixing dependency - //! visitHelper(ds) || - visitHelper(ds) || - visitHelper(ds) || visitHelper(ds) || - visitHelper(ds) || - visitHelper(ds) || - visitHelper(ds) || - visitHelper(ds) || - visitHelper(ds) || - visitHelper(ds) || - visitHelper(ds) || - visitHelper(ds) || - visitHelper(ds) || visitHelper(ds) || - visitHelper(ds) || - // TODO: uncomment after fixing dependency - // visitHelper(ds) || - visitHelper(ds) || - visitHelper(ds) || - visitHelper(ds) || - visitHelper(ds) || visitHelper(ds) || - visitHelper(ds) || - visitHelper(ds) || - visitHelper(ds) || - visitHelper(ds) || - visitHelper(ds) || visitHelper(ds) || - visitHelper(ds) || - visitHelper(ds) || - visitHelper(ds) || visitHelper(ds) - // TODO: uncomment after fixing dependency - //&& visitHelper(ds) - ; - - if (!visited) { - uasserted(ErrorCodes::InternalErrorNotSupported, - str::stream() << "Stage is not supported: " << ds->getSourceName()); - } - } - } - - // TODO: reverse for pre-visitor -} - void DocumentSourceWalker::walk(const Pipeline& pipeline) { for (auto&& ds : pipeline.getSources()) { // Perform double-dispatch based on the visitor context and document source types by diff --git a/src/mongo/db/pipeline/visitors/document_source_walker.h b/src/mongo/db/pipeline/visitors/document_source_walker.h index 0c8702ce9ad..e13f1e38d30 100644 --- a/src/mongo/db/pipeline/visitors/document_source_walker.h +++ b/src/mongo/db/pipeline/visitors/document_source_walker.h @@ -31,32 +31,10 @@ #include "mongo/db/pipeline/document_source.h" #include "mongo/db/pipeline/pipeline.h" -#include "mongo/db/pipeline/visitors/document_source_visitor.h" #include "mongo/db/pipeline/visitors/document_source_visitor_registry.h" namespace mongo { -/** - * DEPRECATED: Use 'DocumentSourceWalker' instead. - * A document source walker. - * TODO SERVER-71943: Delete this class. - */ -class DocumentSourceWalkerLegacy final { -public: - DocumentSourceWalkerLegacy(DocumentSourceConstVisitor* preVisitor, - DocumentSourceConstVisitor* postVisitor) - : _preVisitor{preVisitor}, _postVisitor{postVisitor} {} - - void walk(const Pipeline& pipeline); - -private: - template - bool visitHelper(const DocumentSource* source); - - DocumentSourceConstVisitor* _preVisitor; - DocumentSourceConstVisitor* _postVisitor; -}; - /** * A walker over a DocumentSource pipeline. See the DocumentSourceVisitorRegistry header for details * about why this walker does not use the typical "visitor" interface. -- cgit v1.2.1