aboutsummaryrefslogblamecommitdiffstats
path: root/lib/orber/src/orber_ifr_operationdef.erl
blob: 1d957e17d9aa0533fcf639a48f5e9f1089da9227 (plain) (tree)






























































































































































































                                                                                   
%%--------------------------------------------------------------------
%%
%% %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).