Allow user-defined sigils via parse transforms #9647
+16
−6
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This is a POC of custom sigils implementation for Erlang/OTP.
It is based on this comment on the Erlang Forums.
This is a minimal change and does not break any existing code.
How it works
The developer can use the built-in sigils, like
s
,S
,b
, andB
, but it can also use any sigil it wants. However, it is obligated to handle the custom sigil with parse transform, otherwise, aninvalid sigil
exception will be raised at the compile time.Why parse transform?
It was the first idea and seems to be the simplest one to implement this feature.
Example
Important
Please refer to the example project for the complete code.
Running it
Notes
I have no idea what the core team has planned for sigils.
This PR is just to initiate a discussion about the future of sigils :)