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

[move-compiler-v2] clean up a few remaining issues in lambda parser/front-end code #15365

Merged
merged 2 commits into from
Dec 4, 2024

Conversation

brmataptos
Copy link
Contributor

@brmataptos brmataptos commented Nov 22, 2024

Description

Various fixes:

  • Remove Constraint::NoFunction as it's too broad.
  • Make sure there are still errors for all planned unsupported cases
  • Fix LambdaLifter case for bound free variable without copy.
  • Distinguish between "not supported" and "not implemented" for lambda features.
  • Refine lambda test cases to make _ok versions that compile up to "not implemented" errors.
  • Add a test case to illustrate the function name aliasing issue ([Bug][move-compiler-v2] visible function names shadow local variables with same name in function calls #15360), but changed other tests here to avoid it.

How Has This Been Tested?

Usual tests run, showing unchanged behavior on existing code. Tests under /lambda/ without .lambda. config show proper errors generated if to many functions are used. _ok tests now show code working up until "not implemented" errors.

Key Areas to Review

Most complex stuff is in previous PR, but:

  • Am I missing some ability cases (e.g., filtering for store and copy properties in captured free variables?
  • Are closures with references getting through?
  • Do /lambda/storage/*_ok.move tests look like reasonable code to expect from users?

Type of Change

  • New feature
  • Bug fix
  • Breaking change
  • Performance improvement
  • Refactoring
  • Dependency update
  • Documentation update
  • Tests

Which Components or Systems Does This Change Impact?

  • Validator Node
  • Full Node (API, Indexer, etc.)
  • Move/Aptos Virtual Machine
  • Aptos Framework
  • Aptos CLI/SDK
  • Developer Infrastructure
  • Move Compiler
  • Other (specify)

Checklist

  • I have read and followed the CONTRIBUTING doc
  • I have performed a self-review of my own code
  • I have commented my code, particularly in hard-to-understand areas
  • I identified and added all stakeholders and component owners affected by this change as reviewers
  • I tested both happy and unhappy path of the functionality
  • I have made corresponding changes to the documentation

Copy link

trunk-io bot commented Nov 22, 2024

⏱️ 1h 22m total CI duration on this PR
Job Cumulative Duration Recent Runs
rust-move-tests 12m 🟩
rust-move-tests 12m 🟥
rust-move-tests 12m 🟥
rust-move-tests 12m 🟥
rust-move-tests 12m 🟥
rust-cargo-deny 9m 🟩🟩🟩🟩🟩
check-dynamic-deps 6m 🟩🟩🟩🟩🟩 (+1 more)
general-lints 2m 🟩🟩🟩🟩🟩
semgrep/ci 2m 🟩🟩🟩🟩🟩
file_change_determinator 57s 🟩🟩🟩🟩🟩
permission-check 21s 🟩🟩🟩🟩🟩
permission-check 14s 🟩🟩🟩🟩🟩
check-branch-prefix 1s 🟩

🚨 1 job on the last run was significantly faster/slower than expected

Job Duration vs 7d avg Delta
check-dynamic-deps 2m 1m +84%

settingsfeedbackdocs ⋅ learn more about trunk.io

@brmataptos brmataptos changed the title lambda-compiler-completion [move-compiler-v2] clean up a few remaining issues in lambda parser/front-end code Nov 22, 2024
@brmataptos brmataptos marked this pull request as ready for review November 22, 2024 01:45
@brmataptos brmataptos force-pushed the 11-21-lambda-compiler-completion branch from 3e3563e to dac085c Compare November 22, 2024 21:39
env.error(
&loc,
// TODO(LAMBDA)
"Lambdas expressions with `store` ability currently may only be a simple call to an existing `public` function. This lambda expression requires defining a `public` helper function, which might affect module upgradeability and is not yet supported."
Copy link
Contributor

Choose a reason for hiding this comment

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

This error message looks a little bit confusing for users (e.g what is a helper function and how it may affect upgradeability). Maybe just remove requires defining a public helper function, which might affect module upgradeability` and just saying it is not supported yet?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

done.

env.error(
&loc,
&format!(
"captured variable `{}` must have a value with `copy` ability", // TODO(LAMBDA)
Copy link
Contributor

Choose a reason for hiding this comment

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

Is there a test case for this error?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

added closure_args.move, see closure_args.lambda.exp.

This exercises a lot of cases.

self.emit_call(id, vec![target], BytecodeOperation::ReadRef, vec![
borrow_dest,
])
self.emit_call(
Copy link
Contributor

Choose a reason for hiding this comment

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

Looks like formatting only change? When I run the formatter, it goes back to the original.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

fixed.

probing_vars: Some(_),
..
})
matches!(
Copy link
Contributor

Choose a reason for hiding this comment

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

Similar as above, when I run the formatter, this goes back to original.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

should be fixed,

}

public inline fun quux(f:|u64, u64|u64, a: u64, b: u64): u64 {
f(a, b)
Copy link
Contributor

Choose a reason for hiding this comment

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

Could we also add test cases where we have:

  1. Use statement importing (at the module level and at the function level) a function foo, where foo is also a function parameter to an inline function like here.
  2. Similar as above, but without explicit use statement and instead explicit qualification like other_module::foo.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

This is rather tangential to this PR, but I've added use statements. The explicit qualification case is not interesting, as we know what it will do.

What is happening is very clear if you look at move-compiler/src/expander/translation.rs and .../aliases.rs, which tracks nesting of use of symbols from other modules. All that is tracked are those imported symbols, not any local variables. A name in function call position (and a few other places) is turned into an explicit ModuleIdent::Name pair. A name in other positions may be left unevaluated until later.

node_id,
modified: true,
});
self.free_locals.insert(
Copy link
Contributor

Choose a reason for hiding this comment

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

A number of changes here seem to be only whitespace changes that go away when I format. Any idea how these changes came by?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Merge conflicts? Also, Emacs sometimes indents differently than the Rust usual.

let Some((mut params, mut closure_args, param_index_mapping)) =
self.get_params_for_freevars()
else {
return None;
Copy link
Contributor

Choose a reason for hiding this comment

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

I think the ? operator fits well here.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Done, though I personally find it a little too subtle.

@brmataptos brmataptos force-pushed the 09-27-add_parser_code_for_lambda_types branch from cead217 to 44baaf0 Compare November 27, 2024 10:24
@brmataptos brmataptos force-pushed the 11-21-lambda-compiler-completion branch from 42421fe to 92ae56c Compare November 27, 2024 10:24
@brmataptos brmataptos force-pushed the 11-21-lambda-compiler-completion branch from 92ae56c to 3c02ba1 Compare November 27, 2024 22:41
@brmataptos brmataptos force-pushed the 09-27-add_parser_code_for_lambda_types branch from bab1e7d to 4cf9a1a Compare December 1, 2024 05:57
@brmataptos brmataptos force-pushed the 11-21-lambda-compiler-completion branch 2 times, most recently from ae4444b to 8b37927 Compare December 1, 2024 06:46
Base automatically changed from 09-27-add_parser_code_for_lambda_types to main December 1, 2024 07:28
@brmataptos brmataptos requested a review from vineethk December 4, 2024 04:07
@brmataptos brmataptos force-pushed the 11-21-lambda-compiler-completion branch from 02fb9ec to f2281b4 Compare December 4, 2024 07:23
@brmataptos brmataptos requested a review from areshand as a code owner December 4, 2024 07:54
@brmataptos brmataptos force-pushed the 11-21-lambda-compiler-completion branch from d329f76 to 2734528 Compare December 4, 2024 22:49
@brmataptos brmataptos enabled auto-merge (squash) December 4, 2024 22:53

This comment has been minimized.

This comment has been minimized.

This comment has been minimized.

Copy link
Contributor

github-actions bot commented Dec 4, 2024

✅ Forge suite realistic_env_max_load success on 2734528a61d08756708c0140a24831ce4200ab69

two traffics test: inner traffic : committed: 14328.87 txn/s, latency: 2770.94 ms, (p50: 2700 ms, p70: 2700, p90: 3000 ms, p99: 3900 ms), latency samples: 5448200
two traffics test : committed: 100.07 txn/s, latency: 1407.80 ms, (p50: 1400 ms, p70: 1500, p90: 1500 ms, p99: 2000 ms), latency samples: 1800
Latency breakdown for phase 0: ["MempoolToBlockCreation: max: 1.684, avg: 1.568", "ConsensusProposalToOrdered: max: 0.308, avg: 0.296", "ConsensusOrderedToCommit: max: 0.373, avg: 0.363", "ConsensusProposalToCommit: max: 0.669, avg: 0.659"]
Max non-epoch-change gap was: 1 rounds at version 2542709 (avg 0.00) [limit 4], 1.85s no progress at version 2542709 (avg 0.21s) [limit 15].
Max epoch-change gap was: 0 rounds at version 0 (avg 0.00) [limit 4], 0.63s no progress at version 2164659 (avg 0.63s) [limit 16].
Test Ok

Copy link
Contributor

github-actions bot commented Dec 4, 2024

✅ Forge suite framework_upgrade success on 3527aa2e299553b759c515d9843586bad48c802c ==> 2734528a61d08756708c0140a24831ce4200ab69

Compatibility test results for 3527aa2e299553b759c515d9843586bad48c802c ==> 2734528a61d08756708c0140a24831ce4200ab69 (PR)
Upgrade the nodes to version: 2734528a61d08756708c0140a24831ce4200ab69
framework_upgrade::framework-upgrade::full-framework-upgrade : committed: 1295.88 txn/s, submitted: 1299.72 txn/s, failed submission: 3.84 txn/s, expired: 3.84 txn/s, latency: 2284.71 ms, (p50: 1800 ms, p70: 2400, p90: 3900 ms, p99: 5300 ms), latency samples: 114620
framework_upgrade::framework-upgrade::full-framework-upgrade : committed: 1330.07 txn/s, submitted: 1333.84 txn/s, failed submission: 3.77 txn/s, expired: 3.77 txn/s, latency: 2171.70 ms, (p50: 2000 ms, p70: 2300, p90: 3300 ms, p99: 4800 ms), latency samples: 120040
5. check swarm health
Compatibility test for 3527aa2e299553b759c515d9843586bad48c802c ==> 2734528a61d08756708c0140a24831ce4200ab69 passed
Upgrade the remaining nodes to version: 2734528a61d08756708c0140a24831ce4200ab69
framework_upgrade::framework-upgrade::full-framework-upgrade : committed: 1384.67 txn/s, submitted: 1388.04 txn/s, failed submission: 3.37 txn/s, expired: 3.37 txn/s, latency: 2188.71 ms, (p50: 2100 ms, p70: 2400, p90: 3300 ms, p99: 4600 ms), latency samples: 123440
Test Ok

Copy link
Contributor

github-actions bot commented Dec 4, 2024

✅ Forge suite compat success on 3527aa2e299553b759c515d9843586bad48c802c ==> 2734528a61d08756708c0140a24831ce4200ab69

Compatibility test results for 3527aa2e299553b759c515d9843586bad48c802c ==> 2734528a61d08756708c0140a24831ce4200ab69 (PR)
1. Check liveness of validators at old version: 3527aa2e299553b759c515d9843586bad48c802c
compatibility::simple-validator-upgrade::liveness-check : committed: 17226.40 txn/s, latency: 1974.34 ms, (p50: 2100 ms, p70: 2100, p90: 2200 ms, p99: 2300 ms), latency samples: 553740
2. Upgrading first Validator to new version: 2734528a61d08756708c0140a24831ce4200ab69
compatibility::simple-validator-upgrade::single-validator-upgrading : committed: 7211.06 txn/s, latency: 3858.16 ms, (p50: 4100 ms, p70: 4600, p90: 4900 ms, p99: 5300 ms), latency samples: 131220
compatibility::simple-validator-upgrade::single-validator-upgrade : committed: 7352.60 txn/s, latency: 4423.65 ms, (p50: 4700 ms, p70: 4900, p90: 5200 ms, p99: 6200 ms), latency samples: 240220
3. Upgrading rest of first batch to new version: 2734528a61d08756708c0140a24831ce4200ab69
compatibility::simple-validator-upgrade::half-validator-upgrading : committed: 7368.02 txn/s, latency: 3869.98 ms, (p50: 4400 ms, p70: 4600, p90: 4700 ms, p99: 4800 ms), latency samples: 138300
compatibility::simple-validator-upgrade::half-validator-upgrade : committed: 7550.33 txn/s, latency: 4358.64 ms, (p50: 4700 ms, p70: 4700, p90: 4800 ms, p99: 4900 ms), latency samples: 243380
4. upgrading second batch to new version: 2734528a61d08756708c0140a24831ce4200ab69
compatibility::simple-validator-upgrade::rest-validator-upgrading : committed: 2862.72 txn/s, submitted: 2862.87 txn/s, expired: 0.15 txn/s, latency: 2353.96 ms, (p50: 2600 ms, p70: 2800, p90: 3000 ms, p99: 3000 ms), latency samples: 204909
compatibility::simple-validator-upgrade::rest-validator-upgrade : committed: 12225.25 txn/s, latency: 2619.97 ms, (p50: 2700 ms, p70: 2800, p90: 3000 ms, p99: 3200 ms), latency samples: 394200
5. check swarm health
Compatibility test for 3527aa2e299553b759c515d9843586bad48c802c ==> 2734528a61d08756708c0140a24831ce4200ab69 passed
Test Ok

@brmataptos brmataptos merged commit c6f5752 into main Dec 4, 2024
86 of 88 checks passed
@brmataptos brmataptos deleted the 11-21-lambda-compiler-completion branch December 4, 2024 23:23
danielxiangzl pushed a commit that referenced this pull request Dec 12, 2024
…ront-end code (#15365)

- Distinguish between "not supported" and "not implemented" for lambda features.
- Add a test case to illustrate the function name aliasing issue ([Bug][move-compiler-v2] visible function names shadow local variables with same name in function calls #15360), but changed other tests here to avoid it.
- Remove Constraint::NoFunction as it's too broad.
- Make sure there are still errors for all planned unsupported cases
- Fix LambdaLifter case for bound free variable without copy.
- Refine lambda test cases to make _ok versions that compile up to "not implemented" errors.
danielxiangzl pushed a commit that referenced this pull request Dec 12, 2024
…ront-end code (#15365)

- Distinguish between "not supported" and "not implemented" for lambda features.
- Add a test case to illustrate the function name aliasing issue ([Bug][move-compiler-v2] visible function names shadow local variables with same name in function calls #15360), but changed other tests here to avoid it.
- Remove Constraint::NoFunction as it's too broad.
- Make sure there are still errors for all planned unsupported cases
- Fix LambdaLifter case for bound free variable without copy.
- Refine lambda test cases to make _ok versions that compile up to "not implemented" errors.
georgemitenkov pushed a commit that referenced this pull request Jan 6, 2025
…ront-end code (#15365)

- Distinguish between "not supported" and "not implemented" for lambda features.
- Add a test case to illustrate the function name aliasing issue ([Bug][move-compiler-v2] visible function names shadow local variables with same name in function calls #15360), but changed other tests here to avoid it.
- Remove Constraint::NoFunction as it's too broad.
- Make sure there are still errors for all planned unsupported cases
- Fix LambdaLifter case for bound free variable without copy.
- Refine lambda test cases to make _ok versions that compile up to "not implemented" errors.
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.

3 participants