// Copyright (c) 2011-present, Facebook, Inc. All rights reserved. // This source code is licensed under both the GPLv2 (found in the // COPYING file in the root directory) and Apache 2.0 License // (found in the LICENSE.Apache file in the root directory). #pragma once #ifndef ROCKSDB_LITE #include "rocksdb/sst_dump_tool.h" #include #include #include "db/dbformat.h" #include "file/writable_file_writer.h" #include "options/cf_options.h" namespace ROCKSDB_NAMESPACE { class SstFileDumper { public: explicit SstFileDumper(const Options& options, const std::string& file_name, bool verify_checksum, bool output_hex, bool decode_blob_index); Status ReadSequential(bool print_kv, uint64_t read_num, bool has_from, const std::string& from_key, bool has_to, const std::string& to_key, bool use_from_as_prefix = false); Status ReadTableProperties( std::shared_ptr* table_properties); uint64_t GetReadNumber() { return read_num_; } TableProperties* GetInitTableProperties() { return table_properties_.get(); } Status VerifyChecksum(); Status DumpTable(const std::string& out_filename); Status getStatus() { return init_result_; } int ShowAllCompressionSizes( size_t block_size, const std::vector>& compression_types, int32_t compress_level_from, int32_t compress_level_to); int ShowCompressionSize( size_t block_size, CompressionType compress_type, const CompressionOptions& compress_opt); private: // Get the TableReader implementation for the sst file Status GetTableReader(const std::string& file_path); Status ReadTableProperties(uint64_t table_magic_number, RandomAccessFileReader* file, uint64_t file_size); uint64_t CalculateCompressedTableSize(const TableBuilderOptions& tb_options, size_t block_size, uint64_t* num_data_blocks); Status SetTableOptionsByMagicNumber(uint64_t table_magic_number); Status SetOldTableOptions(); // Helper function to call the factory with settings specific to the // factory implementation Status NewTableReader(const ImmutableCFOptions& ioptions, const EnvOptions& soptions, const InternalKeyComparator& internal_comparator, uint64_t file_size, std::unique_ptr* table_reader); std::string file_name_; uint64_t read_num_; bool verify_checksum_; bool output_hex_; bool decode_blob_index_; EnvOptions soptions_; // options_ and internal_comparator_ will also be used in // ReadSequential internally (specifically, seek-related operations) Options options_; Status init_result_; std::unique_ptr table_reader_; std::unique_ptr file_; const ImmutableCFOptions ioptions_; const MutableCFOptions moptions_; InternalKeyComparator internal_comparator_; std::unique_ptr table_properties_; }; } // namespace ROCKSDB_NAMESPACE #endif // ROCKSDB_LITE