From 84adefa331c4159d432d22840663c38f155cd4c1 Mon Sep 17 00:00:00 2001 From: Erlang/OTP Date: Fri, 20 Nov 2009 14:54:40 +0000 Subject: The R13B03 release. --- lib/orber/src/orber_ifr_operationdef.erl | 191 +++++++++++++++++++++++++++++++ 1 file changed, 191 insertions(+) create mode 100644 lib/orber/src/orber_ifr_operationdef.erl (limited to 'lib/orber/src/orber_ifr_operationdef.erl') diff --git a/lib/orber/src/orber_ifr_operationdef.erl b/lib/orber/src/orber_ifr_operationdef.erl new file mode 100644 index 0000000000..1d957e17d9 --- /dev/null +++ b/lib/orber/src/orber_ifr_operationdef.erl @@ -0,0 +1,191 @@ +%%-------------------------------------------------------------------- +%% +%% %CopyrightBegin% +%% +%% Copyright Ericsson AB 1997-2009. 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 +%% 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 online 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. +%% +%% %CopyrightEnd% +%% +%% +%%---------------------------------------------------------------------- +%% File : orber_ifr_operationdef.erl +%% Purpose : Code for Operationdef +%%---------------------------------------------------------------------- + +-module(orber_ifr_operationdef). + +-export(['_get_def_kind'/1, + destroy/1, + cleanup_for_destroy/1, %not in CORBA 2.0 + '_get_id'/1, + '_set_id'/2, + '_get_name'/1, + '_set_name'/2, + '_get_version'/1, + '_set_version'/2, + '_get_defined_in'/1, + '_get_absolute_name'/1, + '_get_containing_repository'/1, + describe/1, + move/4, + '_get_result'/1, + '_get_result_def'/1, + '_set_result_def'/2, + '_get_params'/1, + '_set_params'/2, + '_get_mode'/1, + '_set_mode'/2, + '_get_contexts'/1, + '_set_contexts'/2, + '_get_exceptions'/1, + '_set_exceptions'/2 + ]). + +-import(orber_ifr_utils,[get_field/2, + set_field/3, + get_object/1, + set_object/1 + ]). + +-include("orber_ifr.hrl"). +-include("ifr_objects.hrl"). +-include_lib("orber/include/ifr_types.hrl"). +-include_lib("orber/include/corba.hrl"). + +%%%====================================================================== +%%% OperationDef (Contained(IRObject)) + +%%%---------------------------------------------------------------------- +%%% Interfaces inherited from IRObject + +'_get_def_kind'({ObjType, ObjID}) ?tcheck(ir_OperationDef, ObjType) -> + orber_ifr_irobject:'_get_def_kind'({ObjType,ObjID}). + +destroy({ObjType, ObjID}) ?tcheck(ir_OperationDef, ObjType) -> + F = fun() -> ObjList = cleanup_for_destroy({ObjType, ObjID}), + orber_ifr_irobject:destroy([{ObjType,ObjID} | ObjList]) + end, + orber_ifr_utils:ifr_transaction_write(F). + +cleanup_for_destroy({ObjType,ObjID}) ?tcheck(ir_OperationDef, ObjType) -> + lists:map(fun(X) -> Idl = X#parameterdescription.type_def, + orber_ifr_idltype:cleanup_for_destroy(Idl) + end, + '_get_params'({ObjType,ObjID})) ++ + orber_ifr_idltype:cleanup_for_destroy('_get_result_def'({ObjType, + ObjID})) ++ + orber_ifr_contained:cleanup_for_destroy({ObjType,ObjID}). + +%%%---------------------------------------------------------------------- +%%% Interfaces inherited from Contained + +'_get_id'({ObjType, ObjID}) ?tcheck(ir_OperationDef, ObjType) -> + orber_ifr_contained:'_get_id'({ObjType,ObjID}). + +'_set_id'({ObjType, ObjID}, EO_Value) ?tcheck(ir_OperationDef, ObjType) -> + orber_ifr_contained:'_set_id'({ObjType,ObjID},EO_Value). + +'_get_name'({ObjType, ObjID}) ?tcheck(ir_OperationDef, ObjType) -> + orber_ifr_contained:'_get_name'({ObjType,ObjID}). + +'_set_name'({ObjType, ObjID}, EO_Value) ?tcheck(ir_OperationDef, ObjType) -> + orber_ifr_contained:'_set_name'({ObjType,ObjID}, EO_Value). + +'_get_version'({ObjType, ObjID}) ?tcheck(ir_OperationDef, ObjType) -> + orber_ifr_contained:'_get_version'({ObjType,ObjID}). + +'_set_version'({ObjType, ObjID}, EO_Value) ?tcheck(ir_OperationDef, ObjType) -> + orber_ifr_contained:'_set_version'({ObjType,ObjID},EO_Value). + +'_get_defined_in'({ObjType, ObjID}) ?tcheck(ir_OperationDef, ObjType) -> + orber_ifr_contained:'_get_defined_in'({ObjType,ObjID}). + +'_get_absolute_name'({ObjType, ObjID}) ?tcheck(ir_OperationDef, ObjType) -> + orber_ifr_contained:'_get_absolute_name'({ObjType,ObjID}). + +'_get_containing_repository'({ObjType, ObjID}) ?tcheck(ir_OperationDef, ObjType) -> + orber_ifr_contained:'_get_containing_repository'({ObjType,ObjID}). + +describe({ObjType, ObjID}) ?tcheck(ir_OperationDef, ObjType) -> + orber_ifr_contained:describe({ObjType,ObjID}). + +move({ObjType, ObjID}, New_container, New_name, New_version) + ?tcheck(ir_OperationDef, ObjType) -> + orber_ifr_contained:move({ObjType,ObjID},New_container,New_name,New_version). + +%%%---------------------------------------------------------------------- +%%% Non-inherited interfaces + +'_get_result'({ObjType, ObjID}) + ?tcheck(ir_OperationDef, ObjType) -> + get_field({ObjType,ObjID},result). + +'_get_result_def'({ObjType, ObjID}) + ?tcheck(ir_OperationDef, ObjType) -> + get_field({ObjType,ObjID},result_def). + +'_set_result_def'({ObjType, ObjID}, EO_Value) + ?tcheck(ir_OperationDef, ObjType) -> + OperationDef = get_object({ObjType, ObjID}), + New_OperationDef = + OperationDef#ir_OperationDef{result = EO_Value#ir_IDLType.type, + result_def = EO_Value}, + set_object(New_OperationDef). + +'_get_params'({ObjType,ObjID}) ?tcheck(ir_OperationDef,ObjType) -> + get_field({ObjType,ObjID},params). + +'_set_params'({ObjType, ObjID}, EO_Value) + ?tcheck(ir_OperationDef, ObjType) -> + set_field({ObjType,ObjID}, params, EO_Value). + +'_get_mode'({ObjType, ObjID}) ?tcheck(ir_OperationDef, ObjType) -> + get_field({ObjType,ObjID},mode). + +'_set_mode'({ObjType, ObjID}, EO_Value) ?tcheck(ir_OperationDef, ObjType) -> + OperationDef = get_object({ObjType, ObjID}), + Set_OK = case EO_Value of + 'OP_ONEWAY' -> + (OperationDef#ir_OperationDef.result == tk_void) + and + lists:foldl(fun(#parameterdescription{mode=Mode},AccIn) -> + (Mode == 'PARAM_IN') and AccIn + end, + true,OperationDef#ir_OperationDef.params); + _ -> + true + end, + set_mode(Set_OK,{ObjType,ObjID},EO_Value). + +set_mode(true,Objref,EO_Value) -> + set_field(Objref,mode,EO_Value); +set_mode(false, Objref, EO_Value) -> + orber:dbg("[~p] ~p:destroy(~p, ~p);~n" + "Illegal '_set_mode'.~n", + [?LINE, ?MODULE, Objref, EO_Value], ?DEBUG_LEVEL), + corba:raise(#'INTF_REPOS'{completion_status=?COMPLETED_NO}). + +'_get_contexts'({ObjType, ObjID}) ?tcheck(ir_OperationDef, ObjType) -> + get_field({ObjType,ObjID},contexts). + +'_set_contexts'({ObjType, ObjID}, EO_Value) + ?tcheck(ir_OperationDef, ObjType) -> + set_field({ObjType,ObjID}, contexts, EO_Value). + +'_get_exceptions'({ObjType, ObjID}) ?tcheck(ir_OperationDef, ObjType) -> + get_field({ObjType,ObjID},exceptions). + +'_set_exceptions'({ObjType, ObjID}, EO_Value) + ?tcheck(ir_OperationDef, ObjType) -> + set_field({ObjType,ObjID}, exceptions, EO_Value). -- cgit v1.2.3