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)
63 [case(SUN_F1, SUN_F2)] float f;
64 [case(SUN_PI)] int *pi;
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 cstr_length([string, size_is(n)] const char *s, int n);
77 int dot_self(vector_t *v);
78 double square_half(double x, [out] double *y);
79 float square_half_float(float x, [out] float *y);
80 long square_half_long(long x, [out] long *y);
81 int sum_fixed_array(int a[5]);
82 int pints_sum(pints_t *pints);
83 double ptypes_sum(ptypes_t *ptypes);
84 int dot_pvectors(pvectors_t *pvectors);
86 /* don't use this anywhere except in sp_t */
99 double square_sun(sun_t *su);
101 typedef struct test_list
106 [case(TL_NULL)] int x; /* end of list */
107 [case(TL_LIST)] struct test_list *tail;
111 int test_list_length(test_list_t *ls);
112 int sum_fixed_int_3d(int m[2][3][4]);
113 int sum_conf_array([size_is(n)] int x[], int n);
114 int sum_var_array([length_is(n)] int x[20], int n);
115 int dot_two_vectors(vector_t vs[2]);
120 [size_is(n)] int ca[];
126 [size_is(*pn)] int *ca1;
127 [size_is(n * 2)] int *ca2;
133 [size_is(c ? a : b)] int *ca;
139 int sum_cs(cs_t *cs);
140 int sum_cps(cps_t *cps);
141 int sum_cpsc(cpsc_t *cpsc);
143 typedef [wire_marshal(int)] void *puint_t;
144 int square_puint(puint_t p);
145 int dot_copy_vectors(vector_t u, vector_t v);
147 typedef struct wire_us *wire_us_t;
148 typedef [wire_marshal(wire_us_t)] struct us us_t;
162 int square_test_us(test_us_t *tus);
164 typedef union encu switch (int t)
167 case ENCU_F: float f;
178 typedef union encue switch (e_t t)
184 double square_encu(encu_t *eu);
185 int sum_parr(int *a[3]);
186 int sum_pcarr([size_is(n)] int *a[], int n);
188 double square_encue(encue_t *eue);
190 int sum_toplev_conf_2n([size_is(n * 2)] int *x, int n);
191 int sum_toplev_conf_cond([size_is(c ? a : b)] int *x, int a, int b, int c);
201 double sum_aligns(aligns_t *a);
209 int sum_padded(padded_t *p);
210 int sum_padded2(padded_t ps[2]);
211 int sum_padded_conf([size_is(n)] padded_t *ps, int n);
226 int sum_bogus(bogus_t *b);
227 void check_null([unique] int *null);