-
Notifications
You must be signed in to change notification settings - Fork 89
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: dump_declared_classes can dump for a specific block range
- Loading branch information
1 parent
5e611ab
commit 0a67776
Showing
5 changed files
with
185 additions
and
49 deletions.
There are no files selected for viewing
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,15 +1,74 @@ | ||
use papyrus_storage::utils::dump_declared_classes_table_to_file; | ||
use clap::{Arg, Command}; | ||
use papyrus_storage::utils::{ | ||
dump_declared_classes_table_by_block_range, | ||
get_compiled_class_marker, | ||
}; | ||
|
||
/// This executable dumps the declared_classes table from the storage to a file. | ||
/// The file path can be passed as an argument, otherwise it will be dumped to | ||
/// "dump_declared_classes.json". | ||
/// The start_block and end_block arguments are mandatory and define the block range to dump, | ||
/// start_block is inclusive and end_block is exclusive. The file_path is an optional parameter, | ||
/// otherwise the data will be dumped to "dump_declared_classes.json". | ||
fn main() { | ||
let args = std::env::args().collect::<Vec<_>>(); | ||
let default_file_path = "dump_declared_classes.json".to_string(); | ||
let file_path = args.get(1).unwrap_or(&default_file_path); | ||
|
||
match dump_declared_classes_table_to_file(file_path) { | ||
Ok(_) => println!("Dumped declared_classes table to file: {}", file_path), | ||
let cli_params = get_cli_params(); | ||
match dump_declared_classes_table_by_block_range(cli_params.start_block, cli_params.end_block, &cli_params.file_path) { | ||
Ok(_) => println!("Dumped declared_classes table to file: {}", cli_params.file_path), | ||
Err(e) => println!("Failed dumping declared_classes table with error: {}", e), | ||
} | ||
} | ||
|
||
struct CliParams { | ||
start_block: u64, | ||
end_block: u64, | ||
file_path: String, | ||
} | ||
|
||
fn get_cli_params() -> CliParams { | ||
let matches = Command::new("Dump declared classes") | ||
.arg( | ||
Arg::new("file_path") | ||
.short('f') | ||
.long("file_path") | ||
.default_value("dump_declared_classes.json") | ||
.help("The file path to dump the declared classes table to."), | ||
) | ||
.arg( | ||
Arg::new("start_block") | ||
.short('s') | ||
.long("start_block") | ||
.required(true) | ||
.help("The block number to start dumping from."), | ||
) | ||
.arg( | ||
Arg::new("end_block") | ||
.short('e') | ||
.long("end_block") | ||
.required(true) | ||
.help("The block number to end dumping at."), | ||
) | ||
.get_matches(); | ||
|
||
let file_path = matches.get_one::<String>("file_path").unwrap().as_str(); | ||
let start_block = matches | ||
.get_one::<String>("start_block") | ||
.unwrap() | ||
.parse::<u64>() | ||
.expect("Failed parsing start_block"); | ||
let end_block = matches | ||
.get_one::<String>("end_block") | ||
.unwrap() | ||
.parse::<u64>() | ||
.expect("Failed parsing end_block"); | ||
if start_block >= end_block { | ||
panic!("start_block must be smaller than end_block"); | ||
} | ||
let compile_class_marker = | ||
get_compiled_class_marker().expect("couldn't get compiled class marker"); | ||
if start_block > compile_class_marker.0 || end_block > compile_class_marker.0 { | ||
let msg = format!( | ||
"start_block: {} and end_block: {} must be smaller than compiled class marker: {}", | ||
start_block, end_block, compile_class_marker.0 | ||
); | ||
panic!("{msg}"); | ||
} | ||
CliParams { start_block, end_block, file_path: file_path.to_string() } | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters