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 + -
显示快捷键?