Skip to content

Commit

Permalink
Merge branch 'master' of github.com:noir-lang/noir into kh-compile-de…
Browse files Browse the repository at this point in the history
…p-wasm
  • Loading branch information
Koby committed Mar 9, 2023
2 parents 63f596e + 870ea46 commit 7ddae4c
Show file tree
Hide file tree
Showing 9 changed files with 25 additions and 25 deletions.
4 changes: 0 additions & 4 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 0 additions & 1 deletion Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,6 @@ codespan = "0.9.5"
codespan-reporting = "0.9.5"
chumsky = { git = "https://github.com/jfecher/chumsky", rev = "ad9d312" }
dirs = "4"
hex = { version = "0.4.2", features = ["serde"] }
serde = { version = "1.0.136", features = ["derive"] }
smol_str = "0.1.17"
thiserror = "1.0.21"
Expand Down
2 changes: 1 addition & 1 deletion crates/nargo/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -23,11 +23,11 @@ noirc_abi.workspace = true
fm.workspace = true
acvm.workspace = true
cfg-if.workspace = true
hex.workspace = true
toml.workspace = true
serde.workspace = true
thiserror.workspace = true
const_format = "0.2.30"
hex = "0.4.2"
serde_json = "1.0"
termcolor = "1.1.2"
tempdir = "0.3.7"
Expand Down
4 changes: 1 addition & 3 deletions crates/nargo/src/cli/check_cmd.rs
Original file line number Diff line number Diff line change
Expand Up @@ -32,9 +32,7 @@ fn check_from_path<P: AsRef<Path>>(p: P, compile_options: &CompileOptions) -> Re
let mut driver = Resolver::resolve_root_config(p.as_ref(), backend.np_language())?;
add_std_lib(&mut driver);

if driver.check_crate(compile_options).is_err() {
std::process::exit(1);
}
driver.check_crate(compile_options).map_err(|_| CliError::CompilationError)?;

// XXX: We can have a --overwrite flag to determine if you want to overwrite the Prover/Verifier.toml files
if let Some((parameters, return_type)) = driver.compute_function_signature() {
Expand Down
2 changes: 1 addition & 1 deletion crates/nargo/src/cli/compile_cmd.rs
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ pub(crate) fn run(mut args: CompileCommand, config: NargoConfig) -> Result<(), C
}
Ok(())
} else {
let main = driver.main_function();
let main = driver.main_function().map_err(|_| CliError::CompilationError)?;
compile_and_save_program(&driver, main, &args, &circuit_dir)
}
}
Expand Down
8 changes: 2 additions & 6 deletions crates/nargo/src/cli/test_cmd.rs
Original file line number Diff line number Diff line change
Expand Up @@ -36,9 +36,7 @@ fn run_tests(
let mut driver = Resolver::resolve_root_config(program_dir, backend.np_language())?;
add_std_lib(&mut driver);

if driver.check_crate(compile_options).is_err() {
std::process::exit(1);
}
driver.check_crate(compile_options).map_err(|_| CliError::CompilationError)?;

let test_functions = driver.get_all_test_functions_in_crate_matching(test_name);
println!("Running {} test functions...", test_functions.len());
Expand Down Expand Up @@ -68,9 +66,7 @@ fn run_tests(
writeln!(writer, "All tests passed").ok();
} else {
let plural = if failing == 1 { "" } else { "s" };
writer.set_color(ColorSpec::new().set_fg(Some(Color::Red))).unwrap();
writeln!(writer, "{failing} test{plural} failed").ok();
std::process::exit(1);
return Err(CliError::Generic(format!("{failing} test{plural} failed")));
}

writer.reset().ok();
Expand Down
1 change: 0 additions & 1 deletion crates/noirc_driver/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -15,4 +15,3 @@ noirc_abi.workspace = true
acvm.workspace = true
fm.workspace = true
serde.workspace = true
hex.workspace = true
24 changes: 18 additions & 6 deletions crates/noirc_driver/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -54,10 +54,13 @@ impl Driver {

// This is here for backwards compatibility
// with the restricted version which only uses one file
pub fn compile_file(root_file: PathBuf, np_language: acvm::Language) -> CompiledProgram {
pub fn compile_file(
root_file: PathBuf,
np_language: acvm::Language,
) -> Result<CompiledProgram, ReportedError> {
let mut driver = Driver::new(&np_language);
driver.create_local_crate(root_file, CrateType::Binary);
driver.compile_main(&CompileOptions::default()).unwrap_or_else(|_| std::process::exit(1))
driver.compile_main(&CompileOptions::default())
}

/// Compiles a file and returns true if compilation was successful
Expand Down Expand Up @@ -168,26 +171,35 @@ impl Driver {
options: &CompileOptions,
) -> Result<CompiledProgram, ReportedError> {
self.check_crate(options)?;
let main = self.main_function();
let main = match self.main_function() {
Ok(m) => m,
Err(e) => {
println!("cannot compile a program with no main function");
return Err(e);
}
};
self.compile_no_check(options, main)
}

/// Returns the FuncId of the 'main' funciton.
/// - Expects check_crate to be called beforehand
/// - Panics if no main function is found
pub fn main_function(&self) -> FuncId {
pub fn main_function(&self) -> Result<FuncId, ReportedError> {
// Find the local crate, one should always be present
let local_crate = self.context.def_map(LOCAL_CRATE).unwrap();

// Check the crate type
// We don't panic here to allow users to `evaluate` libraries which will do nothing
if self.context.crate_graph[LOCAL_CRATE].crate_type != CrateType::Binary {
println!("cannot compile crate into a program as the local crate is not a binary. For libraries, please use the check command");
std::process::exit(1);
return Err(ReportedError);
};

// All Binaries should have a main function
local_crate.main_function().expect("cannot compile a program with no main function")
match local_crate.main_function() {
Some(func_id) => Ok(func_id),
None => Err(ReportedError),
}
}

/// Compile the current crate. Assumes self.check_crate is called beforehand!
Expand Down
4 changes: 2 additions & 2 deletions crates/noirc_driver/src/program.rs
Original file line number Diff line number Diff line change
Expand Up @@ -16,14 +16,14 @@ where
let mut circuit_bytes: Vec<u8> = Vec::new();
circuit.write(&mut circuit_bytes).unwrap();

hex::serialize(circuit_bytes, s)
circuit_bytes.serialize(s)
}

fn deserialize_circuit<'de, D>(deserializer: D) -> Result<Circuit, D::Error>
where
D: Deserializer<'de>,
{
let circuit_bytes: Vec<u8> = hex::deserialize(deserializer)?;
let circuit_bytes = Vec::<u8>::deserialize(deserializer)?;
let circuit = Circuit::read(&*circuit_bytes).unwrap();
Ok(circuit)
}

0 comments on commit 7ddae4c

Please sign in to comment.