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
31 uuid(00000000-4114-0704-2301-000000000000),
32 implicit_handle
(handle_t IServer_IfHandle
)
37 typedef wchar_t WCHAR
;
40 typedef [string] char *str_t
;
41 typedef [string] WCHAR
*wstr_t
;
70 [case(SUN_F1
, SUN_F2
)] float f
;
71 [case(SUN_PI
)] int *pi
;
79 int sum
(int x
, int y
);
80 void square_out
(int x
, [out] int *y
);
81 void square_ref
([in, out] int *x
);
82 int str_length
([string] const char *s
);
83 int cstr_length
([string, size_is(n
)] const char *s
, int n
);
84 int dot_self
(vector_t
*v
);
85 double square_half
(double x
, [out] double *y
);
86 float square_half_float
(float x
, [out] float *y
);
87 long square_half_long
(long x
, [out] long *y
);
88 int sum_fixed_array
(int a
[5]);
89 int pints_sum
(pints_t
*pints
);
90 double ptypes_sum
(ptypes_t
*ptypes
);
91 int dot_pvectors
(pvectors_t
*pvectors
);
93 /* don't use this anywhere except in sp_t */
105 int sum_sp
(sp_t
*sp
);
106 double square_sun
(sun_t
*su
);
108 typedef struct test_list
113 [case(TL_NULL
)] int x
; /* end of list */
114 [case(TL_LIST
)] struct test_list
*tail
;
118 int test_list_length
(test_list_t
*ls
);
119 int sum_fixed_int_3d
(int m
[2][3][4]);
120 int sum_conf_array
([size_is(n
)] int x
[], int n
);
121 int sum_unique_conf_array
([size_is(n
), unique] int x
[], int n
);
122 int sum_unique_conf_ptr
([size_is(n
), unique] int *x
, int n
);
123 int sum_var_array
([length_is(n
)] int x
[20], int n
);
124 int dot_two_vectors
(vector_t vs
[2]);
129 [size_is(n
)] int ca
[];
135 [size_is(*pn
)] int *ca1
;
136 [size_is(n
* 2)] int *ca2
;
142 [size_is(c ? a
: b
)] int *ca
;
148 int sum_cs
(cs_t
*cs
);
149 int sum_cps
(cps_t
*cps
);
150 int sum_cpsc
(cpsc_t
*cpsc
);
152 typedef [wire_marshal(int)] void *puint_t
;
153 int square_puint
(puint_t p
);
154 int dot_copy_vectors
(vector_t u
, vector_t v
);
156 typedef struct wire_us
*wire_us_t
;
157 typedef [wire_marshal(wire_us_t
)] struct us us_t
;
171 int square_test_us
(test_us_t
*tus
);
173 typedef union encu
switch (int t
)
176 case ENCU_F
: float f
;
187 typedef union encue
switch (e_t t
)
193 double square_encu
(encu_t
*eu
);
194 int sum_parr
(int *a
[3]);
195 int sum_pcarr
([size_is(n
)] int *a
[], int n
);
197 double square_encue
(encue_t
*eue
);
199 int sum_toplev_conf_2n
([size_is(n
* 2)] int *x
, int n
);
200 int sum_toplev_conf_cond
([size_is(c ? a
: b
)] int *x
, int a
, int b
, int c
);
210 double sum_aligns
(aligns_t
*a
);
218 int sum_padded
(padded_t
*p
);
219 int sum_padded2
(padded_t ps
[2]);
220 int sum_padded_conf
([size_is(n
)] padded_t
*ps
, int n
);
235 int sum_bogus
(bogus_t
*b
);
236 void check_null
([unique] int *null
);
248 int str_struct_len
(str_struct_t
*s
);
249 int wstr_struct_len
(wstr_struct_t
*s
);