Implemented GetNamedPipeInfo.
[wine/wine-kai.git] / server / request.h
blob3187fe51c47e5f810de7093a7eebbf4ff42745d7
1 /*
2 * Wine server requests
4 * Copyright (C) 1999 Alexandre Julliard
5 */
7 #ifndef __WINE_SERVER_REQUEST_H
8 #define __WINE_SERVER_REQUEST_H
10 #include "thread.h"
11 #include "wine/server_protocol.h"
13 /* max request length */
14 #define MAX_REQUEST_LENGTH 8192
16 /* request handler definition */
17 #define DECL_HANDLER(name) void req_##name( struct name##_request *req )
19 /* request functions */
21 #ifdef __GNUC__
22 extern void fatal_protocol_error( struct thread *thread,
23 const char *err, ... ) __attribute__((format (printf,2,3)));
24 extern void fatal_protocol_perror( struct thread *thread,
25 const char *err, ... ) __attribute__((format (printf,2,3)));
26 extern void fatal_error( const char *err, ... ) __attribute__((noreturn,format(printf,1,2)));
27 extern void fatal_perror( const char *err, ... ) __attribute__((noreturn,format(printf,1,2)));
28 #else
29 extern void fatal_protocol_error( struct thread *thread, const char *err, ... );
30 extern void fatal_protocol_perror( struct thread *thread, const char *err, ... );
31 extern void fatal_error( const char *err, ... );
32 extern void fatal_perror( const char *err, ... );
33 #endif
35 extern const char *get_config_dir(void);
36 extern int receive_fd( struct process *process );
37 extern int send_client_fd( struct process *process, int fd, handle_t handle );
38 extern void read_request( struct thread *thread );
39 extern void send_reply( struct thread *thread, union generic_request *request );
40 extern void open_master_socket(void);
41 extern void close_master_socket(void);
42 extern void lock_master_socket( int locked );
44 extern void trace_request( struct thread *thread, const union generic_request *request );
45 extern void trace_reply( struct thread *thread, const union generic_request *request );
47 /* get the request vararg data */
48 inline static void *get_req_data( const void *req )
50 return (char *)current->buffer + ((struct request_header *)req)->var_offset;
53 /* get the request vararg size */
54 inline static size_t get_req_data_size( const void *req )
56 return ((struct request_header *)req)->var_size;
59 /* set the request vararg size */
60 inline static void set_req_data_size( const void *req, size_t size )
62 ((struct request_header *)req)->var_size = size;
65 /* Everything below this line is generated automatically by tools/make_requests */
66 /* ### make_requests begin ### */
68 DECL_HANDLER(new_process);
69 DECL_HANDLER(get_new_process_info);
70 DECL_HANDLER(new_thread);
71 DECL_HANDLER(boot_done);
72 DECL_HANDLER(init_process);
73 DECL_HANDLER(init_process_done);
74 DECL_HANDLER(init_thread);
75 DECL_HANDLER(set_thread_buffer);
76 DECL_HANDLER(terminate_process);
77 DECL_HANDLER(terminate_thread);
78 DECL_HANDLER(get_process_info);
79 DECL_HANDLER(set_process_info);
80 DECL_HANDLER(get_thread_info);
81 DECL_HANDLER(set_thread_info);
82 DECL_HANDLER(suspend_thread);
83 DECL_HANDLER(resume_thread);
84 DECL_HANDLER(load_dll);
85 DECL_HANDLER(unload_dll);
86 DECL_HANDLER(queue_apc);
87 DECL_HANDLER(get_apc);
88 DECL_HANDLER(close_handle);
89 DECL_HANDLER(set_handle_info);
90 DECL_HANDLER(dup_handle);
91 DECL_HANDLER(open_process);
92 DECL_HANDLER(select);
93 DECL_HANDLER(create_event);
94 DECL_HANDLER(event_op);
95 DECL_HANDLER(open_event);
96 DECL_HANDLER(create_mutex);
97 DECL_HANDLER(release_mutex);
98 DECL_HANDLER(open_mutex);
99 DECL_HANDLER(create_semaphore);
100 DECL_HANDLER(release_semaphore);
101 DECL_HANDLER(open_semaphore);
102 DECL_HANDLER(create_file);
103 DECL_HANDLER(alloc_file_handle);
104 DECL_HANDLER(get_handle_fd);
105 DECL_HANDLER(set_file_pointer);
106 DECL_HANDLER(truncate_file);
107 DECL_HANDLER(set_file_time);
108 DECL_HANDLER(flush_file);
109 DECL_HANDLER(get_file_info);
110 DECL_HANDLER(lock_file);
111 DECL_HANDLER(unlock_file);
112 DECL_HANDLER(create_pipe);
113 DECL_HANDLER(create_socket);
114 DECL_HANDLER(accept_socket);
115 DECL_HANDLER(set_socket_event);
116 DECL_HANDLER(get_socket_event);
117 DECL_HANDLER(enable_socket_event);
118 DECL_HANDLER(alloc_console);
119 DECL_HANDLER(free_console);
120 DECL_HANDLER(open_console);
121 DECL_HANDLER(set_console_fd);
122 DECL_HANDLER(get_console_mode);
123 DECL_HANDLER(set_console_mode);
124 DECL_HANDLER(set_console_info);
125 DECL_HANDLER(get_console_info);
126 DECL_HANDLER(write_console_input);
127 DECL_HANDLER(read_console_input);
128 DECL_HANDLER(create_change_notification);
129 DECL_HANDLER(create_mapping);
130 DECL_HANDLER(open_mapping);
131 DECL_HANDLER(get_mapping_info);
132 DECL_HANDLER(create_device);
133 DECL_HANDLER(create_snapshot);
134 DECL_HANDLER(next_process);
135 DECL_HANDLER(next_thread);
136 DECL_HANDLER(next_module);
137 DECL_HANDLER(wait_debug_event);
138 DECL_HANDLER(queue_exception_event);
139 DECL_HANDLER(get_exception_status);
140 DECL_HANDLER(output_debug_string);
141 DECL_HANDLER(continue_debug_event);
142 DECL_HANDLER(debug_process);
143 DECL_HANDLER(read_process_memory);
144 DECL_HANDLER(write_process_memory);
145 DECL_HANDLER(create_key);
146 DECL_HANDLER(open_key);
147 DECL_HANDLER(delete_key);
148 DECL_HANDLER(enum_key);
149 DECL_HANDLER(set_key_value);
150 DECL_HANDLER(get_key_value);
151 DECL_HANDLER(enum_key_value);
152 DECL_HANDLER(delete_key_value);
153 DECL_HANDLER(load_registry);
154 DECL_HANDLER(save_registry);
155 DECL_HANDLER(save_registry_atexit);
156 DECL_HANDLER(set_registry_levels);
157 DECL_HANDLER(create_timer);
158 DECL_HANDLER(open_timer);
159 DECL_HANDLER(set_timer);
160 DECL_HANDLER(cancel_timer);
161 DECL_HANDLER(get_thread_context);
162 DECL_HANDLER(set_thread_context);
163 DECL_HANDLER(get_selector_entry);
164 DECL_HANDLER(add_atom);
165 DECL_HANDLER(delete_atom);
166 DECL_HANDLER(find_atom);
167 DECL_HANDLER(get_atom_name);
168 DECL_HANDLER(init_atom_table);
169 DECL_HANDLER(get_msg_queue);
170 DECL_HANDLER(inc_queue_paint_count);
171 DECL_HANDLER(set_queue_mask);
172 DECL_HANDLER(get_queue_status);
173 DECL_HANDLER(wait_input_idle);
174 DECL_HANDLER(send_message);
175 DECL_HANDLER(get_message);
176 DECL_HANDLER(reply_message);
177 DECL_HANDLER(get_message_reply);
178 DECL_HANDLER(cleanup_window_queue);
179 DECL_HANDLER(set_win_timer);
180 DECL_HANDLER(kill_win_timer);
181 DECL_HANDLER(create_serial);
182 DECL_HANDLER(get_serial_info);
183 DECL_HANDLER(set_serial_info);
184 DECL_HANDLER(create_async);
185 DECL_HANDLER(create_named_pipe);
186 DECL_HANDLER(open_named_pipe);
187 DECL_HANDLER(connect_named_pipe);
188 DECL_HANDLER(wait_named_pipe);
189 DECL_HANDLER(disconnect_named_pipe);
190 DECL_HANDLER(get_named_pipe_info);
192 #ifdef WANT_REQUEST_HANDLERS
194 typedef void (*req_handler)( void *req );
195 static const req_handler req_handlers[REQ_NB_REQUESTS] =
197 (req_handler)req_new_process,
198 (req_handler)req_get_new_process_info,
199 (req_handler)req_new_thread,
200 (req_handler)req_boot_done,
201 (req_handler)req_init_process,
202 (req_handler)req_init_process_done,
203 (req_handler)req_init_thread,
204 (req_handler)req_set_thread_buffer,
205 (req_handler)req_terminate_process,
206 (req_handler)req_terminate_thread,
207 (req_handler)req_get_process_info,
208 (req_handler)req_set_process_info,
209 (req_handler)req_get_thread_info,
210 (req_handler)req_set_thread_info,
211 (req_handler)req_suspend_thread,
212 (req_handler)req_resume_thread,
213 (req_handler)req_load_dll,
214 (req_handler)req_unload_dll,
215 (req_handler)req_queue_apc,
216 (req_handler)req_get_apc,
217 (req_handler)req_close_handle,
218 (req_handler)req_set_handle_info,
219 (req_handler)req_dup_handle,
220 (req_handler)req_open_process,
221 (req_handler)req_select,
222 (req_handler)req_create_event,
223 (req_handler)req_event_op,
224 (req_handler)req_open_event,
225 (req_handler)req_create_mutex,
226 (req_handler)req_release_mutex,
227 (req_handler)req_open_mutex,
228 (req_handler)req_create_semaphore,
229 (req_handler)req_release_semaphore,
230 (req_handler)req_open_semaphore,
231 (req_handler)req_create_file,
232 (req_handler)req_alloc_file_handle,
233 (req_handler)req_get_handle_fd,
234 (req_handler)req_set_file_pointer,
235 (req_handler)req_truncate_file,
236 (req_handler)req_set_file_time,
237 (req_handler)req_flush_file,
238 (req_handler)req_get_file_info,
239 (req_handler)req_lock_file,
240 (req_handler)req_unlock_file,
241 (req_handler)req_create_pipe,
242 (req_handler)req_create_socket,
243 (req_handler)req_accept_socket,
244 (req_handler)req_set_socket_event,
245 (req_handler)req_get_socket_event,
246 (req_handler)req_enable_socket_event,
247 (req_handler)req_alloc_console,
248 (req_handler)req_free_console,
249 (req_handler)req_open_console,
250 (req_handler)req_set_console_fd,
251 (req_handler)req_get_console_mode,
252 (req_handler)req_set_console_mode,
253 (req_handler)req_set_console_info,
254 (req_handler)req_get_console_info,
255 (req_handler)req_write_console_input,
256 (req_handler)req_read_console_input,
257 (req_handler)req_create_change_notification,
258 (req_handler)req_create_mapping,
259 (req_handler)req_open_mapping,
260 (req_handler)req_get_mapping_info,
261 (req_handler)req_create_device,
262 (req_handler)req_create_snapshot,
263 (req_handler)req_next_process,
264 (req_handler)req_next_thread,
265 (req_handler)req_next_module,
266 (req_handler)req_wait_debug_event,
267 (req_handler)req_queue_exception_event,
268 (req_handler)req_get_exception_status,
269 (req_handler)req_output_debug_string,
270 (req_handler)req_continue_debug_event,
271 (req_handler)req_debug_process,
272 (req_handler)req_read_process_memory,
273 (req_handler)req_write_process_memory,
274 (req_handler)req_create_key,
275 (req_handler)req_open_key,
276 (req_handler)req_delete_key,
277 (req_handler)req_enum_key,
278 (req_handler)req_set_key_value,
279 (req_handler)req_get_key_value,
280 (req_handler)req_enum_key_value,
281 (req_handler)req_delete_key_value,
282 (req_handler)req_load_registry,
283 (req_handler)req_save_registry,
284 (req_handler)req_save_registry_atexit,
285 (req_handler)req_set_registry_levels,
286 (req_handler)req_create_timer,
287 (req_handler)req_open_timer,
288 (req_handler)req_set_timer,
289 (req_handler)req_cancel_timer,
290 (req_handler)req_get_thread_context,
291 (req_handler)req_set_thread_context,
292 (req_handler)req_get_selector_entry,
293 (req_handler)req_add_atom,
294 (req_handler)req_delete_atom,
295 (req_handler)req_find_atom,
296 (req_handler)req_get_atom_name,
297 (req_handler)req_init_atom_table,
298 (req_handler)req_get_msg_queue,
299 (req_handler)req_inc_queue_paint_count,
300 (req_handler)req_set_queue_mask,
301 (req_handler)req_get_queue_status,
302 (req_handler)req_wait_input_idle,
303 (req_handler)req_send_message,
304 (req_handler)req_get_message,
305 (req_handler)req_reply_message,
306 (req_handler)req_get_message_reply,
307 (req_handler)req_cleanup_window_queue,
308 (req_handler)req_set_win_timer,
309 (req_handler)req_kill_win_timer,
310 (req_handler)req_create_serial,
311 (req_handler)req_get_serial_info,
312 (req_handler)req_set_serial_info,
313 (req_handler)req_create_async,
314 (req_handler)req_create_named_pipe,
315 (req_handler)req_open_named_pipe,
316 (req_handler)req_connect_named_pipe,
317 (req_handler)req_wait_named_pipe,
318 (req_handler)req_disconnect_named_pipe,
319 (req_handler)req_get_named_pipe_info,
321 #endif /* WANT_REQUEST_HANDLERS */
323 /* ### make_requests end ### */
324 /* Everything above this line is generated automatically by tools/make_requests */
326 #endif /* __WINE_SERVER_REQUEST_H */