-
Notifications
You must be signed in to change notification settings - Fork 10
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Feat/build all casper circuits #271
base: main
Are you sure you want to change the base?
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Add README for usage
let command_line_arguments: Vec<String> = args().skip(1).collect(); | ||
|
||
if command_line_circuit.name != Circuits::all { | ||
for (_, arg) in command_line_arguments.iter().enumerate() { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
enumerate is useless if you are not using the index
for (_, arg) in command_line_arguments.iter().enumerate() { | ||
let arg_as_circuit = Circuits::from_str(&arg); | ||
build_circuit(arg_as_circuit.unwrap()); | ||
let path = format!("build/{}", arg_as_circuit.unwrap().to_string()); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
handle the None case
let command_line_circuit: CommandLineCircuit = CommandLineCircuit::parse(); | ||
let command_line_arguments: Vec<String> = args().skip(1).collect(); | ||
|
||
if command_line_circuit.name != Circuits::all { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You are only using command_line_circuit to check if it's all and are not using it to determine which circuits you should build. You could just as well check if args()[1] is "all"
circuit.save(&path, &gate_serializer, &hint_serializer); | ||
} | ||
} else { | ||
for _circuit in Circuits::iter() { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Remove underscore
#[derive(Debug, Eq, Hash, PartialEq, Copy, Clone, EnumString, Display, EnumIter)] | ||
#[allow(non_camel_case_types)] | ||
enum Circuits { | ||
compute_shuffled_index_mainnet, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Rename these to Pascal case
} | ||
|
||
impl Circuits { | ||
fn from_str(circuit_as_str: &str) -> Option<Circuits> { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
EnumString already creates this function for you so this implementation is redundant. Moreover, you can provide casing in it to match the Pascal case of the enum corectly
let circuit = builder.build(); | ||
let hint_serializer = HintRegistry::<L, D>::new(); | ||
let gate_serializer = GateRegistry::<L, D>::new(); | ||
let command_line_circuit: CommandLineCircuit = CommandLineCircuit::parse(); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Rename CommandLineCircuit to CommandLineOptions
Lazy::force(&circuit_weigh_justification_and_finalization); | ||
})) | ||
} | ||
Circuits::all => OneOrAllCircuits::AllCircuits(vec![ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is never called
fn build_circuit(circuit: Circuits) -> OneOrAllCircuits { | ||
match circuit { | ||
Circuits::compute_shuffled_index_mainnet => OneOrAllCircuits::OneCircuit(Box::new(|| { | ||
Lazy::force(&circuit_mainnet); | ||
})), | ||
Circuits::compute_shuffled_index_minimal => OneOrAllCircuits::OneCircuit(Box::new(|| { | ||
Lazy::force(&circuit_minimal); | ||
})), | ||
Circuits::weigh_justification_and_finalization => { | ||
OneOrAllCircuits::OneCircuit(Box::new(|| { | ||
Lazy::force(&circuit_weigh_justification_and_finalization); | ||
})) | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Return type of build_circuit is never used so it can be removed. Then OneOrAllCircuits becomes obsolete and the Box::new expression can be removed. Simply match the enum value and Lazy::force in the body of the matched value
No description provided.