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

fix: Display warning if last expression of block is unused #2314

Merged
merged 3 commits into from
Aug 16, 2023

Conversation

alexvitkov
Copy link
Contributor

Description

We normally throw an error on unused expression:

fn foo() {
    3 + 2; // error: expected (), got field
    5;
}

However we currently fail to catch the case where there's only one expression:

fn foo() {
    3 + 2; // no error :(
}

This PR fixes that, and per suggestion of @jfecher (#2304 (comment)) converts that error to a warning. This is probably also needed, since otherwise it breaks a few tests that rely on the old behavior, and potentially user code.

Nicer error message is also provided:

Before:

error: Expected type (), found type Field
  ┌─ /home/vitkov/code/repos/metacraft-labs/noir/proj/src/main.nr:3:5
  │
3 │     5;
  │     -

After:

warning: Unused expression result (of type Field)
  ┌─ /home/vitkov/code/repos/metacraft-labs/noir/proj/src/main.nr:3:5
  │
3 │     5;
  │     -

Problem*

Resolves #2304

Summary*

Documentation

  • This PR requires documentation updates when merged.

    • I will submit a noir-lang/docs PR.
    • I will request for and support Dev Rel's help in documenting this PR.

PR Checklist*

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

@TomAFrench TomAFrench changed the title fix: Warning if last expression of block is unused fix: Display warning if last expression of block is unused Aug 16, 2023
Copy link
Contributor

@jfecher jfecher left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you!

@jfecher jfecher added this pull request to the merge queue Aug 16, 2023
@TomAFrench TomAFrench removed this pull request from the merge queue due to a manual request Aug 16, 2023
@TomAFrench
Copy link
Member

I'm currently in the process of pushing out a bug fix release containing #2340. I'll add this back to the queue once that's out.

@TomAFrench TomAFrench added this pull request to the merge queue Aug 16, 2023
Merged via the queue into noir-lang:master with commit 8110136 Aug 16, 2023
TomAFrench added a commit that referenced this pull request Aug 16, 2023
* master:
  fix: Display warning if last expression of block is unused (#2314)
  chore(noir): Release 0.10.2 (#2343)
  fix: Prevent dead instruction elimination of brillig functions which may contain side-effects (#2340)
  chore: Separate integration tests for contracts and programs (#2339)
TomAFrench added a commit that referenced this pull request Aug 17, 2023
* master: (25 commits)
  chore: update noir-source-resolver from `1.1.2` to `^1.1.3` (#2349)
  chore(ci): Avoid writing to cache in workflows triggered by the merge queue (#2341)
  chore(noir): Release 0.10.3 (#2344)
  feat(lsp): Add `Execute` code lens for `main` functions (#2330)
  feat(lsp): Add `Compile` code lens for `main` function and contracts (#2309)
  feat: Allow calling higher-order functions with closures (#2335)
  fix: Display warning if last expression of block is unused (#2314)
  chore(noir): Release 0.10.2 (#2343)
  fix: Prevent dead instruction elimination of brillig functions which may contain side-effects (#2340)
  chore: Separate integration tests for contracts and programs (#2339)
  chore: move orphaned integration tests to new directory (#2331)
  chore(noir): Release 0.10.1 (#2328)
  feat(ssa): Switch mem2reg pass to be per function rather than per block (#2243)
  feat(ssa): Perform dead instruction elimination on intrinsic functions (#2276)
  feat: Add full call stacks to runtime errors (#2310)
  chore(ci): fix mismatched input name to publish workflow (#2327)
  chore: add README for integration test structure (#2277)
  feat: Improved error message for unexpected return type (#2302)
  feat(stdlib): Implement `str` `as_bytes` and `into_bytes` function (#2298)
  chore(ci): automatically convert changelog entries to sentence case (#2325)
  ...
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.

Type check error on non-unit expression statements
3 participants