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

Adding binding rules to typeof(<enum>).min and max, and to <enum>.<member> so they work with extensions #1177

Open
wants to merge 14 commits into
base: main
Choose a base branch
from

Conversation

beta-ziliani
Copy link
Contributor

@beta-ziliani beta-ziliani commented Dec 2, 2024

Fixes #1158.
Fixes #1196.

Considerations:

  • It's built on top of Solidity binding fixes driven by Sanctuary #1149 It's rebased on master.
  • It's currently missing a test for max
  • I adapted an existing test, though maybe it's preferred to add a different one?
  • I use the same test for min and max, I think it makes sense to have them together. I'm not so sure where to put it though. It's testing these functions, but also in combination with using for, so it can very well be moved to the using folder.

EDITED

@beta-ziliani beta-ziliani requested review from a team as code owners December 2, 2024 17:04
Copy link

changeset-bot bot commented Dec 2, 2024

⚠️ No Changeset found

Latest commit: bd2ad90

Merging this PR will not cause a version bump for any packages. If these changes should not result in a new version, you're good to go. If these changes should result in a version bump, you need to add a changeset.

This PR includes no changesets

When changesets are added to this PR, you'll see the packages that this PR includes changesets for and the associated semver types

Click here to learn what changesets are, and how to add one.

Click here if you're a maintainer who wants to add a changeset to this PR

Copy link
Contributor

@OmarTawfik OmarTawfik left a comment

Choose a reason for hiding this comment

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

I think this needs rebasing on latest main.

cc @ggiraldez if you don't mind a quick review?

@OmarTawfik OmarTawfik requested a review from ggiraldez December 3, 2024 09:36
@beta-ziliani
Copy link
Contributor Author

I suppose it's best to wait for #1149 to be in sync with main, and then rebase this one on top of it

Copy link
Contributor

@ggiraldez ggiraldez left a comment

Choose a reason for hiding this comment

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

I left a couple of comments that need addressing. Please ping me if you have questions.

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 file is a left over from #1196, but it doesn't harm to have it here

@beta-ziliani beta-ziliani changed the title Adding binding rules so typeof(enum).min and typeof(enum).max resolve to the enum's scope Adding binding rules to typeof(<enum>).min and max, and to <enum>.<member> so they work with extensions Dec 20, 2024
Copy link
Contributor

@ggiraldez ggiraldez left a comment

Choose a reason for hiding this comment

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

Left a couple of suggestions.

crates/solidity/inputs/language/bindings/rules.msgb Outdated Show resolved Hide resolved
crates/solidity/inputs/language/bindings/rules.msgb Outdated Show resolved Hide resolved
crates/solidity/inputs/language/bindings/rules.msgb Outdated Show resolved Hide resolved
@beta-ziliani
Copy link
Contributor Author

beta-ziliani commented Jan 13, 2025

This is ready for another review. CI is complaining that

> Generated file is out of date: "/workspaces/slang/crates/solidity/testing/snapshots/bindings_output/expressions/type_expr_minmax/generated/0.4.11-failure.txt"'

although locally it runs fine and the working tree is clean, so I'm uncertain as to what should I do

I think the issue is addressed in bd2ad90. I still don't understand why CI was not showing a problem on my end.

Copy link
Contributor

@ggiraldez ggiraldez left a comment

Choose a reason for hiding this comment

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

Looks good except for the version restriction on binding enum members.

Comment on lines +2089 to +2091
if (version-matches ">= 0.6.8") {
edge def -> @enum.value_ref_typeof
}
Copy link
Contributor

Choose a reason for hiding this comment

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

This should not be version restricted. I tried in Remix and binding enum members work for all our supported versions (eg. >= 0.4.11).

using Id for Answer;

function testFunc() returns (Answer) {
Answer.Yes.id();
Copy link
Contributor

Choose a reason for hiding this comment

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

This should resolve for all versions, but you'll need to move the enum inside the library because top-level enums are not supported before 0.6.0.

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