error_handler.erl

来自「OTP是开放电信平台的简称」· ERL 代码 · 共 97 行

ERL
97
字号
%% ``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%% compliance with the License. You should have received a copy of the%% Erlang Public License along with this software. If not, it can be%% retrieved via the world wide web at http://www.erlang.org/.%% %% Software distributed under the License is distributed on an "AS IS"%% basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See%% the License for the specific language governing rights and limitations%% under the License.%% %% The Initial Developer of the Original Code is Ericsson Utvecklings AB.%% Portions created by Ericsson are Copyright 1999, Ericsson Utvecklings%% AB. All Rights Reserved.''%% %%     $Id$%%-module(error_handler).%% A simple error handler.-export([undefined_function/3, undefined_lambda/3, stub_function/3,	 breakpoint/3]).undefined_function(Module, Func, Args) ->    case ensure_loaded(Module) of	{module, Module} ->	    case erlang:function_exported(Module, Func, length(Args)) of		true ->		    apply(Module, Func, Args);		false ->		    crash(Module, Func, Args)	    end;	{module, _} ->	    crash(Module, Func, Args);	_Other ->	    crash(Module, Func, Args)    end.undefined_lambda(Module, Fun, Args) ->    case ensure_loaded(Module) of	{module, Module} ->	    %% There is no need (and no way) to test if the fun is present.	    %% apply/2 will not call us again if the fun is missing.	    apply(Fun, Args);	{module, _} ->	    crash(Fun, Args);	_Other ->	    crash(Fun, Args)    end.breakpoint(Module, Func, Args) ->    (int()):eval(Module, Func, Args).%% Used to make the call to the 'int' module a "weak" one, to avoid%% building strong components in xref or dialyzer.int() -> int.    %%%% Crash providing a beautiful stack backtrace.%%crash(Fun, Args) ->    crash({Fun,Args}).crash(M, F, A) ->    crash({M,F,A}).crash(MFA) ->    try erlang:error(undef)    catch	error:undef ->	    erlang:raise(error, undef, [MFA|tl(erlang:get_stacktrace())])    end.%% If the code_server has not been started yet dynamic code loading%% is handled by init.ensure_loaded(Module) ->    Self = self(),    case whereis(code_server) of	%% Perhaps double fault should be detected in code:ensure_loaded/1 	%% instead, since this error handler cannot know whether the 	%% code server can resolve the problem or not.	%% An {error, Reason} return from there would crash the code server and 	%% bring down the node.	Self ->	    Error = "The code server called the unloaded module `" ++		atom_to_list(Module) ++ "'",	    halt(Error);	Pid when is_pid(Pid) ->	    code:ensure_loaded(Module);	_ ->	    init:ensure_loaded(Module)    end.stub_function(Mod, Func, Args) ->    exit({undef,[{Mod,Func,Args}]}).

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?