Fixed typo in HKEY_CURRENT_CONFIG name.
[wine] / server / request.h
1 /*
2  * Wine server requests
3  *
4  * Copyright (C) 1999 Alexandre Julliard
5  */
6
7 #ifndef __WINE_SERVER_REQUEST_H
8 #define __WINE_SERVER_REQUEST_H
9
10 #ifndef __WINE_SERVER__
11 #error This file can only be used in the Wine server
12 #endif
13
14 #include "thread.h"
15
16 /* max request length */
17 #define MAX_REQUEST_LENGTH  8192
18
19 /* request handler definition */
20 #define DECL_HANDLER(name) void req_##name( struct name##_request *req )
21
22 /* request functions */
23
24 #ifdef __GNUC__
25 extern void fatal_protocol_error( struct thread *thread,
26                                   const char *err, ... ) __attribute__((format (printf,2,3)));
27 #else
28 extern void fatal_protocol_error( struct thread *thread, const char *err, ... );
29 #endif
30
31 extern void fatal_error( const char *err, ... ) WINE_NORETURN;
32 extern void fatal_perror( const char *err, ... ) WINE_NORETURN;
33 extern const char *get_config_dir(void);
34 extern void read_request( struct thread *thread );
35 extern int write_request( struct thread *thread );
36 extern void set_reply_fd( struct thread *thread, int pass_fd );
37 extern void send_reply( struct thread *thread );
38 extern void open_master_socket(void);
39 extern void close_master_socket(void);
40 extern void lock_master_socket( int locked );
41
42 extern void trace_request( enum request req );
43 extern void trace_reply( struct thread *thread );
44
45 /* get the request buffer */
46 static inline void *get_req_ptr( struct thread *thread )
47 {
48     return thread->buffer;
49 }
50
51 /* get the remaining size in the request buffer for object of a given size */
52 static inline int get_req_size( const void *req, const void *ptr, size_t typesize )
53 {
54     return ((char *)req + MAX_REQUEST_LENGTH - (char *)ptr) / typesize;
55 }
56
57 /* get the length of a request string, without going past the end of the request */
58 static inline size_t get_req_strlen( const void *req, const char *str )
59 {
60     const char *p = str;
61     while (*p && (p < (char *)req + MAX_REQUEST_LENGTH - 1)) p++;
62     return p - str;
63 }
64
65 /* same as above for Unicode */
66 static inline size_t get_req_strlenW( const void *req, const WCHAR *str )
67 {
68     const WCHAR *p = str;
69     while (*p && (p < (WCHAR *)req + MAX_REQUEST_LENGTH/sizeof(WCHAR) - 1)) p++;
70     return p - str;
71 }
72
73 /* Everything below this line is generated automatically by tools/make_requests */
74 /* ### make_requests begin ### */
75
76 DECL_HANDLER(new_process);
77 DECL_HANDLER(wait_process);
78 DECL_HANDLER(new_thread);
79 DECL_HANDLER(boot_done);
80 DECL_HANDLER(init_process);
81 DECL_HANDLER(init_process_done);
82 DECL_HANDLER(init_thread);
83 DECL_HANDLER(get_thread_buffer);
84 DECL_HANDLER(terminate_process);
85 DECL_HANDLER(terminate_thread);
86 DECL_HANDLER(get_process_info);
87 DECL_HANDLER(set_process_info);
88 DECL_HANDLER(get_thread_info);
89 DECL_HANDLER(set_thread_info);
90 DECL_HANDLER(suspend_thread);
91 DECL_HANDLER(resume_thread);
92 DECL_HANDLER(load_dll);
93 DECL_HANDLER(unload_dll);
94 DECL_HANDLER(queue_apc);
95 DECL_HANDLER(get_apc);
96 DECL_HANDLER(close_handle);
97 DECL_HANDLER(get_handle_info);
98 DECL_HANDLER(set_handle_info);
99 DECL_HANDLER(dup_handle);
100 DECL_HANDLER(open_process);
101 DECL_HANDLER(select);
102 DECL_HANDLER(create_event);
103 DECL_HANDLER(event_op);
104 DECL_HANDLER(open_event);
105 DECL_HANDLER(create_mutex);
106 DECL_HANDLER(release_mutex);
107 DECL_HANDLER(open_mutex);
108 DECL_HANDLER(create_semaphore);
109 DECL_HANDLER(release_semaphore);
110 DECL_HANDLER(open_semaphore);
111 DECL_HANDLER(create_file);
112 DECL_HANDLER(alloc_file_handle);
113 DECL_HANDLER(get_read_fd);
114 DECL_HANDLER(get_write_fd);
115 DECL_HANDLER(set_file_pointer);
116 DECL_HANDLER(truncate_file);
117 DECL_HANDLER(set_file_time);
118 DECL_HANDLER(flush_file);
119 DECL_HANDLER(get_file_info);
120 DECL_HANDLER(lock_file);
121 DECL_HANDLER(unlock_file);
122 DECL_HANDLER(create_pipe);
123 DECL_HANDLER(create_socket);
124 DECL_HANDLER(accept_socket);
125 DECL_HANDLER(set_socket_event);
126 DECL_HANDLER(get_socket_event);
127 DECL_HANDLER(enable_socket_event);
128 DECL_HANDLER(alloc_console);
129 DECL_HANDLER(free_console);
130 DECL_HANDLER(open_console);
131 DECL_HANDLER(set_console_fd);
132 DECL_HANDLER(get_console_mode);
133 DECL_HANDLER(set_console_mode);
134 DECL_HANDLER(set_console_info);
135 DECL_HANDLER(get_console_info);
136 DECL_HANDLER(write_console_input);
137 DECL_HANDLER(read_console_input);
138 DECL_HANDLER(create_change_notification);
139 DECL_HANDLER(create_mapping);
140 DECL_HANDLER(open_mapping);
141 DECL_HANDLER(get_mapping_info);
142 DECL_HANDLER(create_device);
143 DECL_HANDLER(create_snapshot);
144 DECL_HANDLER(next_process);
145 DECL_HANDLER(next_thread);
146 DECL_HANDLER(next_module);
147 DECL_HANDLER(wait_debug_event);
148 DECL_HANDLER(exception_event);
149 DECL_HANDLER(output_debug_string);
150 DECL_HANDLER(continue_debug_event);
151 DECL_HANDLER(debug_process);
152 DECL_HANDLER(read_process_memory);
153 DECL_HANDLER(write_process_memory);
154 DECL_HANDLER(create_key);
155 DECL_HANDLER(open_key);
156 DECL_HANDLER(delete_key);
157 DECL_HANDLER(close_key);
158 DECL_HANDLER(enum_key);
159 DECL_HANDLER(query_key_info);
160 DECL_HANDLER(set_key_value);
161 DECL_HANDLER(get_key_value);
162 DECL_HANDLER(enum_key_value);
163 DECL_HANDLER(delete_key_value);
164 DECL_HANDLER(load_registry);
165 DECL_HANDLER(save_registry);
166 DECL_HANDLER(save_registry_atexit);
167 DECL_HANDLER(set_registry_levels);
168 DECL_HANDLER(create_timer);
169 DECL_HANDLER(open_timer);
170 DECL_HANDLER(set_timer);
171 DECL_HANDLER(cancel_timer);
172 DECL_HANDLER(get_thread_context);
173 DECL_HANDLER(set_thread_context);
174 DECL_HANDLER(get_selector_entry);
175 DECL_HANDLER(add_atom);
176 DECL_HANDLER(delete_atom);
177 DECL_HANDLER(find_atom);
178 DECL_HANDLER(get_atom_name);
179 DECL_HANDLER(init_atom_table);
180 DECL_HANDLER(get_msg_queue);
181 DECL_HANDLER(wake_queue);
182 DECL_HANDLER(wait_input_idle);
183
184 #ifdef WANT_REQUEST_HANDLERS
185
186 typedef void (*req_handler)( void *req );
187 static const req_handler req_handlers[REQ_NB_REQUESTS] =
188 {
189     (req_handler)req_new_process,
190     (req_handler)req_wait_process,
191     (req_handler)req_new_thread,
192     (req_handler)req_boot_done,
193     (req_handler)req_init_process,
194     (req_handler)req_init_process_done,
195     (req_handler)req_init_thread,
196     (req_handler)req_get_thread_buffer,
197     (req_handler)req_terminate_process,
198     (req_handler)req_terminate_thread,
199     (req_handler)req_get_process_info,
200     (req_handler)req_set_process_info,
201     (req_handler)req_get_thread_info,
202     (req_handler)req_set_thread_info,
203     (req_handler)req_suspend_thread,
204     (req_handler)req_resume_thread,
205     (req_handler)req_load_dll,
206     (req_handler)req_unload_dll,
207     (req_handler)req_queue_apc,
208     (req_handler)req_get_apc,
209     (req_handler)req_close_handle,
210     (req_handler)req_get_handle_info,
211     (req_handler)req_set_handle_info,
212     (req_handler)req_dup_handle,
213     (req_handler)req_open_process,
214     (req_handler)req_select,
215     (req_handler)req_create_event,
216     (req_handler)req_event_op,
217     (req_handler)req_open_event,
218     (req_handler)req_create_mutex,
219     (req_handler)req_release_mutex,
220     (req_handler)req_open_mutex,
221     (req_handler)req_create_semaphore,
222     (req_handler)req_release_semaphore,
223     (req_handler)req_open_semaphore,
224     (req_handler)req_create_file,
225     (req_handler)req_alloc_file_handle,
226     (req_handler)req_get_read_fd,
227     (req_handler)req_get_write_fd,
228     (req_handler)req_set_file_pointer,
229     (req_handler)req_truncate_file,
230     (req_handler)req_set_file_time,
231     (req_handler)req_flush_file,
232     (req_handler)req_get_file_info,
233     (req_handler)req_lock_file,
234     (req_handler)req_unlock_file,
235     (req_handler)req_create_pipe,
236     (req_handler)req_create_socket,
237     (req_handler)req_accept_socket,
238     (req_handler)req_set_socket_event,
239     (req_handler)req_get_socket_event,
240     (req_handler)req_enable_socket_event,
241     (req_handler)req_alloc_console,
242     (req_handler)req_free_console,
243     (req_handler)req_open_console,
244     (req_handler)req_set_console_fd,
245     (req_handler)req_get_console_mode,
246     (req_handler)req_set_console_mode,
247     (req_handler)req_set_console_info,
248     (req_handler)req_get_console_info,
249     (req_handler)req_write_console_input,
250     (req_handler)req_read_console_input,
251     (req_handler)req_create_change_notification,
252     (req_handler)req_create_mapping,
253     (req_handler)req_open_mapping,
254     (req_handler)req_get_mapping_info,
255     (req_handler)req_create_device,
256     (req_handler)req_create_snapshot,
257     (req_handler)req_next_process,
258     (req_handler)req_next_thread,
259     (req_handler)req_next_module,
260     (req_handler)req_wait_debug_event,
261     (req_handler)req_exception_event,
262     (req_handler)req_output_debug_string,
263     (req_handler)req_continue_debug_event,
264     (req_handler)req_debug_process,
265     (req_handler)req_read_process_memory,
266     (req_handler)req_write_process_memory,
267     (req_handler)req_create_key,
268     (req_handler)req_open_key,
269     (req_handler)req_delete_key,
270     (req_handler)req_close_key,
271     (req_handler)req_enum_key,
272     (req_handler)req_query_key_info,
273     (req_handler)req_set_key_value,
274     (req_handler)req_get_key_value,
275     (req_handler)req_enum_key_value,
276     (req_handler)req_delete_key_value,
277     (req_handler)req_load_registry,
278     (req_handler)req_save_registry,
279     (req_handler)req_save_registry_atexit,
280     (req_handler)req_set_registry_levels,
281     (req_handler)req_create_timer,
282     (req_handler)req_open_timer,
283     (req_handler)req_set_timer,
284     (req_handler)req_cancel_timer,
285     (req_handler)req_get_thread_context,
286     (req_handler)req_set_thread_context,
287     (req_handler)req_get_selector_entry,
288     (req_handler)req_add_atom,
289     (req_handler)req_delete_atom,
290     (req_handler)req_find_atom,
291     (req_handler)req_get_atom_name,
292     (req_handler)req_init_atom_table,
293     (req_handler)req_get_msg_queue,
294     (req_handler)req_wake_queue,
295     (req_handler)req_wait_input_idle,
296 };
297 #endif  /* WANT_REQUEST_HANDLERS */
298
299 /* ### make_requests end ### */
300 /* Everything above this line is generated automatically by tools/make_requests */
301
302 #endif  /* __WINE_SERVER_REQUEST_H */