Skip to content

Commit

Permalink
ledger-tool: Deprecate bank-hash command (solana-labs#1710)
Browse files Browse the repository at this point in the history
ledger-tool has a somewhat cluttered interface. The bank-hash command
offers little extra functionality compared to what the verify command
does, and could instead be an optional flag for the verify command.

This change leaves the bank-hash command present, but prints an error
message and tells the user to instead use verify --print-bank-hash. The
command will be removed altogether in the future.
  • Loading branch information
steviez authored and gregcusack committed Jun 14, 2024
1 parent 1b70fe4 commit 864e468
Showing 1 changed file with 21 additions and 19 deletions.
40 changes: 21 additions & 19 deletions ledger-tool/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1047,6 +1047,14 @@ fn main() {
stores",
),
)
.arg(
Arg::with_name("print_bank_hash")
.long("print-bank-hash")
.takes_value(false)
.help(
"After verifying the ledger, print the working bank's hash"
),
)
.arg(
Arg::with_name("write_bank_file")
.long("write-bank-file")
Expand Down Expand Up @@ -1620,24 +1628,11 @@ fn main() {
)
);
}
("bank-hash", Some(arg_matches)) => {
let process_options = parse_process_options(&ledger_path, arg_matches);
let genesis_config = open_genesis_config_by(&ledger_path, arg_matches);
let blockstore = open_blockstore(
&ledger_path,
arg_matches,
get_access_type(&process_options),
("bank-hash", Some(_)) => {
eprintln!(
"The bank-hash command has been deprecated, use \
agave-ledger-tool verify --print-bank-hash ... instead"
);
let (bank_forks, _) = load_and_process_ledger_or_exit(
arg_matches,
&genesis_config,
Arc::new(blockstore),
process_options,
snapshot_archive_path,
incremental_snapshot_archive_path,
None,
);
println!("{}", &bank_forks.read().unwrap().working_bank().hash());
}
("verify", Some(arg_matches)) => {
let exit_signal = Arc::new(AtomicBool::new(false));
Expand Down Expand Up @@ -1797,6 +1792,7 @@ fn main() {
process_options.slot_callback = slot_callback;

let print_accounts_stats = arg_matches.is_present("print_accounts_stats");
let print_bank_hash = arg_matches.is_present("print_bank_hash");
let write_bank_file = arg_matches.is_present("write_bank_file");
let genesis_config = open_genesis_config_by(&ledger_path, arg_matches);
info!("genesis hash: {}", genesis_config.hash());
Expand All @@ -1816,12 +1812,18 @@ fn main() {
transaction_status_sender,
);

let working_bank = bank_forks.read().unwrap().working_bank();
if print_accounts_stats {
let working_bank = bank_forks.read().unwrap().working_bank();
working_bank.print_accounts_stats();
}
if print_bank_hash {
println!(
"Bank hash for slot {}: {}",
working_bank.slot(),
working_bank.hash()
);
}
if write_bank_file {
let working_bank = bank_forks.read().unwrap().working_bank();
bank_hash_details::write_bank_hash_details_file(&working_bank)
.map_err(|err| {
warn!("Unable to write bank hash_details file: {err}");
Expand Down

0 comments on commit 864e468

Please sign in to comment.