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

HookEmit #392

Open
wants to merge 18 commits into
base: dev
Choose a base branch
from
Open

HookEmit #392

wants to merge 18 commits into from

Conversation

tequdev
Copy link
Collaborator

@tequdev tequdev commented Nov 15, 2024

close #365

High Level Overview of Change

Context of Change

Type of Change

  • Bug fix (non-breaking change which fixes an issue)
  • New feature (non-breaking change which adds functionality)
  • Breaking change (fix or feature that would cause existing functionality to not work as expected)
  • Refactor (non-breaking change that only restructures code)
  • Tests (you added tests for code that already exists, or your new feature included in this PR)
  • Documentation update
  • Chore (no impact to binary, e.g. .gitignore, formatting, dropping support for older tooling)
  • Release

API Impact

  • Public API: New feature (new methods and/or new fields)
  • Public API: Breaking change (in general, breaking changes should only impact the next api_version)
  • libxrpl change (any change that may affect libxrpl or dependents of libxrpl)
  • Peer protocol change (must be backward compatible or bump the peer protocol version)

@RichardAH
Copy link
Contributor

hopefully we'll get this into the release after next

@tequdev
Copy link
Collaborator Author

tequdev commented Dec 11, 2024

hopefully we'll get this into the release after next

Due to waiting for the probability of a deterministic build, I don’t add enough tests at this time.

@tequdev tequdev changed the title HookEmit [DO NOT MERGE] HookEmit Mar 4, 2025
@tequdev tequdev requested review from dangell7 and RichardAH March 4, 2025 12:58
@tequdev tequdev added the feature Feature Request label Mar 4, 2025
@tequdev tequdev changed the title HookEmit HookEmit [DO NOT MERGE] Mar 5, 2025
@tequdev tequdev changed the title HookEmit [DO NOT MERGE] HookEmit Mar 5, 2025
@tequdev tequdev changed the title HookEmit HookEmit [DO NOT MERGE] Mar 5, 2025
@tequdev tequdev changed the title HookEmit [DO NOT MERGE] HookEmit Apr 1, 2025
@RichardAH
Copy link
Contributor

I think HookEmit is a bit of a confusing label? Maybe HookEmittable? Or HookCanEmit

@tequdev
Copy link
Collaborator Author

tequdev commented Apr 2, 2025

hookSetObj.isFieldPresent(sfHookEmit))

@RichardAH
Yes, at this moment I have chosen HookEmit because of its simplicity and the similarity of its sound to HookOn.
I have no objection to changing the name to something else.

@sublimator
Copy link
Collaborator

I think HookEmit is a bit of a confusing label? Maybe HookEmittable? Or HookCanEmit

I agree it's not totally clear even though it is nice and concise.

There's arguments to be made for various names that prioritize brevity, for consistency with existing fields etc, but clarity is important for approachability too. I've chatted to various AIs and they'll be adamant initially that HookEmit is the best, but then can yield to various arguments.

I was drawn to HookCanEmit initially as it's very clear.

What about sfEmitMask ? The hook definition already has sfCreateCode as exception to any perceived Hook* naming convention.


uint256 hookEmit =
(hookObj.isFieldPresent(sfHookEmit)
? hookObj.getFieldH256(sfHookEmit)
Copy link
Collaborator

Choose a reason for hiding this comment

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

Maybe a helper function for this

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

Successfully merging this pull request may close these issues.

New field in the Hook object that limits the TransactionType that can be emitted from within the Hook
3 participants