r13109: 3.0.21b chnges from the 3.0 tree (round #2)
[Samba.git] / source / rpc_parse / parse_echo.c
blob48dda7b17152b8504eea79e10c5237d674696d27
1 /*
2 * Unix SMB/CIFS implementation.
4 * RPC Pipe client / server routines
6 * Copyright (C) Tim Potter 2003
7 *
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
23 #include "includes.h"
25 #undef DBGC_CLASS
26 #define DBGC_CLASS DBGC_RPC_PARSE
28 void init_echo_q_add_one(ECHO_Q_ADD_ONE *q_d, uint32 request)
30 q_d->request = request;
33 BOOL echo_io_q_add_one(const char *desc, ECHO_Q_ADD_ONE *q_d,
34 prs_struct *ps, int depth)
36 if (!prs_uint32("request", ps, 0, &q_d->request))
37 return False;
39 return True;
42 BOOL echo_io_r_add_one(const char *desc, ECHO_R_ADD_ONE *q_d,
43 prs_struct *ps, int depth)
45 if (!prs_uint32("response", ps, 0, &q_d->response))
46 return False;
48 return True;
52 void init_echo_q_echo_data(ECHO_Q_ECHO_DATA *q_d, uint32 size, char *data)
54 q_d->size = size;
55 q_d->data = data;
58 BOOL echo_io_q_echo_data(const char *desc, ECHO_Q_ECHO_DATA *q_d,
59 prs_struct *ps, int depth)
61 if (!prs_uint32("size", ps, depth, &q_d->size))
62 return False;
64 if (!prs_uint32("size", ps, depth, &q_d->size))
65 return False;
67 if (UNMARSHALLING(ps)) {
68 q_d->data = PRS_ALLOC_MEM(ps, char, q_d->size);
70 if (!q_d->data)
71 return False;
74 if (!prs_uint8s(False, "data", ps, depth, (unsigned char *)q_d->data, q_d->size))
75 return False;
77 return True;
80 BOOL echo_io_r_echo_data(const char *desc, ECHO_R_ECHO_DATA *q_d,
81 prs_struct *ps, int depth)
83 if (!prs_uint32("size", ps, 0, &q_d->size))
84 return False;
86 if (UNMARSHALLING(ps)) {
87 q_d->data = PRS_ALLOC_MEM(ps, char, q_d->size);
89 if (!q_d->data)
90 return False;
93 if (!prs_uint8s(False, "data", ps, depth, (unsigned char *)q_d->data, q_d->size))
94 return False;
96 return True;
99 void init_echo_q_sink_data(ECHO_Q_SINK_DATA *q_d, uint32 size, char *data)
101 q_d->size = size;
102 q_d->data = data;
105 BOOL echo_io_q_sink_data(const char *desc, ECHO_Q_SINK_DATA *q_d,
106 prs_struct *ps, int depth)
108 if (!prs_uint32("size", ps, depth, &q_d->size))
109 return False;
111 if (!prs_uint32("size", ps, depth, &q_d->size))
112 return False;
114 if (UNMARSHALLING(ps)) {
115 q_d->data = PRS_ALLOC_MEM(ps, char, q_d->size);
117 if (!q_d->data)
118 return False;
121 if (!prs_uint8s(False, "data", ps, depth, (unsigned char *)q_d->data, q_d->size))
122 return False;
124 return True;
127 BOOL echo_io_r_sink_data(const char *desc, ECHO_R_SINK_DATA *q_d,
128 prs_struct *ps, int depth)
130 return True;
133 void init_echo_q_source_data(ECHO_Q_SOURCE_DATA *q_d, uint32 size)
135 q_d->size = size;
138 BOOL echo_io_q_source_data(const char *desc, ECHO_Q_SOURCE_DATA *q_d,
139 prs_struct *ps, int depth)
141 if (!prs_uint32("size", ps, depth, &q_d->size))
142 return False;
144 return True;
147 BOOL echo_io_r_source_data(const char *desc, ECHO_R_SOURCE_DATA *q_d,
148 prs_struct *ps, int depth)
150 if (!prs_uint32("size", ps, 0, &q_d->size))
151 return False;
153 if (UNMARSHALLING(ps)) {
154 q_d->data = PRS_ALLOC_MEM(ps, char, q_d->size);
156 if (!q_d->data)
157 return False;
160 if (!prs_uint8s(False, "data", ps, depth, (unsigned char *)q_d->data, q_d->size))
161 return False;
163 return True;