Skip to content
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: don't report warnings for dependencies #6926

Open
wants to merge 8 commits into
base: master
Choose a base branch
from

Conversation

asterite
Copy link
Collaborator

@asterite asterite commented Jan 2, 2025

Description

Problem

Resolves #6909

Summary

The way this is done here is:

  1. When collecting all files to parse, we also collect which files belong to root packages
  2. When reporting errors and warnings we drop warnings from files that are not in root packages

Additional Context

The name of the branch has "2" in it because at first I tried a different approach: avoid collecting warnings as soon as we encounter them in dependencies. However, this is much more complex because we can't immediately know if an error is a warning or not (we have to turn it into a Diagnostic first, or introduce a large refactor to track this separately) and also in LSP it makes sense to track errors from dependencies if they are tracked by the editor, so it doesn't make sense to exclude them right away.

Documentation

Check one:

  • No documentation needed.
  • Documentation included in this PR.
  • [For Experimental Features] Documentation to be submitted in a separate PR.

PR Checklist

  • I have tested the changes locally.
  • I have formatted the changes with Prettier and/or cargo fmt on default settings.

Copy link
Contributor

github-actions bot commented Jan 2, 2025

Compilation Report

Program Compilation Time %
sha256_regression 1.369s -2%
regression_4709 0.807s 0%
ram_blowup_regression 15.158s -1%
rollup-root 3.783s -4%
rollup-block-merge 3.668s -15%
rollup-base-public 116.130s 2%
rollup-base-private 97.686s 1%
private-kernel-tail 1.008s -3%
private-kernel-reset 7.432s 3%
private-kernel-inner 2.144s 3%
parity-root 0.798s 10%
noir-contracts 85.720s -2%

Copy link
Contributor

github-actions bot commented Jan 2, 2025

Execution Report

Program Execution Time %
sha256_regression 0.593s 0%
regression_4709 0.407s 2%
ram_blowup_regression 3.925s 1%
rollup-root 2.178s -1%
rollup-block-merge 2.082s -5%
rollup-base-public 35.150s 1%
rollup-base-private 31.634s -1%
private-kernel-tail 0.755s 0%
private-kernel-reset 2.181s 1%
private-kernel-inner 1.232s 1%
parity-root 0.555s 6%

Copy link
Contributor

github-actions bot commented Jan 2, 2025

Peak Memory Sample

Program Peak Memory
keccak256 78.48M
workspace 123.79M
regression_4709 422.91M
ram_blowup_regression 1.58G
rollup-base-public 10.47G
rollup-base-private 6.57G
private-kernel-tail 201.81M
private-kernel-reset 717.07M
private-kernel-inner 291.88M
parity-root 172.14M

@asterite asterite requested a review from a team January 2, 2025 19:23
@TomAFrench
Copy link
Member

Hmm, forcing the user to pass around another piece of compiler state is a little sad. I'd like to avoid this if possible but would need to think more on this.

@asterite
Copy link
Collaborator Author

asterite commented Jan 2, 2025

The set of root files could be tracked by FileManager so we'd need less things to pass around... though at that point maybe FileManager would be doing more just than a single thing.

@TomAFrench
Copy link
Member

I'm thinking that there's enough information for what we want inside of the Context struct, following this down we can get the ModuleData for a particular crate.

pub def_maps: BTreeMap<CrateId, CrateDefMap>,

pub(crate) modules: Arena<ModuleData>,

pub children: HashMap<Ident, LocalModuleId>,

By reading the ModuleData for a particular crate we can get a tree of all the modules within a particular crate. Working down from the root we can then use logic similar to find_module in order to get all of the FileIds connected to this crate.

fn find_module(
file_manager: &FileManager,
anchor: FileId,
mod_name: &Ident,
) -> Result<FileId, DefCollectorErrorKind> {

We should then be able to generate this list after the fact rather than needing to pass it around externally to the compiler.

Note that this method will mean that we ignore any warnings outside of the current crate as opposed to the current workspace. This seems to be closer to what we want imo as it will avoid a workspace library from having its warnings emitted many times (this also matches up with cargo behaviour).

@TomAFrench
Copy link
Member

TomAFrench commented Jan 3, 2025

We could also track this a little more explicitly inside of the compiler state but the above is a "zero footprint" solution.

Edit: agreed that it would be best to keep FileManager "pure" and avoid it knowing about this.

@asterite
Copy link
Collaborator Author

asterite commented Jan 3, 2025

Sounds good, I'll do what you say in the first comment.

I was thinking that eventually it would be nice for the compiler to be able to compile crates modularly. It's a bit strange that we read all files of all packages and all dependencies in one go. Ideally we'd process a package by reading its files, compiling it, then moving to dependent packages, even being able to parallelize things... though I know that would be a huge refactor, but in the way we'd get "for free" errors and warnings grouped by package.

@asterite
Copy link
Collaborator Author

asterite commented Jan 3, 2025

Almost there! In compile_cmd and debug_cmd there's no Context so I don't know where to get the files from... Those files end up calling compile_program that returns CompilationResult<CompiledProgram>, maybe that type (CompiledProgram) could hold that, or maybe a tuple could be returned... but I think it would make the code messier again.

@TomAFrench
Copy link
Member

We can filter the returned warnings inside of the compiler before we pass it back up to nargo_cli though, no? Is there a reason why we need to do this externally?

@asterite
Copy link
Collaborator Author

asterite commented Jan 3, 2025

Is there a reason why we need to do this externally?

The main reason is that for LSP we'd still want to show warnings in crates that are open in the UI but are not the main crate. Though I guess not doing would be fine too...

@asterite
Copy link
Collaborator Author

asterite commented Jan 3, 2025

It worked! And for some reason it works well in LSP too, maybe the code there is slightly different, or maybe all crates are checked, not sure.

Copy link
Contributor

github-actions bot commented Jan 3, 2025

Execution Memory Report

Program Peak Memory
keccak256 74.61M
workspace 123.80M
regression_4709 315.92M
ram_blowup_regression 512.47M
rollup-base-public 3.05G
rollup-base-private 2.97G
private-kernel-tail 181.15M
private-kernel-reset 255.23M
private-kernel-inner 214.34M
parity-root 155.76M

Copy link
Contributor

github-actions bot commented Jan 3, 2025

Compilation Memory Report

Program Peak Memory
keccak256 78.48M
workspace 123.70M
regression_4709 422.91M
ram_blowup_regression 1.58G
rollup-base-public 10.47G
rollup-base-private 6.57G
private-kernel-tail 201.78M
private-kernel-reset 717.04M
private-kernel-inner 291.85M
parity-root 172.11M

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Automatically filter out any warnings which are thrown in dependencies
2 participants