Sync to trunk head(r38096)
[reactos.git] / rostests / winetests / rpcrt4 / server.idl
1 /*
2 * A simple interface to test the RPC server.
3 *
4 * Copyright (C) Google 2007 (Dan Hipschman)
5 *
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version.
10 *
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
15 *
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
19 */
20
21 #include "server_defines.h"
22
23 typedef struct tag_vector
24 {
25 int x;
26 int y;
27 int z;
28 } vector_t;
29
30 [
31 uuid(00000000-4114-0704-2301-000000000000),
32 #ifndef __midl
33 implicit_handle(handle_t IServer_IfHandle)
34 #endif
35 ]
36 interface IServer
37 {
38 cpp_quote("#if 0")
39 typedef wchar_t WCHAR;
40 cpp_quote("#endif")
41
42 typedef [string] char *str_t;
43 typedef [string] WCHAR *wstr_t;
44
45 typedef struct
46 {
47 int *pi;
48 int **ppi;
49 int ***pppi;
50 } pints_t;
51
52 typedef struct
53 {
54 char *pc;
55 short *ps;
56 long *pl;
57 float *pf;
58 double *pd;
59 } ptypes_t;
60
61 typedef struct
62 {
63 vector_t *pu;
64 vector_t **pv;
65 } pvectors_t;
66
67 typedef struct
68 {
69 [switch_is(s)] union
70 {
71 [case(SUN_I)] int i;
72 [case(SUN_F1, SUN_F2)] float f;
73 [case(SUN_PI)] int *pi;
74 } u;
75
76 int s;
77 } sun_t;
78
79 int int_return(void);
80 int square(int x);
81 int sum(int x, int y);
82 void square_out(int x, [out] int *y);
83 void square_ref([in, out] int *x);
84 int str_length([string] const char *s);
85 int str_t_length(str_t s);
86 int cstr_length([string, size_is(n)] const char *s, int n);
87 int dot_self(vector_t *v);
88 double square_half(double x, [out] double *y);
89 float square_half_float(float x, [out] float *y);
90 long square_half_long(long x, [out] long *y);
91 int sum_fixed_array(int a[5]);
92 int pints_sum(pints_t *pints);
93 double ptypes_sum(ptypes_t *ptypes);
94 int dot_pvectors(pvectors_t *pvectors);
95
96 /* don't use this anywhere except in sp_t */
97 typedef struct
98 {
99 int x;
100 } sp_inner_t;
101
102 typedef struct
103 {
104 int x;
105 sp_inner_t *s;
106 } sp_t;
107
108 int sum_sp(sp_t *sp);
109 double square_sun(sun_t *su);
110
111 typedef struct test_list
112 {
113 int t;
114 [switch_is(t)] union
115 {
116 [case(TL_NULL)] char x; /* end of list */
117 [case(TL_LIST)] struct test_list *tail;
118 } u;
119 } test_list_t;
120
121 int test_list_length(test_list_t *ls);
122 int sum_fixed_int_3d(int m[2][3][4]);
123 int sum_conf_array([size_is(n)] int x[], int n);
124 int sum_unique_conf_array([size_is(n), unique] int x[], int n);
125 int sum_unique_conf_ptr([size_is(n), unique] int *x, int n);
126 int sum_var_array([length_is(n)] int x[20], int n);
127 int dot_two_vectors(vector_t vs[2]);
128
129 typedef struct
130 {
131 int n;
132 [size_is(n)] int ca[];
133 } cs_t;
134
135 typedef struct
136 {
137 int *pn;
138 [size_is(*pn)] int *ca1;
139 [size_is(n * 2)] int *ca2;
140 int n;
141 } cps_t;
142
143 typedef struct
144 {
145 [size_is(c ? a : b)] int *ca;
146 int a;
147 int b;
148 int c;
149 } cpsc_t;
150
151 int sum_cs(cs_t *cs);
152 int sum_cps(cps_t *cps);
153 int sum_cpsc(cpsc_t *cpsc);
154
155 typedef [wire_marshal(int)] void *puint_t;
156 int square_puint(puint_t p);
157
158 typedef struct
159 {
160 [size_is(n)] puint_t *ps;
161 int n;
162 } puints_t;
163
164 /* Same thing as puints_t, but make it complex (needs padding). */
165 typedef struct
166 {
167 [size_is(n)] puint_t *ps;
168 char n;
169 } cpuints_t;
170
171 int sum_puints(puints_t *p);
172 int sum_cpuints(cpuints_t *p);
173 int dot_copy_vectors(vector_t u, vector_t v);
174
175 typedef struct wire_us *wire_us_t;
176 typedef [wire_marshal(wire_us_t)] struct us us_t;
177 struct us
178 {
179 void *x;
180 };
181 struct wire_us
182 {
183 int x;
184 };
185 typedef struct
186 {
187 us_t us;
188 } test_us_t;
189
190 int square_test_us(test_us_t *tus);
191
192 typedef union encu switch (int t)
193 {
194 case ENCU_I: int i;
195 case ENCU_F: float f;
196 } encu_t;
197
198 typedef enum
199 {
200 E1 = 23,
201 E2 = 4,
202 E3 = 0,
203 E4 = 64
204 } e_t;
205
206 typedef union encue switch (e_t t)
207 {
208 case E1: int i1;
209 case E2: float f2;
210 } encue_t;
211
212 typedef struct
213 {
214 e_t f;
215 } se_t;
216
217 double square_encu(encu_t *eu);
218 int sum_parr(int *a[3]);
219 int sum_pcarr([size_is(n)] int *a[], int n);
220 int enum_ord(e_t e);
221 double square_encue(encue_t *eue);
222 void check_se2(se_t *s);
223
224 int sum_toplev_conf_2n([size_is(n * 2)] int *x, int n);
225 int sum_toplev_conf_cond([size_is(c ? a : b)] int *x, int a, int b, int c);
226
227 typedef struct
228 {
229 char c;
230 int i;
231 short s;
232 double d;
233 } aligns_t;
234
235 double sum_aligns(aligns_t *a);
236
237 typedef struct
238 {
239 int i;
240 char c;
241 } padded_t;
242
243 int sum_padded(padded_t *p);
244 int sum_padded2(padded_t ps[2]);
245 int sum_padded_conf([size_is(n)] padded_t *ps, int n);
246
247 typedef struct
248 {
249 int *p1;
250 } bogus_helper_t;
251
252 typedef struct
253 {
254 bogus_helper_t h;
255 int *p2;
256 int *p3;
257 char c;
258 } bogus_t;
259
260 int sum_bogus(bogus_t *b);
261 void check_null([unique] int *null);
262
263 typedef struct
264 {
265 str_t s;
266 } str_struct_t;
267
268 typedef struct
269 {
270 wstr_t s;
271 } wstr_struct_t;
272
273 int str_struct_len(str_struct_t *s);
274 int wstr_struct_len(wstr_struct_t *s);
275
276 typedef struct
277 {
278 unsigned int n;
279 [size_is(n)] byte a[];
280 } doub_carr_1_t;
281
282 typedef struct
283 {
284 int n;
285 [size_is(n)] doub_carr_1_t *a[];
286 } doub_carr_t;
287
288 int sum_doub_carr(doub_carr_t *dc);
289 void make_pyramid_doub_carr(unsigned char n, [out] doub_carr_t **dc);
290
291 typedef struct
292 {
293 short n;
294 [size_is(n)] short data[];
295 } wire_bstr_t;
296
297 typedef [wire_marshal(wire_bstr_t)] short *bstr_t;
298 unsigned hash_bstr(bstr_t s);
299
300 typedef struct
301 {
302 [string, size_is(size)] char *name;
303 unsigned int size;
304 } name_t;
305 void get_name([in,out] name_t *name);
306
307 int sum_pcarr2(int n, [size_is(, n)] int **pa);
308 int sum_L1_norms(int n, [size_is(n)] vector_t *vs);
309
310 /* Don't use this except in the get_s123 test. */
311 typedef struct
312 {
313 int f1;
314 int f2;
315 int f3;
316 } s123_t;
317
318 /* Make sure WIDL generates a type format string for a previously unseen
319 type as a return value. */
320 s123_t *get_s123(void);
321
322 void get_5numbers([in] int count, [out, length_is(count)] pints_t pn[5]);
323 void get_numbers([in] int length, [in] int size, [out, length_is(length), size_is(size)] pints_t pn[]);
324 str_t get_filename(void);
325 void context_handle_test(void);
326 void stop(void);
327 }