etrap_common.erl
来自「OTP是开放电信平台的简称」· ERL 代码 · 共 186 行
ERL
186 行
%%--------------------------------------------------------------------%% ``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$%%%%----------------------------------------------------------------------%% File : ETraP_Common.erl%% Author : Nicklas Eklund <nick@gwaihir>%% Purpose : %% Created : 14 Oct 1998 by Nicklas Eklund <nick@gwaihir>%%-----------------------------------------------------------------------module('ETraP_Common').%%--------------- INCLUDES -----------------------------------include_lib("orber/include/corba.hrl").-include_lib("orber/include/ifr_types.hrl").%% Local-include_lib("ETraP_Common.hrl").-include_lib("CosTransactions.hrl").%%--------------- EXPORTS ------------------------------------export([try_timeout/1, get_option/3, create_name/2, create_name/1, is_debug_compiled/0, send_stubborn/5, create_link/3]).%%--------------- DEFINITIONS OF CONSTANTS ------------------%%------------------------------------------------------------%% function : create_link%% Arguments: Module - which Module to call%% Env/ARgList - ordinary oe_create arguments.%% Returns : %% Exception: %% Effect : Necessary since we want the supervisor to be a %% 'simple_one_for_one'. Otherwise, using for example,%% 'one_for_one', we have to call supervisor:delete_child%% to remove the childs startspecification from the %% supervisors internal state.%%------------------------------------------------------------create_link(Module, Env, ArgList) -> Module:oe_create_link(Env, ArgList).%%------------------------------------------------------------%% function : get_option%% Arguments: %% Returns : %% Exception: %% Effect : %%------------------------------------------------------------get_option(Key, OptionList, DefaultList) -> case lists:keysearch(Key, 1, OptionList) of {value,{Key,Value}} -> Value; _ -> case lists:keysearch(Key, 1, DefaultList) of {value,{Key,Value}} -> Value; _-> {error, "Invalid option"} end end.%%------------------------------------------------------------%% function : create_name/2%% Arguments: %% Returns : %% Exception: %% Effect : %%------------------------------------------------------------ create_name(Name,Type) -> {MSec, Sec, USec} = erlang:now(), lists:concat(['oe_',node(),'_',Type,'_',Name,'_',MSec, '_', Sec, '_', USec]). %%------------------------------------------------------------%% function : create_name/1%% Arguments: %% Returns : %% Exception: %% Effect : %%------------------------------------------------------------ create_name(Type) -> {MSec, Sec, USec} = erlang:now(), lists:concat(['oe_',node(),'_',Type,'_',MSec, '_', Sec, '_', USec]).%%------------------------------------------------------------%% function : try_timeout%% Arguments: Id - name of the timeoutSrv server.%% Returns : Boolean%% Exception: %% Effect : %%------------------------------------------------------------try_timeout(TimeoutAt) -> case TimeoutAt of infinity -> false; _-> {MegaSecs, Secs, _Microsecs} = erlang:now(), Time = MegaSecs*1000000+Secs, if Time < TimeoutAt -> false; true -> true end end.%%------------------------------------------------------------%% function : send_stubborn%% Arguments: M - module%% F - function%% A - arguments%% MaxR - Maximum no retries%% Wait - sleep Wait seconds before next try.%% Returns : see effect%% Exception: %% Effect : Retries repeatedly until anything else besides%% 'EXIT', 'COMM_FAILURE' or 'OBJECT_NOT_EXIST'%%------------------------------------------------------------send_stubborn(M, F, A, MaxR, Wait) when list(A) -> send_stubborn(M, F, A, MaxR, Wait, 0);send_stubborn(M, F, A, MaxR, Wait) -> send_stubborn(M, F, [A], MaxR, Wait, 0).send_stubborn(M, F, A, MaxR, _Wait, MaxR) -> ?tr_error_msg("~p:~p( ~p ) failed!! Tried ~p times.~n", [M,F,A,MaxR]), corba:raise(#'INTERNAL'{completion_status=?COMPLETED_NO});send_stubborn(M, F, A, MaxR, Wait, Times) -> ?debug_print("~p:~p(~p) # of retries: ~p~n", [M,F,A, Times]), case catch apply(M,F,A) of {'EXCEPTION', E} when record(E, 'COMM_FAILURE')-> NewTimes = Times +1, timer:sleep(Wait), send_stubborn(M, F, A, MaxR, Wait, NewTimes); {'EXCEPTION', E} when record(E, 'TRANSIENT')-> NewTimes = Times +1, timer:sleep(Wait), send_stubborn(M, F, A, MaxR, Wait, NewTimes); {'EXCEPTION', E} when record(E, 'TIMEOUT')-> NewTimes = Times +1, timer:sleep(Wait), send_stubborn(M, F, A, MaxR, Wait, NewTimes); {'EXIT', _} -> NewTimes = Times +1, timer:sleep(Wait), send_stubborn(M, F, A, MaxR, Wait, NewTimes); Other -> ?debug_print("~p:~p(~p) Resulted in: ~p~n", [M,F,A, Other]), Other end.%%------------------------------------------------------------%% function : is_debug_compiled%% Arguments: %% Returns : %% Exception: %% Effect : %%-------------------------------------------------------------ifdef(debug). is_debug_compiled() -> true.-else. is_debug_compiled() -> false.-endif.%%--------------- END OF MODULE ------------------------------
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?