diff options
author | Björn Gustavsson <[email protected]> | 2012-02-16 15:12:13 +0100 |
---|---|---|
committer | Björn Gustavsson <[email protected]> | 2012-02-16 15:12:13 +0100 |
commit | 7cd2fd917c8f4d6dff5ca1aca9d938a1790fc9a8 (patch) | |
tree | a495d229c0708e4c9ec611d4fd0383794da17712 /lib/compiler/src/cerl_inline.erl | |
parent | ddefaf865cb357a11e0aa80315a461e774c0d6fb (diff) | |
parent | f928756b2b7f26b90d962cc038d4ba68619c1bf5 (diff) | |
download | otp-7cd2fd917c8f4d6dff5ca1aca9d938a1790fc9a8.tar.gz otp-7cd2fd917c8f4d6dff5ca1aca9d938a1790fc9a8.tar.bz2 otp-7cd2fd917c8f4d6dff5ca1aca9d938a1790fc9a8.zip |
Merge branch 'bjorn/compiler/inline-and-on_load/OTP-9910' into maint
* bjorn/compiler/inline-and-on_load/OTP-9910:
compiler: Teach the inliner to preserve on_load functions
Diffstat (limited to 'lib/compiler/src/cerl_inline.erl')
-rw-r--r-- | lib/compiler/src/cerl_inline.erl | 24 |
1 files changed, 23 insertions, 1 deletions
diff --git a/lib/compiler/src/cerl_inline.erl b/lib/compiler/src/cerl_inline.erl index c15103999f..589685d72d 100644 --- a/lib/compiler/src/cerl_inline.erl +++ b/lib/compiler/src/cerl_inline.erl @@ -1262,8 +1262,9 @@ i_receive_1(E, Cs, T, B, S) -> i_module(E, Ctxt, Ren, Env, S) -> %% Cf. `i_letrec'. Note that we pass a dummy constant value for the %% "body" parameter. + Exps = i_module_exports(E), {Es, _, Xs1, S1} = i_letrec(module_defs(E), void(), - module_exports(E), Ctxt, Ren, Env, S), + Exps, Ctxt, Ren, Env, S), %% Sanity check: case Es of [] -> @@ -1276,6 +1277,27 @@ i_module(E, Ctxt, Ren, Env, S) -> E1 = update_c_module(E, module_name(E), Xs1, module_attrs(E), Es), {E1, count_size(weight(module), S1)}. +i_module_exports(E) -> + %% If a function is named in an `on_load' attribute, we will + %% pretend that it is exported to ensure that it will not be removed. + Exps = module_exports(E), + Attrs = module_attrs(E), + case i_module_on_load(Attrs) of + none -> + Exps; + [{_,_}=FA] -> + ordsets:add_element(c_var(FA), Exps) + end. + +i_module_on_load([{Key,Val}|T]) -> + case concrete(Key) of + on_load -> + concrete(Val); + _ -> + i_module_on_load(T) + end; +i_module_on_load([]) -> none. + %% Binary-syntax expressions are too complicated to do anything %% interesting with here - that is beyond the scope of this program; %% also, their construction could have side effects, so even in effect |