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

Add fail_with_status host function, fix #146 #425

Merged
merged 2 commits into from
Sep 20, 2022
Merged

Conversation

graydon
Copy link
Contributor

@graydon graydon commented Sep 12, 2022

Addresses #146 by providing a fail_with_status function that users can call to fail the current contract call (trapping its vm) with a user-provided status. The status has to be the newly-added ScStatusType::ContractError with an opaque user-provided u32 body.

@graydon graydon requested review from jonjove, sisuresh and a team as code owners September 12, 2022 19:49
@graydon
Copy link
Contributor Author

graydon commented Sep 12, 2022

cc @jonjove and @leighmcculloch I am posting this to make discussion concrete -- we shouldn't merge this until we have consensus that it's the right thing to do.

Copy link
Member

@leighmcculloch leighmcculloch 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 to me.

Let's continue to discuss whether we should do this in https://github.com/stellar/stellar-xdr-next/issues/28.

/// Causes the currently executing contract to fail immediately
/// with a provided status code, which must be of error-type
/// `ScStatusType::ContractError`. Does not actually return.
{"9", fn fail_with_status(status:Status) -> RawVal }
Copy link
Member

Choose a reason for hiding this comment

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

I'm wondering if fail is the best term for us to use. Maybe we should use abort_with_, since what will happen is equivalent to aborting? This isn't particularly important and it is fine, and maybe preferable, as is.

Copy link
Member

@leighmcculloch leighmcculloch left a comment

Choose a reason for hiding this comment

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

One word change in error text, otherwise LGTM.

Also, one build is failing.

@graydon graydon force-pushed the bug-146-fail-with-status branch from 9b68ab8 to ec2575e Compare September 20, 2022 20:13
@graydon graydon enabled auto-merge (squash) September 20, 2022 20:14
@graydon graydon merged commit c9ea486 into main Sep 20, 2022
@graydon graydon deleted the bug-146-fail-with-status branch September 20, 2022 20:19
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.

2 participants