[erlang-questions] Proposal to remove tuple dispatches from Erlang
Fred Hebert
mononcqc@REDACTED
Fri Apr 14 15:00:17 CEST 2017
On 04/14, José Valim wrote:
>This behaviour is considered by most in the community to be undesired
>and confusing, as it obfuscates the meaning of the code and adds
>indirection.
>
>Please let me know if there are other options available,
>
>I will be glad to send patches and implement the required parse-transforms
>if this is accepted by the OTP team.
>
One thing to consider is that this code is a remnant of parametrized
modules, which have been removed back in 2012. See https://web-beta.archive.org/web/20121019180935/http://www.erlang.org/news/35
> To allow for source code compatibility, the board decides to only
> remove the syntactic support for parameterized modules. This means:
>
> * Apply with tuple modules will be retained, supported and properly documented.
>
> [...]
>
> * The parser will accept the syntax for implementation of
> parameterized modules [...]
>
> * A parse_transform handling source code implementing a parameterized
> module will be published in the public domain, free to use and
> include in any package needing it. It will however not be part of OTP.
> As it uses supported and documented functionality, it will however
> be expected to work for forthcoming releases as well, or at least
> to be possible to adopt to forthcoming releases.
This is to say the OTP team made a commitment to supporting tuple calls
as a way to remove parametrized modules and keep the code working.
Removing tuple calls must at the very least ensure a seamless transition
to keep working with the parametrized module parse transforms, and
moreover have the guarantee that it will "be expected to work for
forthcoming releases" because it "uses supported and documented
functionality".
Regards,
Fred.
More information about the erlang-questions
mailing list