// This file is part of Substrate. // Copyright (C) 2018-2022 Parity Technologies (UK) Ltd. // SPDX-License-Identifier: GPL-3.0-or-later WITH Classpath-exception-2.0 // This program is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // 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 // GNU General Public License for more details. // You should have received a copy of the GNU General Public License // along with this program. If not, see . use crate::arg_enums::Database; use clap::Args; use sc_service::TransactionStorageMode; /// Parameters for block import. #[derive(Debug, Clone, PartialEq, Args)] pub struct DatabaseParams { /// Select database backend to use. #[clap( long, alias = "db", value_name = "DB", ignore_case = true, possible_values = Database::variants(), )] pub database: Option, /// Limit the memory the database cache can use. #[clap(long = "db-cache", value_name = "MiB")] pub database_cache_size: Option, /// Enable storage chain mode /// /// This changes the storage format for blocks bodies. /// If this is enabled, each transaction is stored separately in the /// transaction database column and is only referenced by hash /// in the block body column. #[clap(long)] pub storage_chain: bool, } impl DatabaseParams { /// Limit the memory the database cache can use. pub fn database(&self) -> Option { self.database } /// Limit the memory the database cache can use. pub fn database_cache_size(&self) -> Option { self.database_cache_size } /// Transaction storage scheme. pub fn transaction_storage(&self) -> TransactionStorageMode { if self.storage_chain { TransactionStorageMode::StorageChain } else { TransactionStorageMode::BlockBody } } }