Skip to content

Commit

Permalink
chore: make error reporting an explicit action
Browse files Browse the repository at this point in the history
  • Loading branch information
TomAFrench committed Mar 1, 2024
1 parent 3c0e616 commit f1b3a8d
Show file tree
Hide file tree
Showing 5 changed files with 86 additions and 61 deletions.
14 changes: 12 additions & 2 deletions tooling/lsp/src/requests/profile_run.rs
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,10 @@ use std::{

use acvm::acir::circuit::ExpressionWidth;
use async_lsp::{ErrorCode, ResponseError};
use nargo::{artifacts::debug::DebugArtifact, insert_all_files_for_workspace_into_file_manager};
use nargo::{
artifacts::debug::DebugArtifact, insert_all_files_for_workspace_into_file_manager,
ops::report_errors,
};
use nargo_toml::{find_package_manifest, resolve_workspace_from_toml, PackageSelection};
use noirc_driver::{
file_manager_with_stdlib, CompileOptions, DebugFile, NOIR_ARTIFACT_VERSION_STRING,
Expand Down Expand Up @@ -60,11 +63,18 @@ fn on_profile_run_request_inner(
Some(_package) => {
let expression_width = ExpressionWidth::Bounded { width: 3 };

let (compiled_programs, compiled_contracts) = nargo::ops::compile_workspace(
let compiled_workspace = nargo::ops::compile_workspace(
&workspace_file_manager,
&parsed_files,
&workspace,
&CompileOptions::default(),
);

let (compiled_programs, compiled_contracts) = report_errors(
compiled_workspace,
&workspace_file_manager,
CompileOptions::default().deny_warnings,
CompileOptions::default().silence_warnings,
)
.map_err(|err| ResponseError::new(ErrorCode::REQUEST_FAILED, err))?;

Expand Down
64 changes: 38 additions & 26 deletions tooling/nargo/src/ops/compile.rs
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ pub fn compile_workspace(
parsed_files: &ParsedFiles,
workspace: &Workspace,
compile_options: &CompileOptions,
) -> Result<(Vec<CompiledProgram>, Vec<CompiledContract>), CompileError> {
) -> CompilationResult<(Vec<CompiledProgram>, Vec<CompiledContract>)> {
let (binary_packages, contract_packages): (Vec<_>, Vec<_>) = workspace
.into_iter()
.filter(|package| !package.is_library())
Expand All @@ -38,31 +38,20 @@ pub fn compile_workspace(
.map(|package| compile_contract(file_manager, parsed_files, package, compile_options))
.collect();

// Report any warnings/errors which were encountered during compilation.
let compiled_programs: Vec<CompiledProgram> = program_results
.into_iter()
.map(|compilation_result| {
report_errors(
compilation_result,
file_manager,
compile_options.deny_warnings,
compile_options.silence_warnings,
)
})
.collect::<Result<_, _>>()?;
let compiled_contracts: Vec<CompiledContract> = contract_results
.into_iter()
.map(|compilation_result| {
report_errors(
compilation_result,
file_manager,
compile_options.deny_warnings,
compile_options.silence_warnings,
)
})
.collect::<Result<_, _>>()?;

Ok((compiled_programs, compiled_contracts))
// Collate any warnings/errors which were encountered during compilation.
let compiled_programs = collect_errors(program_results);
let compiled_contracts = collect_errors(contract_results);

match (compiled_programs, compiled_contracts) {
(Ok((programs, program_warnings)), Ok((contracts, contract_warnings))) => {
let warnings = [program_warnings, contract_warnings].concat();
Ok(((programs, contracts), warnings))
}
(Err(program_errors), Err(contract_errors)) => {
Err([program_errors, contract_errors].concat())
}
(Err(errors), _) | (_, Err(errors)) => Err(errors),
}
}

pub fn compile_program(
Expand Down Expand Up @@ -107,6 +96,29 @@ pub fn compile_contract(
noirc_driver::compile_contract(&mut context, crate_id, compile_options)
}

/// Constructs a single `CompilationResult` for a collection of `CompilationResult`s, merging the set of warnings/errors.
pub fn collect_errors<T>(results: Vec<CompilationResult<T>>) -> CompilationResult<Vec<T>> {
let mut artifacts = Vec::new();
let mut warnings = Vec::new();
let mut errors = Vec::new();

for result in results {
match result {
Ok((new_artifact, new_warnings)) => {
artifacts.push(new_artifact);
warnings.extend(new_warnings);
}
Err(new_errors) => errors.extend(new_errors),
}
}

if errors.is_empty() {
Ok((artifacts, warnings))
} else {
Err(errors)
}
}

pub fn report_errors<T>(
result: CompilationResult<T>,
file_manager: &FileManager,
Expand Down
4 changes: 2 additions & 2 deletions tooling/nargo/src/ops/mod.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
pub use self::compile::{
compile_contract, compile_program, compile_program_with_debug_instrumenter, compile_workspace,
report_errors,
collect_errors, compile_contract, compile_program, compile_program_with_debug_instrumenter,
compile_workspace, report_errors,
};
pub use self::execute::execute_circuit;
pub use self::foreign_calls::{
Expand Down
54 changes: 25 additions & 29 deletions tooling/nargo_cli/src/cli/compile_cmd.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ use std::path::Path;

use fm::FileManager;
use nargo::artifacts::program::ProgramArtifact;
use nargo::ops::{compile_contract, compile_program, report_errors};
use nargo::ops::{collect_errors, compile_contract, compile_program, report_errors};
use nargo::package::Package;
use nargo::workspace::Workspace;
use nargo::{insert_all_files_for_workspace_into_file_manager, parse_all};
Expand Down Expand Up @@ -64,11 +64,18 @@ pub(crate) fn run(
.compile_options
.expression_width
.unwrap_or_else(|| backend.get_backend_info_or_default());
let (compiled_program, compiled_contracts) = compile_workspace(
let compiled_workspace = compile_workspace(
&workspace_file_manager,
&parsed_files,
&workspace,
&args.compile_options,
);

let (compiled_programs, compiled_contracts) = report_errors(
compiled_workspace,
&workspace_file_manager,
args.compile_options.deny_warnings,
args.compile_options.silence_warnings,
)?;

let (binary_packages, contract_packages): (Vec<_>, Vec<_>) = workspace
Expand All @@ -79,7 +86,7 @@ pub(crate) fn run(

// Save build artifacts to disk.
let only_acir = args.compile_options.only_acir;
for (package, program) in binary_packages.into_iter().zip(compiled_program) {
for (package, program) in binary_packages.into_iter().zip(compiled_programs) {
let program = nargo::ops::transform_program(program, expression_width);
save_program(program.clone(), &package, &workspace.target_directory_path(), only_acir);
}
Expand All @@ -96,7 +103,7 @@ pub(super) fn compile_workspace(
parsed_files: &ParsedFiles,
workspace: &Workspace,
compile_options: &CompileOptions,
) -> Result<(Vec<CompiledProgram>, Vec<CompiledContract>), CliError> {
) -> CompilationResult<(Vec<CompiledProgram>, Vec<CompiledContract>)> {
let (binary_packages, contract_packages): (Vec<_>, Vec<_>) = workspace
.into_iter()
.filter(|package| !package.is_library())
Expand All @@ -122,31 +129,20 @@ pub(super) fn compile_workspace(
.map(|package| compile_contract(file_manager, parsed_files, package, compile_options))
.collect();

// Report any warnings/errors which were encountered during compilation.
let compiled_programs: Vec<CompiledProgram> = program_results
.into_iter()
.map(|compilation_result| {
report_errors(
compilation_result,
file_manager,
compile_options.deny_warnings,
compile_options.silence_warnings,
)
})
.collect::<Result<_, _>>()?;
let compiled_contracts: Vec<CompiledContract> = contract_results
.into_iter()
.map(|compilation_result| {
report_errors(
compilation_result,
file_manager,
compile_options.deny_warnings,
compile_options.silence_warnings,
)
})
.collect::<Result<_, _>>()?;

Ok((compiled_programs, compiled_contracts))
// Collate any warnings/errors which were encountered during compilation.
let compiled_programs = collect_errors(program_results);
let compiled_contracts = collect_errors(contract_results);

match (compiled_programs, compiled_contracts) {
(Ok((programs, program_warnings)), Ok((contracts, contract_warnings))) => {
let warnings = [program_warnings, contract_warnings].concat();
Ok(((programs, contracts), warnings))
}
(Err(program_errors), Err(contract_errors)) => {
Err([program_errors, contract_errors].concat())
}
(Err(errors), _) | (_, Err(errors)) => Err(errors),
}
}

pub(super) fn save_program(
Expand Down
11 changes: 9 additions & 2 deletions tooling/nargo_cli/src/cli/info_cmd.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ use clap::Args;
use iter_extended::vecmap;
use nargo::{
artifacts::debug::DebugArtifact, insert_all_files_for_workspace_into_file_manager,
package::Package, parse_all,
ops::report_errors, package::Package, parse_all,
};
use nargo_toml::{get_package_manifest, resolve_workspace_from_toml, PackageSelection};
use noirc_driver::{
Expand Down Expand Up @@ -73,11 +73,18 @@ pub(crate) fn run(
.compile_options
.expression_width
.unwrap_or_else(|| backend.get_backend_info_or_default());
let (compiled_programs, compiled_contracts) = compile_workspace(
let compiled_workspace = compile_workspace(
&workspace_file_manager,
&parsed_files,
&workspace,
&args.compile_options,
);

let (compiled_programs, compiled_contracts) = report_errors(
compiled_workspace,
&workspace_file_manager,
args.compile_options.deny_warnings,
args.compile_options.silence_warnings,
)?;

let compiled_programs = vecmap(compiled_programs, |program| {
Expand Down

0 comments on commit f1b3a8d

Please sign in to comment.