diff options
Diffstat (limited to 'lib/sasl/src')
| -rw-r--r-- | lib/sasl/src/release_handler.erl | 42 | ||||
| -rw-r--r-- | lib/sasl/src/release_handler_1.erl | 44 | ||||
| -rw-r--r-- | lib/sasl/src/systools_make.erl | 83 | ||||
| -rw-r--r-- | lib/sasl/src/systools_relup.erl | 9 | 
4 files changed, 109 insertions, 69 deletions
| diff --git a/lib/sasl/src/release_handler.erl b/lib/sasl/src/release_handler.erl index 4c43277848..b60aa847df 100644 --- a/lib/sasl/src/release_handler.erl +++ b/lib/sasl/src/release_handler.erl @@ -791,7 +791,7 @@ check_rel(Root, RelFile, Masters) ->  check_rel(Root, RelFile, LibDirs, Masters) ->      case consult(RelFile, Masters) of  	{ok, [RelData]} -> -	    check_rel_data(RelData, Root, LibDirs); +	    check_rel_data(RelData, Root, LibDirs, Masters);  	{ok, _} ->  	    throw({error, {bad_rel_file, RelFile}});  	{error, Reason} when is_tuple(Reason) -> @@ -800,7 +800,8 @@ check_rel(Root, RelFile, LibDirs, Masters) ->  	    throw({error, {FileError, RelFile}})      end. -check_rel_data({release, {Name, Vsn}, {erts, EVsn}, Libs}, Root, LibDirs) -> +check_rel_data({release, {Name, Vsn}, {erts, EVsn}, Libs}, Root, LibDirs, +		Masters) ->      Libs2 =  	lists:map(fun(LibSpec) ->  			  Lib = element(1, LibSpec), @@ -810,7 +811,7 @@ check_rel_data({release, {Name, Vsn}, {erts, EVsn}, Libs}, Root, LibDirs) ->  			      case lists:keysearch(Lib, 1, LibDirs) of  				  {value, {_Lib, _Vsn, Dir}} ->  				      Path = filename:join(Dir,LibName), -				      check_path(Path), +				      check_path(Path, Masters),  				      Path;  				  _ ->  				      filename:join([Root, "lib", LibName]) @@ -820,19 +821,34 @@ check_rel_data({release, {Name, Vsn}, {erts, EVsn}, Libs}, Root, LibDirs) ->  		  Libs),      #release{name = Name, vsn = Vsn, erts_vsn = EVsn,  	     libs = Libs2, status = unpacking}; -check_rel_data(RelData, _Root, _LibDirs) -> +check_rel_data(RelData, _Root, _LibDirs, _Masters) ->      throw({error, {bad_rel_data, RelData}}).  check_path(Path) -> -    case file:read_file_info(Path) of -	{ok, Info} when Info#file_info.type==directory -> -	    ok; -	{ok, _Info} -> -	    throw({error, {not_a_directory, Path}}); -	{error, _Reason} -> -	    throw({error, {no_such_directory, Path}}) -    end. -     +	check_path_response(Path, file:read_file_info(Path)). +check_path(Path, false)   -> check_path(Path); +check_path(Path, Masters) -> check_path_master(Masters, Path). + +%%----------------------------------------------------------------- +%% check_path at any master node. +%% If the path does not exist or is not a directory +%% at one node it should not exist at any other node either. +%%----------------------------------------------------------------- +check_path_master([Master|Ms], Path) -> +	case rpc:call(Master, file, read_file_info, [Path]) of +	{badrpc, _} -> consult_master(Ms, Path); +	Res         -> check_path_response(Path, Res) +	end; +check_path_master([], _Path) -> +	{error, no_master}. + +check_path_response(_Path, {ok, Info}) when Info#file_info.type==directory -> +	ok; +check_path_response(Path, {ok, _Info}) -> +	throw({error, {not_a_directory, Path}}); +check_path_response(Path, {error, _Reason}) -> +	throw({error, {no_such_directory, Path}}). +  do_check_install_release(RelDir, Vsn, Releases, Masters) ->      case lists:keysearch(Vsn, #release.vsn, Releases) of  	{value, #release{status = current}} -> diff --git a/lib/sasl/src/release_handler_1.erl b/lib/sasl/src/release_handler_1.erl index 9c0edf4e99..8d050fb7b0 100644 --- a/lib/sasl/src/release_handler_1.erl +++ b/lib/sasl/src/release_handler_1.erl @@ -1,7 +1,7 @@  %%  %% %CopyrightBegin%  %% -%% Copyright Ericsson AB 1996-2010. All Rights Reserved. +%% Copyright Ericsson AB 1996-2011. 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 @@ -20,7 +20,7 @@  %% External exports  -export([eval_script/3, eval_script/4, check_script/2]). --export([get_vsn/1]). %% exported because used in a test case +-export([get_current_vsn/1]). %% exported because used in a test case  -record(eval_state, {bins = [], stopped = [], suspended = [], apps = [],  		     libdirs, unpurged = [], vsns = [], newlibs = [], @@ -223,7 +223,7 @@ eval({load_object_code, {Lib, LibVsn, Modules}}, EvalState) ->  				    FName = filename:join(Ebin, File),  				    case erl_prim_loader:get_file(FName) of  					{ok, Bin, FName2} -> -					    NVsns = add_new_vsn(Mod, FName2, Vsns), +					    NVsns = add_new_vsn(Mod, Bin, Vsns),  					    {[{Mod, Bin, FName2} | Bins],NVsns};  					error ->  					    throw({error, {no_such_file,FName}}) @@ -609,17 +609,17 @@ sync_nodes(Id, Nodes) ->  add_old_vsn(Mod, Vsns) ->      case lists:keysearch(Mod, 1, Vsns) of  	{value, {Mod, undefined, NewVsn}} -> -	    OldVsn = get_vsn(code:which(Mod)), +	    OldVsn = get_current_vsn(Mod),  	    lists:keyreplace(Mod, 1, Vsns, {Mod, OldVsn, NewVsn});  	{value, {Mod, _OldVsn, _NewVsn}} ->  	    Vsns;  	false -> -	    OldVsn = get_vsn(code:which(Mod)), +	    OldVsn = get_current_vsn(Mod),  	    [{Mod, OldVsn, undefined} | Vsns]      end. -add_new_vsn(Mod, File, Vsns) -> -    NewVsn = get_vsn(File), +add_new_vsn(Mod, Bin, Vsns) -> +    NewVsn = get_vsn(Bin),      case lists:keysearch(Mod, 1, Vsns) of  	{value, {Mod, OldVsn, undefined}} ->  	    lists:keyreplace(Mod, 1, Vsns, {Mod, OldVsn, NewVsn}); @@ -627,17 +627,35 @@ add_new_vsn(Mod, File, Vsns) ->  	    [{Mod, undefined, NewVsn} | Vsns]      end. - +%%----------------------------------------------------------------- +%% Func: get_current_vsn/1 +%% Args: Mod = atom() +%% Purpose: This function returns the equivalent of  +%%   beam_lib:version(code:which(Mod)), but it will also handle the +%%   case when using erl_prim_loader loader different from 'efile'. +%%   The reason for not using the Binary from the 'bins' or the +%%   version directly from the 'vsns' state field is that these are +%%   updated already by load_object_code, and this function is called +%%   from load and remove. +%% Returns: Vsn = term() +%%----------------------------------------------------------------- +get_current_vsn(Mod) -> +    File = code:which(Mod), +    case erl_prim_loader:get_file(File) of +	{ok, Bin, _File2} -> +	    get_vsn(Bin); +	error -> +	    throw({error, {no_such_file, File}}) +    end.  %%-----------------------------------------------------------------  %% Func: get_vsn/1 -%% Args: File = string() +%% Args: Bin = binary()  %% Purpose: Finds the version attribute of a module. -%% Returns: Vsn -%%          Vsn = term() +%% Returns: Vsn = term()  %%----------------------------------------------------------------- -get_vsn(File) -> -    {ok, {_Mod, Vsn}} = beam_lib:version(File), +get_vsn(Bin) -> +    {ok, {_Mod, Vsn}} = beam_lib:version(Bin),      case misc_supp:is_string(Vsn) of  	true ->  	    Vsn; diff --git a/lib/sasl/src/systools_make.erl b/lib/sasl/src/systools_make.erl index 20a142c763..7489ee58d2 100644 --- a/lib/sasl/src/systools_make.erl +++ b/lib/sasl/src/systools_make.erl @@ -1,7 +1,7 @@  %%  %% %CopyrightBegin%  %%  -%% Copyright Ericsson AB 1996-2009. All Rights Reserved. +%% Copyright Ericsson AB 1996-2011. 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 @@ -50,7 +50,7 @@  %% the applications are found.  %%  %% New options: {path,Path} can contain wildcards -%%              no_module_tests +%%              src_tests  %%              {variables,[{Name,AbsString}]}  %%              {machine, jam | beam | vee}  %%              exref | {exref, [AppName]} @@ -82,8 +82,7 @@ make_script(RelName, Output, Flags) when is_list(RelName),  	    Path0 = get_path(Flags),  	    Path1 = mk_path(Path0), % expand wildcards etc.  	    Path  = make_set(Path1 ++ code:get_path()), -	    ModTestP = {not member(no_module_tests, Flags), -			xref_p(Flags)}, +	    ModTestP = {member(src_tests, Flags),xref_p(Flags)},  	    case get_release(RelName, Path, ModTestP, machine(Flags)) of  		{ok, Release, Appls, Warnings} ->  		    case generate_script(Output,Release,Appls,Flags) of @@ -155,7 +154,7 @@ return({error,Mod,Error},_,Flags) ->  %% should be included in the release package and there it can be found.  %%  %% New options: {path,Path} can contain wildcards -%%              no_module_tests +%%              src_tests  %%              exref | {exref, [AppName]}  %%              {variables,[{Name,AbsString}]}  %%              {machine, jam | beam | vee} @@ -190,8 +189,7 @@ make_tar(RelName, Flags) when is_list(RelName), is_list(Flags) ->  	    Path0 = get_path(Flags),  	    Path1 = mk_path(Path0),  	    Path  = make_set(Path1 ++ code:get_path()), -	    ModTestP = {not member(no_module_tests, Flags), -			xref_p(Flags)}, +	    ModTestP = {member(src_tests, Flags),xref_p(Flags)},  	    case get_release(RelName, Path, ModTestP, machine(Flags)) of  		{ok, Release, Appls, Warnings} ->  		    case catch mk_tar(RelName, Release, Appls, Flags, Path1) of @@ -218,7 +216,7 @@ make_tar(RelName, Flags) ->  %%     {ok, #release, [{{Name,Vsn},#application}], Warnings} | {error, What}  get_release(File, Path) -> -    get_release(File, Path, true, false). +    get_release(File, Path, {false,false}, false).  get_release(File, Path, ModTestP) ->      get_release(File, Path, ModTestP, false). @@ -771,36 +769,40 @@ get_mod_vsn([]) ->  %% Use the module extension of the running machine as extension for  %% the checked modules. -check_mods(Modules, Appls, Path, {true, XrefP}, Machine) -> -    Ext = objfile_extension(Machine), -    IncPath = create_include_path(Appls, Path), -    Res = append(map(fun(ModT) -> -			     {Mod,_Vsn,App,_,Dir} = ModT, -			     case check_mod(Mod,App,Dir,Ext,IncPath) of -				 ok -> -				     []; -				 {error, Error} -> -				     [{error,{Error, ModT}}]; -				 {warning, Warn} -> -				     [{warning,{Warn,ModT}}] -			     end -		     end, -		     Modules)), -    Res2 = Res ++ check_xref(Appls, Path, XrefP), +check_mods(Modules, Appls, Path, {SrcTestP, XrefP}, Machine) -> +    SrcTestRes = check_src(Modules, Appls, Path, SrcTestP, Machine), +    XrefRes = check_xref(Appls, Path, XrefP), +    Res = SrcTestRes ++ XrefRes,      case filter(fun({error, _}) -> true;  		   (_)          -> false  		end, -		Res2) of +		Res) of  	[] ->  	    {ok, filter(fun({warning, _}) -> true;  			   (_)            -> false  			end, -			Res2)}; +			Res)};  	Errors ->  	    {error, Errors} -    end; -check_mods(_, _, _, _, _) -> -    {ok, []}. +    end. + +check_src(Modules, Appls, Path, true, Machine) -> +    Ext = objfile_extension(Machine), +    IncPath = create_include_path(Appls, Path), +    append(map(fun(ModT) -> +		       {Mod,_Vsn,App,_,Dir} = ModT, +		       case check_mod(Mod,App,Dir,Ext,IncPath) of +			   ok -> +			       []; +			   {error, Error} -> +			       [{error,{Error, ModT}}]; +			   {warning, Warn} -> +			       [{warning,{Warn,ModT}}] +		       end +	       end, +	       Modules)); +check_src(_, _, _, _, _) -> +    [].  check_xref(_Appls, _Path, false) ->      []; @@ -1853,11 +1855,11 @@ cas([silent | Args], {Path, _Sil, Loc, Test, Var, Mach,  cas([local | Args], {Path, Sil, _Loc, Test, Var, Mach,  		     Xref, XrefApps, X}) ->      cas(Args, {Path, Sil, local, Test, Var, Mach, Xref, XrefApps, X}); -%%% no_module_tests ---------------------------------------------------- -cas([no_module_tests | Args], {Path, Sil, Loc, _Test, Var, Mach, -			       Xref, XrefApps, X}) -> +%%% src_tests ------------------------------------------------------- +cas([src_tests | Args], {Path, Sil, Loc, _Test, Var, Mach, +			    Xref, XrefApps, X}) ->      cas(Args, -	{Path, Sil, Loc, no_module_tests, Var, Mach, Xref, XrefApps,X}); +	{Path, Sil, Loc, src_tests, Var, Mach, Xref, XrefApps,X});  %%% variables ----------------------------------------------------------  cas([{variables, V} | Args], {Path, Sil, Loc, Test, Var, Mach,   				 Xref, XrefApps, X}) when is_list(V) -> @@ -1896,6 +1898,10 @@ cas([{outdir, Dir} | Args], {Path, Sil, Loc, Test, Var, Mach,  cas([otp_build | Args], {Path, Sil, Loc, Test, Var, Mach,  			 Xref, XrefApps, X}) ->      cas(Args, {Path, Sil, Loc, Test, Var, Mach, Xref, XrefApps, X}); +%%% no_module_tests (kept for backwards compatibility, but ignored) ---- +cas([no_module_tests | Args], {Path, Sil, Loc, Test, Var, Mach, +			       Xref, XrefApps, X}) -> +    cas(Args, {Path, Sil, Loc, Test, Var, Mach, Xref, XrefApps,X});  %%% ERROR --------------------------------------------------------------  cas([Y | Args], {Path, Sil, Loc, Test, Var, Mach, Xref, XrefApps, X}) ->      cas(Args, {Path, Sil, Loc, Test, Var, Mach, Xref, XrefApps,X++[Y]}). @@ -1935,10 +1941,10 @@ cat([{dirs, D} | Args], {Path, Sil, Dirs, Erts, Test,  cat([{erts, E} | Args], {Path, Sil, Dirs, _Erts, Test,   			 Var, VarTar, Mach, Xref, XrefApps, X}) when is_list(E)->      cat(Args, {Path, Sil, Dirs, E, Test, Var, VarTar, Mach, Xref, XrefApps, X}); -%%% no_module_tests ---------------------------------------------------- -cat([no_module_tests | Args], {Path, Sil, Dirs, Erts, _Test, Var, VarTar, Mach, Xref, XrefApps, X}) -> -    cat(Args, {Path, Sil, Dirs, Erts, no_module_tests, Var, VarTar, Mach,  -		     Xref, XrefApps, X}); +%%% src_tests ---------------------------------------------------- +cat([src_tests | Args], {Path, Sil, Dirs, Erts, _Test, Var, VarTar, Mach, Xref, XrefApps, X}) -> +    cat(Args, {Path, Sil, Dirs, Erts, src_tests, Var, VarTar, Mach,  +	       Xref, XrefApps, X});  %%% variables ----------------------------------------------------------  cat([{variables, V} | Args], {Path, Sil, Dirs, Erts, Test, Var, VarTar, Mach, Xref, XrefApps, X}) when is_list(V) ->      case check_vars(V) of @@ -1982,6 +1988,9 @@ cat([{outdir, Dir} | Args], {Path, Sil, Dirs, Erts, Test, Var, VarTar, Mach, Xre  %%% otp_build (secret, not documented) ---------------------------------  cat([otp_build | Args], {Path, Sil, Dirs, Erts, Test, Var, VarTar, Mach, Xref, XrefApps, X})  ->      cat(Args, {Path, Sil, Dirs, Erts, Test, Var, VarTar, Mach, Xref, XrefApps, X}); +%%% no_module_tests (kept for backwards compatibility, but ignored) ---- +cat([no_module_tests | Args], {Path, Sil, Dirs, Erts, Test, Var, VarTar, Mach, Xref, XrefApps, X}) -> +    cat(Args, {Path, Sil, Dirs, Erts, Test, Var, VarTar, Mach, Xref, XrefApps, X});  %%% ERROR --------------------------------------------------------------  cat([Y | Args], {Path, Sil, Dirs, Erts, Test, Var, VarTar, Mach, Xref, XrefApps, X}) ->      cat(Args, {Path, Sil, Dirs, Erts, Test, Var, VarTar, Mach, Xref, XrefApps, X++[Y]}). diff --git a/lib/sasl/src/systools_relup.erl b/lib/sasl/src/systools_relup.erl index 6b0f77703e..ec5486226c 100644 --- a/lib/sasl/src/systools_relup.erl +++ b/lib/sasl/src/systools_relup.erl @@ -179,8 +179,7 @@ check_opts([]) ->      [].  do_mk_relup(TopRelFile, BaseUpRelDcs, BaseDnRelDcs, Path, Opts) -> -    ModTest = false, -    case systools_make:get_release(to_list(TopRelFile), Path, ModTest) of +    case systools_make:get_release(to_list(TopRelFile), Path) of  	%%  	%% TopRel = #release  	%% NameVsnApps = [{{Name, Vsn}, #application}] @@ -246,9 +245,8 @@ foreach_baserel_up(TopRel, TopApps, [BaseRelDc|BaseRelDcs], Path, Opts,      {RUs4, Ws4} =   	check_for_emulator_restart(TopRel, BaseRel, RUs3, Ws3, Opts), -    ModTest = false,      BaseApps = -	case systools_make:get_release(BaseRelFile, Path, ModTest) of +	case systools_make:get_release(BaseRelFile, Path) of  	    {ok, _, NameVsnApps, _Warns} ->  		lists:map(fun({_,App}) -> App end, NameVsnApps);  	    Other1 -> @@ -283,9 +281,8 @@ foreach_baserel_dn(TopRel, TopApps, [BaseRelDc|BaseRelDcs], Path, Opts,      %%      {RUs1, Ws1} = collect_appup_scripts(dn, TopApps, BaseRel, Ws, []), -    ModTest = false,      {BaseApps, Ws2} = -	case systools_make:get_release(BaseRelFile, Path, ModTest) of +	case systools_make:get_release(BaseRelFile, Path) of  	    %%  	    %% NameVsnApps = [{{Name, Vsn}, #application}]  	    {ok, _, NameVsnApps, Warns} -> | 
