diff options
Diffstat (limited to 'lib/kernel/src/code_server.erl')
| -rw-r--r-- | lib/kernel/src/code_server.erl | 16 | 
1 files changed, 11 insertions, 5 deletions
| diff --git a/lib/kernel/src/code_server.erl b/lib/kernel/src/code_server.erl index 32a12e2b52..00ad923466 100644 --- a/lib/kernel/src/code_server.erl +++ b/lib/kernel/src/code_server.erl @@ -1,7 +1,7 @@  %%  %% %CopyrightBegin%  %% -%% Copyright Ericsson AB 1998-2011. All Rights Reserved. +%% Copyright Ericsson AB 1998-2012. All Rights Reserved.  %%  %% The contents of this file are subject to the Erlang Public License,  %% Version 1.1, (the "License"); you may not use this file except in @@ -394,8 +394,8 @@ handle_call(stop,{_From,_Tag}, S) ->  handle_call({is_cached,_File}, {_From,_Tag}, S=#state{cache=no_cache}) ->      {reply, no, S}; -handle_call({set_primary_archive, File, ArchiveBin, FileInfo}, {_From,_Tag}, S=#state{mode=Mode}) -> -    case erl_prim_loader:set_primary_archive(File, ArchiveBin, FileInfo) of +handle_call({set_primary_archive, File, ArchiveBin, FileInfo, ParserFun}, {_From,_Tag}, S=#state{mode=Mode}) -> +    case erl_prim_loader:set_primary_archive(File, ArchiveBin, FileInfo, ParserFun) of  	{ok, Files} ->  	    {reply, {ok, Mode, Files}, S};  	{error, _Reason} = Error -> @@ -1317,15 +1317,21 @@ int_list([H|T]) when is_integer(H) -> int_list(T);  int_list([_|_])                    -> false;  int_list([])                       -> true. +load_file(Mod0, {From,_}=Caller, St0) -> +    Mod = to_atom(Mod0), +    case pending_on_load(Mod, From, St0) of +	no -> load_file_1(Mod, Caller, St0); +	{yes,St} -> {noreply,St} +    end. -load_file(Mod, Caller, #state{path=Path,cache=no_cache}=St) -> +load_file_1(Mod, Caller, #state{path=Path,cache=no_cache}=St) ->      case mod_to_bin(Path, Mod) of  	error ->  	    {reply,{error,nofile},St};  	{Mod,Binary,File} ->  	    try_load_module(File, Mod, Binary, Caller, St)      end; -load_file(Mod, Caller, #state{cache=Cache}=St0) -> +load_file_1(Mod, Caller, #state{cache=Cache}=St0) ->      Key = {obj,Mod},      case ets:lookup(Cache, Key) of  	[] ->  | 
