#pragma once #include #include namespace DB { class StorageMergeTree; struct StorageInMemoryMetadata; using StorageMetadataPtr = std::shared_ptr; struct FutureMergedMutatedPart; using FutureMergedMutatedPartPtr = std::shared_ptr; struct CurrentlyMergingPartsTagger { FutureMergedMutatedPartPtr future_part; ReservationSharedPtr reserved_space; StorageMergeTree & storage; // Optional tagger to maintain volatile parts for the JBOD balancer std::optional tagger; CurrentlyMergingPartsTagger( FutureMergedMutatedPartPtr future_part_, size_t total_size, StorageMergeTree & storage_, const StorageMetadataPtr & metadata_snapshot, bool is_mutation); ~CurrentlyMergingPartsTagger(); }; using CurrentlyMergingPartsTaggerPtr = std::unique_ptr; struct MergeMutateSelectedEntry { FutureMergedMutatedPartPtr future_part; CurrentlyMergingPartsTaggerPtr tagger; MutationCommandsConstPtr commands; MergeTreeTransactionPtr txn; MergeMutateSelectedEntry(FutureMergedMutatedPartPtr future_part_, CurrentlyMergingPartsTaggerPtr tagger_, MutationCommandsConstPtr commands_, const MergeTreeTransactionPtr & txn_ = NO_TRANSACTION_PTR) : future_part(future_part_) , tagger(std::move(tagger_)) , commands(commands_) , txn(txn_) {} }; using MergeMutateSelectedEntryPtr = std::shared_ptr; }