diff options
| author | José Valim <[email protected]> | 2015-05-14 13:26:16 +0200 | 
|---|---|---|
| committer | José Valim <[email protected]> | 2015-05-14 13:26:17 +0200 | 
| commit | 5f5ce84d0f85faba7f9f26059a08a2ba9122f524 (patch) | |
| tree | dcef42757ab9cd4cc6f8297de7bbc72758f43839 /lib/stdlib/src | |
| parent | 6a3e878126da1e8d75c704510c7a7339ff306138 (diff) | |
| download | otp-5f5ce84d0f85faba7f9f26059a08a2ba9122f524.tar.gz otp-5f5ce84d0f85faba7f9f26059a08a2ba9122f524.tar.bz2 otp-5f5ce84d0f85faba7f9f26059a08a2ba9122f524.zip | |
Cache nowarn_bif_clash functions in erl_lint
When compiling parser files, because they rely heavily
on inline annotations, retrieving the nowarn_bif_clash
information from the compiler options is expensive.
This patch stores nowarn_bif_clash in the lint record.
By using erlc +'{eprof,lint_module}' when compiling the
erlang parser, we noticed the time spent on
nowarn_function/2 reduced from 30% to 0.01%.
Diffstat (limited to 'lib/stdlib/src')
| -rw-r--r-- | lib/stdlib/src/erl_lint.erl | 8 | 
1 files changed, 4 insertions, 4 deletions
| diff --git a/lib/stdlib/src/erl_lint.erl b/lib/stdlib/src/erl_lint.erl index 821d81a6b4..c68ec601bf 100644 --- a/lib/stdlib/src/erl_lint.erl +++ b/lib/stdlib/src/erl_lint.erl @@ -120,6 +120,7 @@ value_option(Flag, Default, On, OnVal, Off, OffVal, Opts) ->                 func=[],                         %Current function                 warn_format=0,                   %Warn format calls  	       enabled_warnings=[],		%All enabled warnings (ordset). +               nowarn_bif_clash=[],             %All no warn bif clashes (ordset).                 errors=[],                       %Current errors                 warnings=[],                     %Current warnings                 file = ""        :: string(),	%From last file attribute @@ -569,6 +570,7 @@ start(File, Opts) ->            warn_format = value_option(warn_format, 1, warn_format, 1,  				     nowarn_format, 0, Opts),  	  enabled_warnings = Enabled, +          nowarn_bif_clash = nowarn_function(nowarn_bif_clash, Opts),            file = File           }. @@ -772,8 +774,7 @@ eof(_Line, St0) ->  %% bif_clashes(Forms, State0) -> State. -bif_clashes(Forms, St) -> -    Nowarn = nowarn_function(nowarn_bif_clash, St#lint.compile), +bif_clashes(Forms, #lint{nowarn_bif_clash=Nowarn} = St) ->      Clashes0 = [{Name,Arity} || {function,_L,Name,Arity,_Cs} <- Forms,                                  erl_internal:bif(Name, Arity)],      Clashes = ordsets:subtract(ordsets:from_list(Clashes0), Nowarn), @@ -3781,8 +3782,7 @@ is_autoimport_suppressed(NoAutoSet,{Func,Arity}) ->      gb_sets:is_element({Func,Arity},NoAutoSet).  %% Predicate to find out if a function specific bif-clash suppression (old deprecated) is present  bif_clash_specifically_disabled(St,{F,A}) -> -    Nowarn = nowarn_function(nowarn_bif_clash, St#lint.compile), -    lists:member({F,A},Nowarn). +    lists:member({F,A},St#lint.nowarn_bif_clash).  %% Predicate to find out if an autoimported guard_bif is not overriden in some way  %% Guard Bif without module name is disallowed if | 
