1%%--------------------------------------------------------------------
2%%
3%% %CopyrightBegin%
4%%
5%% Copyright Ericsson AB 1997-2016. All Rights Reserved.
6%%
7%% Licensed under the Apache License, Version 2.0 (the "License");
8%% you may not use this file except in compliance with the License.
9%% You may obtain a copy of the License at
10%%
11%%     http://www.apache.org/licenses/LICENSE-2.0
12%%
13%% Unless required by applicable law or agreed to in writing, software
14%% distributed under the License is distributed on an "AS IS" BASIS,
15%% WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16%% See the License for the specific language governing permissions and
17%% limitations under the License.
18%%
19%% %CopyrightEnd%
20%%
21%%
22%%----------------------------------------------------------------------
23%% File    : orber_ifr_constantdef.erl
24%% Purpose : Code for Constantdef
25%%----------------------------------------------------------------------
26
27-module(orber_ifr_constantdef).
28
29-export(['_get_def_kind'/1,
30	 destroy/1,
31	 cleanup_for_destroy/1,			%not in CORBA 2.0
32	 '_get_id'/1,
33	 '_set_id'/2,
34	 '_get_name'/1,
35	 '_set_name'/2,
36	 '_get_version'/1,
37	 '_set_version'/2,
38	 '_get_defined_in'/1,
39	 '_get_absolute_name'/1,
40	 '_get_containing_repository'/1,
41	 describe/1,
42	 move/4,
43	 '_get_type'/1,
44	 '_get_type_def'/1,
45	 '_set_type_def'/2,
46	 '_get_value'/1,
47	 '_set_value'/2
48	]).
49
50-import(orber_ifr_utils,[get_field/2,
51		   set_field/3,
52		   get_object/1,
53		   set_object/1
54		  ]).
55
56-include_lib("orber/include/corba.hrl").
57-include("orber_ifr.hrl").
58-include("ifr_objects.hrl").
59
60%%%======================================================================
61%%% ConstantDef (Contained(IRObject))
62
63%%%----------------------------------------------------------------------
64%%% Interfaces inherited from IRObject
65
66'_get_def_kind'({ObjType,ObjID}) ?tcheck(ir_ConstantDef,ObjType) ->
67    orber_ifr_irobject:'_get_def_kind'({ObjType, ObjID}).
68
69destroy({ObjType, ObjID}) ?tcheck(ir_ConstantDef, ObjType) ->
70    F = fun() -> ObjList = cleanup_for_destroy({ObjType,ObjID}),
71		 orber_ifr_irobject:destroy([{ObjType,ObjID} | ObjList])
72	end,
73    orber_ifr_utils:ifr_transaction_write(F).
74
75cleanup_for_destroy({ObjType,ObjID}) ?tcheck(ir_ConstantDef, ObjType) ->
76    orber_ifr_idltype:cleanup_for_destroy(
77      '_get_type_def'({ObjType,ObjID})) ++
78	orber_ifr_contained:cleanup_for_destroy({ObjType,ObjID}).
79
80%%%----------------------------------------------------------------------
81%%% Interfaces inherited from Contained
82
83'_get_id'({ObjType, ObjID}) ?tcheck(ir_ConstantDef, ObjType) ->
84    orber_ifr_contained:'_get_id'({ObjType,ObjID}).
85
86'_set_id'({ObjType, ObjID}, EO_Value) ?tcheck(ir_ConstantDef, ObjType) ->
87    orber_ifr_contained:'_set_id'({ObjType,ObjID},EO_Value).
88
89'_get_name'({ObjType, ObjID}) ?tcheck(ir_ConstantDef, ObjType) ->
90    orber_ifr_contained:'_get_name'({ObjType,ObjID}).
91
92'_set_name'({ObjType, ObjID}, EO_Value) ?tcheck(ir_ConstantDef, ObjType) ->
93    orber_ifr_contained:'_set_name'({ObjType,ObjID}, EO_Value).
94
95'_get_version'({ObjType, ObjID}) ?tcheck(ir_ConstantDef,ObjType) ->
96    orber_ifr_contained:'_get_version'({ObjType,ObjID}).
97
98'_set_version'({ObjType, ObjID}, EO_Value) ?tcheck(ir_ConstantDef, ObjType) ->
99    orber_ifr_contained:'_set_version'({ObjType,ObjID},EO_Value).
100
101'_get_defined_in'({ObjType, ObjID}) ?tcheck(ir_ConstantDef, ObjType) ->
102    orber_ifr_contained:'_get_defined_in'({ObjType,ObjID}).
103
104'_get_absolute_name'({ObjType, ObjID}) ?tcheck(ir_ConstantDef, ObjType) ->
105    orber_ifr_contained:'_get_absolute_name'({ObjType,ObjID}).
106
107'_get_containing_repository'({ObjType, ObjID})
108			    ?tcheck(ir_ConstantDef, ObjType) ->
109    orber_ifr_contained:'_get_containing_repository'({ObjType,ObjID}).
110
111describe({ObjType, ObjID}) ?tcheck(ir_ConstantDef, ObjType) ->
112    orber_ifr_contained:describe({ObjType,ObjID}).
113						%
114move({ObjType, ObjID}, New_container, New_name, New_version)
115    ?tcheck(ir_ConstantDef, ObjType) ->
116    orber_ifr_contained:move({ObjType,ObjID},New_container,New_name,
117			     New_version).
118
119%%%----------------------------------------------------------------------
120%%% Non-inherited interfaces
121
122'_get_type'({ObjType, ObjID}) ?tcheck(ir_ConstantDef, ObjType) ->
123    get_field({ObjType,ObjID},type).
124
125'_get_type_def'({ObjType,ObjID}) ?tcheck(ir_ConstantDef,ObjType) ->
126    get_field({ObjType,ObjID},type_def).
127
128'_set_type_def'({ObjType, ObjID}, EO_Value) ?tcheck(ir_ConstantDef, ObjType) ->
129    ConstantDef = get_object({ObjType, ObjID}),
130    New_ConstantDef = ConstantDef#ir_ConstantDef{type=EO_Value#ir_IDLType.type,
131						 type_def = EO_Value},
132    set_object(New_ConstantDef).
133
134'_get_value'({ObjType, ObjID}) ?tcheck(ir_ConstantDef, ObjType) ->
135    get_field({ObjType,ObjID},value).
136
137'_set_value'({ObjType, ObjID}, EO_Value) ?tcheck(ir_ConstantDef, ObjType) ->
138    Typecode = get_field({ObjType,ObjID},type),
139    {Value_typecode, _} = EO_Value,
140    case Value_typecode == Typecode of
141	true ->
142	    set_field({ObjType, ObjID}, value, EO_Value);
143	false ->
144	    orber:dbg("[~p] ~p:destroy(~p, ~p, ~p);~n"
145		      "Wrong typecode in set_value.~n",
146		      [?LINE, ?MODULE, ObjType, ObjID, EO_Value], ?DEBUG_LEVEL),
147	    corba:raise(#'INTF_REPOS'{completion_status=?COMPLETED_NO})
148    end.
149