widl: Represent arrays with type_t.
[wine/wine64.git] / dlls / rpcrt4 / tests / server.idl
blob65fb71f941ac8eae4830086f1249564431c38517
1 /*
2 * A simple interface to test the RPC server.
4 * Copyright (C) Google 2007 (Dan Hipschman)
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.
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.
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
21 #include "server_defines.h"
23 typedef struct tag_vector
25 int x;
26 int y;
27 int z;
28 } vector_t;
31 uuid(00000000-4114-0704-2301-000000000000),
32 implicit_handle(handle_t IServer_IfHandle)
34 interface IServer
36 typedef struct
38 int *pi;
39 int **ppi;
40 int ***pppi;
41 } pints_t;
43 typedef struct
45 char *pc;
46 short *ps;
47 long *pl;
48 float *pf;
49 double *pd;
50 } ptypes_t;
52 typedef struct
54 vector_t *pu;
55 vector_t **pv;
56 } pvectors_t;
58 typedef struct
60 [switch_is(s)] union
62 [case(SUN_I)] int i;
63 [case(SUN_F1, SUN_F2)] float f;
64 [case(SUN_PI)] int *pi;
65 } u;
67 int s;
68 } sun_t;
70 int int_return(void);
71 int square(int x);
72 int sum(int x, int y);
73 void square_out(int x, [out] int *y);
74 void square_ref([in, out] int *x);
75 int str_length([string] const char *s);
76 int dot_self(vector_t *v);
77 double square_half(double x, [out] double *y);
78 float square_half_float(float x, [out] float *y);
79 long square_half_long(long x, [out] long *y);
80 int sum_fixed_array(int a[5]);
81 int pints_sum(pints_t *pints);
82 double ptypes_sum(ptypes_t *ptypes);
83 int dot_pvectors(pvectors_t *pvectors);
85 /* don't use this anywhere except in sp_t */
86 typedef struct
88 int x;
89 } sp_inner_t;
91 typedef struct
93 int x;
94 sp_inner_t *s;
95 } sp_t;
97 int sum_sp(sp_t *sp);
98 double square_sun(sun_t *su);
100 typedef struct test_list
102 int t;
103 [switch_is(t)] union
105 [case(TL_NULL)] int x; /* end of list */
106 [case(TL_LIST)] struct test_list *tail;
107 } u;
108 } test_list_t;
110 int test_list_length(test_list_t *ls);
111 int sum_fixed_int_3d(int m[2][3][4]);
112 int sum_conf_array([size_is(n)] int x[], int n);
113 int sum_var_array([length_is(n)] int x[20], int n);
114 int dot_two_vectors(vector_t vs[2]);
115 void stop(void);