[eeps] [erlang-patches] EEP37: Funs with names
Anthony Ramine
n.oxyde@REDACTED
Sun Dec 1 13:46:08 CET 2013
Amended with your fixup and some covering code for functions named with "_" in xref_SUITE.
Please refetch.
--
Anthony Ramine
Le 28 nov. 2013 à 13:52, Anthony Ramine <n.oxyde@REDACTED> a écrit :
> Hello Björn,
>
> Replied inline.
>
> --
> Anthony Ramine
>
> Le 28 nov. 2013 à 13:44, Björn Gustavsson <bgustavsson@REDACTED> a écrit :
>
>> On Wed, Nov 14, 2012 at 5:42 PM, Anthony Ramine <n.oxyde@REDACTED> wrote:
>> This patch implements EEP37: Funs with names
>>
>>
>> It is now much closer to being graduated.
>>
>> I have added the branch to our daily builds for the master branch.
>
> Cool.
>
>> I would like a comment from Kostis about the Dialyzer changes.
>
> Me too, he suggested to me that it might break HiPE too but I couldn’t make HiPE crash.
>
>> What also remains is coverage in test suites. I have fixed a few,
>> but xref_SUITE remains to be fixed (a named fun with the '_' name
>> should be tested).
>
> Will do.
>
>> Here are my fixes for the test suites (also included as an attachment
>> to make it easier to apply):
>
> Will apply.
>
>> diff --git a/lib/compiler/test/fun_SUITE.erl b/lib/compiler/test/fun_SUITE.erl
>> index 0ff846e..e35692e 100644
>> --- a/lib/compiler/test/fun_SUITE.erl
>> +++ b/lib/compiler/test/fun_SUITE.erl
>> @@ -197,10 +197,14 @@ external(Config) when is_list(Config) ->
>> call_me(I) ->
>> {ok,I}.
>>
>> -id(I) ->
>> - I.
>> -
>> eep37(Config) when is_list(Config) ->
>> F = fun Fact(N) when N > 0 -> N * Fact(N - 1); Fact(0) -> 1 end,
>> + Add = fun _(N) -> N + 1 end,
>> + UnusedName = fun BlackAdder(N) -> N + 42 end,
>> 720 = F(6),
>> + 10 = Add(9),
>> + 50 = UnusedName(8),
>> ok.
>> +
>> +id(I) ->
>> + I.
>> diff --git a/lib/debugger/test/fun_SUITE.erl b/lib/debugger/test/fun_SUITE.erl
>> index 569af6c..75e3b55 100644
>> --- a/lib/debugger/test/fun_SUITE.erl
>> +++ b/lib/debugger/test/fun_SUITE.erl
>> @@ -288,10 +288,14 @@ external(Config) when is_list(Config) ->
>> call_me(I) ->
>> {ok,I}.
>>
>> -id(I) ->
>> - I.
>> -
>> eep37(Config) when is_list(Config) ->
>> F = fun Fact(N) when N > 0 -> N * Fact(N - 1); Fact(0) -> 1 end,
>> + Add = fun _(N) -> N + 1 end,
>> + UnusedName = fun BlackAdder(N) -> N + 42 end,
>> 720 = F(6),
>> + 10 = Add(9),
>> + 50 = UnusedName(8),
>> ok.
>> +
>> +id(I) ->
>> + I.
>> diff --git a/lib/stdlib/test/erl_lint_SUITE.erl b/lib/stdlib/test/erl_lint_SUITE.erl
>> index ea90793..ad51bfa 100644
>> --- a/lib/stdlib/test/erl_lint_SUITE.erl
>> +++ b/lib/stdlib/test/erl_lint_SUITE.erl
>> @@ -644,7 +644,9 @@ unused_vars_warn_fun(Config) when is_list(Config) ->
>> u() ->
>> fun U(U) -> foo end; % U shadowed. U unused.
>> u() ->
>> - fun U(1) -> U; U(U) -> foo end. % U shadowed. U unused.
>> + fun U(1) -> U; U(U) -> foo end; % U shadowed. U unused.
>> + u() ->
>> + fun _(N) -> N + 1 end. % Cover handling of '_' name.
>> ">>,
>> [warn_unused_vars],
>> {error,[{3,erl_lint,{unbound_var,'U'}}],
>>
>>
>> id/1 is a common help function, so I want it to remain at the end
>> of the file.
>
> Thanks for nitpicking even more than myself :p
>
>> /Bjorn
More information about the eeps
mailing list