summaryrefslogtreecommitdiff
path: root/src/mongo/db/catalog/collection_info_cache.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/mongo/db/catalog/collection_info_cache.h')
-rw-r--r--src/mongo/db/catalog/collection_info_cache.h118
1 files changed, 0 insertions, 118 deletions
diff --git a/src/mongo/db/catalog/collection_info_cache.h b/src/mongo/db/catalog/collection_info_cache.h
deleted file mode 100644
index 8ae84fb3eec..00000000000
--- a/src/mongo/db/catalog/collection_info_cache.h
+++ /dev/null
@@ -1,118 +0,0 @@
-/**
- * Copyright (C) 2018-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
- * <http://www.mongodb.com/licensing/server-side-public-license>.
- *
- * 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/collection_index_usage_tracker.h"
-#include "mongo/db/query/plan_cache.h"
-#include "mongo/db/query/plan_summary_stats.h"
-#include "mongo/db/query/query_settings.h"
-#include "mongo/db/update_index_data.h"
-
-namespace mongo {
-class Collection;
-class IndexDescriptor;
-class OperationContext;
-
-/**
- * this is for storing things that you want to cache about a single collection
- * life cycle is managed for you from inside Collection.
- */
-class CollectionInfoCache {
-public:
- virtual ~CollectionInfoCache() = default;
-
- /**
- * Builds internal cache state based on the current state of the Collection's IndexCatalog.
- */
- virtual void init(OperationContext* const opCtx) = 0;
-
- /**
- * Get the PlanCache for this collection.
- */
- virtual PlanCache* getPlanCache() const = 0;
-
- /**
- * Get the QuerySettings for this collection.
- */
- virtual QuerySettings* getQuerySettings() const = 0;
-
- /* get set of index keys for this namespace. handy to quickly check if a given
- field is indexed (Note it might be a secondary component of a compound index.)
- */
- virtual const UpdateIndexData& getIndexKeys(OperationContext* const opCtx) const = 0;
-
- /**
- * Returns cached index usage statistics for this collection. The map returned will contain
- * entry for each index in the collection along with both a usage counter and a timestamp
- * representing the date/time the counter is valid from.
- *
- * Note for performance that this method returns a copy of a StringMap.
- */
- virtual CollectionIndexUsageMap getIndexUsageStats() const = 0;
-
- /**
- * Returns a struct containing information on the number of collection scans that have been
- * performed.
- */
- virtual CollectionIndexUsageTracker::CollectionScanStats getCollectionScanStats() const = 0;
-
- /**
- * Register a newly-created index with the cache. Must be called whenever an index is
- * built on the associated collection.
- *
- * Must be called under exclusive collection lock.
- */
- virtual void addedIndex(OperationContext* const opCtx, const IndexDescriptor* const desc) = 0;
-
- /**
- * Deregister a newly-dropped index with the cache. Must be called whenever an index is
- * dropped on the associated collection.
- *
- * Must be called under exclusive collection lock.
- */
- virtual void droppedIndex(OperationContext* const opCtx, const StringData indexName) = 0;
-
- /**
- * Removes all cached query plans.
- */
- virtual void clearQueryCache() = 0;
-
- /**
- * Signal to the cache that a query operation has completed. 'indexesUsed' should list the
- * set of indexes used by the winning plan, if any. 'summaryStats.collectionScans' and
- * 'summaryStats.collectionScansNonTailable' should be the number of collections scans and
- * non-tailable collection scans that occured while executing the winning plan.
- */
- virtual void notifyOfQuery(OperationContext* const opCtx,
- const PlanSummaryStats& summaryStats) = 0;
-
- virtual void setNs(NamespaceString ns) = 0;
-};
-} // namespace mongo