xref: /aoo4110/main/cppu/inc/uno/sequence2.h (revision b1cdbd2c)
1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski #ifndef _UNO_SEQUENCE2_H_
24*b1cdbd2cSJim Jagielski #define _UNO_SEQUENCE2_H_
25*b1cdbd2cSJim Jagielski 
26*b1cdbd2cSJim Jagielski #include <sal/types.h>
27*b1cdbd2cSJim Jagielski #include <uno/data.h>
28*b1cdbd2cSJim Jagielski 
29*b1cdbd2cSJim Jagielski #ifdef __cplusplus
30*b1cdbd2cSJim Jagielski extern "C"
31*b1cdbd2cSJim Jagielski {
32*b1cdbd2cSJim Jagielski #endif
33*b1cdbd2cSJim Jagielski 
34*b1cdbd2cSJim Jagielski struct _typelib_TypeDescriptionReference;
35*b1cdbd2cSJim Jagielski struct _typelib_TypeDescription;
36*b1cdbd2cSJim Jagielski typedef sal_Sequence uno_Sequence;
37*b1cdbd2cSJim Jagielski 
38*b1cdbd2cSJim Jagielski /** Assigns a sequence.
39*b1cdbd2cSJim Jagielski 
40*b1cdbd2cSJim Jagielski 	@param ppDest		destinstaion sequence
41*b1cdbd2cSJim Jagielski 	@param pSource		source sequence
42*b1cdbd2cSJim Jagielski 	@param pTypeDescr	type description of the sequence and NOT of an element
43*b1cdbd2cSJim Jagielski 	@param release		function called each time an interface needs to
44*b1cdbd2cSJim Jagielski                         be released; defaults (0) to uno
45*b1cdbd2cSJim Jagielski */
46*b1cdbd2cSJim Jagielski void SAL_CALL uno_sequence_assign(
47*b1cdbd2cSJim Jagielski 	uno_Sequence ** ppDest,
48*b1cdbd2cSJim Jagielski 	uno_Sequence * pSource,
49*b1cdbd2cSJim Jagielski 	struct _typelib_TypeDescription * pTypeDescr,
50*b1cdbd2cSJim Jagielski 	uno_ReleaseFunc release )
51*b1cdbd2cSJim Jagielski 	SAL_THROW_EXTERN_C();
52*b1cdbd2cSJim Jagielski /** Assigns a sequence.
53*b1cdbd2cSJim Jagielski 
54*b1cdbd2cSJim Jagielski 	@param ppDest		destinstaion sequence
55*b1cdbd2cSJim Jagielski 	@param pSource		source sequence
56*b1cdbd2cSJim Jagielski 	@param pType		type of the sequence and NOT of an element
57*b1cdbd2cSJim Jagielski 	@param release		function called each time an interface needs to
58*b1cdbd2cSJim Jagielski                         be released; defaults (0) to uno
59*b1cdbd2cSJim Jagielski */
60*b1cdbd2cSJim Jagielski void SAL_CALL uno_type_sequence_assign(
61*b1cdbd2cSJim Jagielski 	uno_Sequence ** ppDest,
62*b1cdbd2cSJim Jagielski 	uno_Sequence * pSource,
63*b1cdbd2cSJim Jagielski 	struct _typelib_TypeDescriptionReference * pType,
64*b1cdbd2cSJim Jagielski 	uno_ReleaseFunc release )
65*b1cdbd2cSJim Jagielski 	SAL_THROW_EXTERN_C();
66*b1cdbd2cSJim Jagielski 
67*b1cdbd2cSJim Jagielski /** Constructs a new sequence with given elements.
68*b1cdbd2cSJim Jagielski 
69*b1cdbd2cSJim Jagielski 	@param ppSequence		  out parameter sequence;
70*b1cdbd2cSJim Jagielski                               0 if memory allocation has failed
71*b1cdbd2cSJim Jagielski 	@param pTypeDescr		  type description of the sequence and NOT of an
72*b1cdbd2cSJim Jagielski                               element
73*b1cdbd2cSJim Jagielski 	@param pElements		  if 0, then all elements are default constructed
74*b1cdbd2cSJim Jagielski 	@param len				  number of elements
75*b1cdbd2cSJim Jagielski 	@param acquire			  function called each time an interface needs to
76*b1cdbd2cSJim Jagielski                               be acquired; defaults (0) to uno
77*b1cdbd2cSJim Jagielski     @return                   false, if memoray allocation has failed
78*b1cdbd2cSJim Jagielski */
79*b1cdbd2cSJim Jagielski sal_Bool SAL_CALL uno_sequence_construct(
80*b1cdbd2cSJim Jagielski 	uno_Sequence ** ppSequence,
81*b1cdbd2cSJim Jagielski 	struct _typelib_TypeDescription * pTypeDescr,
82*b1cdbd2cSJim Jagielski 	void * pElements, sal_Int32 len,
83*b1cdbd2cSJim Jagielski 	uno_AcquireFunc acquire )
84*b1cdbd2cSJim Jagielski 	SAL_THROW_EXTERN_C();
85*b1cdbd2cSJim Jagielski /** Constructs a new sequence with given elements.
86*b1cdbd2cSJim Jagielski 
87*b1cdbd2cSJim Jagielski 	@param ppSequence		  out parameter sequence;
88*b1cdbd2cSJim Jagielski                               0 if memory allocation has failed
89*b1cdbd2cSJim Jagielski 	@param pType			  type of the sequence and NOT of an element
90*b1cdbd2cSJim Jagielski 	@param pElements		  if 0, then all elements are default constructed
91*b1cdbd2cSJim Jagielski 	@param len				  number of elements
92*b1cdbd2cSJim Jagielski 	@param acquire			  function called each time an interface needs to
93*b1cdbd2cSJim Jagielski                               be acquired; defaults (0) to uno
94*b1cdbd2cSJim Jagielski     @return                   false, if memoray allocation has failed
95*b1cdbd2cSJim Jagielski */
96*b1cdbd2cSJim Jagielski sal_Bool SAL_CALL uno_type_sequence_construct(
97*b1cdbd2cSJim Jagielski 	uno_Sequence ** ppSequence,
98*b1cdbd2cSJim Jagielski 	struct _typelib_TypeDescriptionReference * pType,
99*b1cdbd2cSJim Jagielski 	void * pElements, sal_Int32 len,
100*b1cdbd2cSJim Jagielski 	uno_AcquireFunc acquire )
101*b1cdbd2cSJim Jagielski 	SAL_THROW_EXTERN_C();
102*b1cdbd2cSJim Jagielski 
103*b1cdbd2cSJim Jagielski /** Assures that the reference count of the given sequence is one.
104*b1cdbd2cSJim Jagielski     Otherwise a new copy of the sequence is created with a reference count
105*b1cdbd2cSJim Jagielski     of one.
106*b1cdbd2cSJim Jagielski 
107*b1cdbd2cSJim Jagielski 	@param ppSequence		inout sequence
108*b1cdbd2cSJim Jagielski 	@param pTypeDescr		type description of sequence
109*b1cdbd2cSJim Jagielski 	@param acquire			function called each time an interface needs to
110*b1cdbd2cSJim Jagielski                             be acquired; defaults (0) to uno
111*b1cdbd2cSJim Jagielski 	@param release			function called each time an interface needs to
112*b1cdbd2cSJim Jagielski                             be released; defaults (0) to uno
113*b1cdbd2cSJim Jagielski     @return                 false, if memoray allocation has failed
114*b1cdbd2cSJim Jagielski */
115*b1cdbd2cSJim Jagielski sal_Bool SAL_CALL uno_sequence_reference2One(
116*b1cdbd2cSJim Jagielski 	uno_Sequence ** ppSequence,
117*b1cdbd2cSJim Jagielski 	struct _typelib_TypeDescription * pTypeDescr,
118*b1cdbd2cSJim Jagielski 	uno_AcquireFunc acquire,
119*b1cdbd2cSJim Jagielski 	uno_ReleaseFunc release )
120*b1cdbd2cSJim Jagielski 	SAL_THROW_EXTERN_C();
121*b1cdbd2cSJim Jagielski /** Assures that the reference count of the given sequence is one.
122*b1cdbd2cSJim Jagielski     Otherwise a new copy of the sequence is created with a reference count
123*b1cdbd2cSJim Jagielski     of one.
124*b1cdbd2cSJim Jagielski 
125*b1cdbd2cSJim Jagielski 	@param ppSequence		inout sequence
126*b1cdbd2cSJim Jagielski 	@param pType			type of sequence
127*b1cdbd2cSJim Jagielski 	@param acquire			function called each time an interface needs to
128*b1cdbd2cSJim Jagielski                             be acquired; defaults (0) to uno
129*b1cdbd2cSJim Jagielski 	@param release			function called each time an interface needs to
130*b1cdbd2cSJim Jagielski                             be released; defaults (0) to uno
131*b1cdbd2cSJim Jagielski     @return                 false, if memoray allocation has failed
132*b1cdbd2cSJim Jagielski */
133*b1cdbd2cSJim Jagielski sal_Bool SAL_CALL uno_type_sequence_reference2One(
134*b1cdbd2cSJim Jagielski 	uno_Sequence ** ppSequence,
135*b1cdbd2cSJim Jagielski 	struct _typelib_TypeDescriptionReference * pType,
136*b1cdbd2cSJim Jagielski 	uno_AcquireFunc acquire,
137*b1cdbd2cSJim Jagielski 	uno_ReleaseFunc release )
138*b1cdbd2cSJim Jagielski 	SAL_THROW_EXTERN_C();
139*b1cdbd2cSJim Jagielski 
140*b1cdbd2cSJim Jagielski /** Reallocates length of a sequence. This truncates a sequence or enlarges
141*b1cdbd2cSJim Jagielski     it default constructing appended elements.
142*b1cdbd2cSJim Jagielski 
143*b1cdbd2cSJim Jagielski 	@param ppSequence		inout sequence
144*b1cdbd2cSJim Jagielski 	@param pTypeDescr		type description of sequence
145*b1cdbd2cSJim Jagielski 	@param nSize			new size of sequence
146*b1cdbd2cSJim Jagielski 	@param acquire			function called each time an interface needs to
147*b1cdbd2cSJim Jagielski                             be acquired; defaults (0) to uno
148*b1cdbd2cSJim Jagielski 	@param release			function called each time an interface needs to
149*b1cdbd2cSJim Jagielski                             be released; defaults (0) to uno
150*b1cdbd2cSJim Jagielski     @return                 false, if memoray allocation has failed
151*b1cdbd2cSJim Jagielski */
152*b1cdbd2cSJim Jagielski sal_Bool SAL_CALL uno_sequence_realloc(
153*b1cdbd2cSJim Jagielski 	uno_Sequence ** ppSequence,
154*b1cdbd2cSJim Jagielski 	struct _typelib_TypeDescription * pTypeDescr,
155*b1cdbd2cSJim Jagielski 	sal_Int32 nSize,
156*b1cdbd2cSJim Jagielski 	uno_AcquireFunc acquire,
157*b1cdbd2cSJim Jagielski 	uno_ReleaseFunc release )
158*b1cdbd2cSJim Jagielski 	SAL_THROW_EXTERN_C();
159*b1cdbd2cSJim Jagielski /** Reallocates length of a sequence. This truncates a sequence or enlarges
160*b1cdbd2cSJim Jagielski     it default constructing appended elements.
161*b1cdbd2cSJim Jagielski 
162*b1cdbd2cSJim Jagielski 	@param ppSequence		inout sequence
163*b1cdbd2cSJim Jagielski 	@param pType			type of sequence
164*b1cdbd2cSJim Jagielski 	@param nSize			new size of sequence
165*b1cdbd2cSJim Jagielski 	@param acquire			function called each time an interface needs to
166*b1cdbd2cSJim Jagielski                             be acquired; defaults (0) to uno
167*b1cdbd2cSJim Jagielski 	@param release			function called each time an interface needs to
168*b1cdbd2cSJim Jagielski                             be released; defaults (0) to uno
169*b1cdbd2cSJim Jagielski     @return                 false, if memoray allocation has failed
170*b1cdbd2cSJim Jagielski */
171*b1cdbd2cSJim Jagielski sal_Bool SAL_CALL uno_type_sequence_realloc(
172*b1cdbd2cSJim Jagielski 	uno_Sequence ** ppSequence,
173*b1cdbd2cSJim Jagielski 	struct _typelib_TypeDescriptionReference * pType,
174*b1cdbd2cSJim Jagielski 	sal_Int32 nSize,
175*b1cdbd2cSJim Jagielski 	uno_AcquireFunc acquire,
176*b1cdbd2cSJim Jagielski 	uno_ReleaseFunc release )
177*b1cdbd2cSJim Jagielski 	SAL_THROW_EXTERN_C();
178*b1cdbd2cSJim Jagielski 
179*b1cdbd2cSJim Jagielski #ifdef __cplusplus
180*b1cdbd2cSJim Jagielski }
181*b1cdbd2cSJim Jagielski #endif
182*b1cdbd2cSJim Jagielski 
183*b1cdbd2cSJim Jagielski #endif
184