1 /* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
2 /* dbus-message.h DBusMessage object
4 * Copyright (C) 2002, 2003, 2005 Red Hat Inc.
5 * Copyright (C) 2015 Samsung Electronics
7 * Licensed under the Academic Free License version 2.1
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
24 #if !defined (DBUS_INSIDE_DBUS_H) && !defined (DBUS_COMPILATION)
25 #error "Only <dbus/dbus.h> can be included directly, this file may disappear or change contents."
28 #ifndef DBUS_MESSAGE_H
29 #define DBUS_MESSAGE_H
31 #include <dbus/dbus-macros.h>
32 #include <dbus/dbus-types.h>
33 #include <dbus/dbus-arch-deps.h>
34 #include <dbus/dbus-memory.h>
35 #include <dbus/dbus-errors.h>
41 * @addtogroup DBusMessage
45 typedef struct DBusMessage DBusMessage;
46 /** Opaque type representing a message iterator. Can be copied by value, and contains no allocated memory so never needs to be freed and can be allocated on the stack. */
47 typedef struct DBusMessageIter DBusMessageIter;
50 * DBusMessageIter struct; contains no public fields.
52 struct DBusMessageIter
53 { /* layout on a standard 64-bit system */
54 void *dummy1; /**< Don't use this */ /* message */
55 dbus_uint32_t dummy3a : 21; /**< Don't use this */
56 dbus_uint32_t dummy3b : 3; /**< Don't use this */
57 dbus_uint32_t dummy3c : 8; /**< Don't use this */
59 /* padding before union */
63 dbus_uint32_t dummy1a : 8; /**< Don't use this */
64 dbus_uint32_t dummy1b : 1; /**< Don't use this */
65 dbus_uint32_t dummy1c : 3; /**< Don't use this */
66 dbus_uint32_t dummy1d : 1; /**< Don't use this */
67 dbus_uint32_t dummy1e : 1; /**< Don't use this */
68 dbus_uint32_t dummy1f : 1; /**< Don't use this */
69 void *dummy2; /**< Don't use this */
70 int dummy3; /**< Don't use this */
71 void *dummy4; /**< Don't use this */
72 int dummy5; /**< Don't use this */
73 int dummy6; /**< Don't use this */
74 size_t dummy7; /**< Don't use this */
75 size_t dummy8; /**< Don't use this */
76 int dummy9; /**< Don't use this */
78 void *dummy10; /**< Don't use this */
82 int dummy11; /**< Don't use this */
89 dbus_uint32_t dummy1a : 8; /**< Don't use this */
90 dbus_uint32_t dummy1b : 8; /**< Don't use this */
91 dbus_uint32_t dummy1c : 1; /**< Don't use this */
92 dbus_uint32_t dummy1d : 1; /**< Don't use this */
93 dbus_uint32_t dummy1e : 1; /**< Don't use this */
94 dbus_uint32_t dummy1f : 1; /**< Don't use this */
95 dbus_uint32_t dummy1g : 1; /**< Don't use this */
97 void *dummy2; /**< Don't use this */
98 int dummy3; /**< Don't use this */
99 void *dummy4; /**< Don't use this */
100 int dummy5; /**< Don't use this */
101 size_t dummy6; /**< Don't use this */
102 void *dummy7; /**< Don't use this */
103 int dummy8; /**< Don't use this */
104 char dummy9; /**< Don't use this */
109 int dummy10; /**< Don't use this */
110 int dummy11; /**< Don't use this */
111 int dummy12; /**< Don't use this */
114 size_t dummy13; /**< Don't use this */
122 DBusMessage* dbus_message_new (int message_type);
124 DBusMessage* dbus_message_new_method_call (const char *bus_name,
129 DBusMessage* dbus_message_new_method_return (DBusMessage *method_call);
131 DBusMessage* dbus_message_new_signal (const char *path,
135 DBusMessage* dbus_message_new_error (DBusMessage *reply_to,
136 const char *error_name,
137 const char *error_message);
139 DBusMessage* dbus_message_new_error_printf (DBusMessage *reply_to,
140 const char *error_name,
141 const char *error_format,
145 DBusMessage* dbus_message_copy (const DBusMessage *message);
148 DBusMessage* dbus_message_ref (DBusMessage *message);
150 void dbus_message_unref (DBusMessage *message);
152 int dbus_message_get_type (DBusMessage *message);
154 dbus_bool_t dbus_message_set_path (DBusMessage *message,
155 const char *object_path);
157 const char* dbus_message_get_path (DBusMessage *message);
159 dbus_bool_t dbus_message_has_path (DBusMessage *message,
160 const char *object_path);
162 dbus_bool_t dbus_message_set_interface (DBusMessage *message,
165 const char* dbus_message_get_interface (DBusMessage *message);
167 dbus_bool_t dbus_message_has_interface (DBusMessage *message,
170 dbus_bool_t dbus_message_set_member (DBusMessage *message,
173 const char* dbus_message_get_member (DBusMessage *message);
175 dbus_bool_t dbus_message_has_member (DBusMessage *message,
178 dbus_bool_t dbus_message_set_error_name (DBusMessage *message,
181 const char* dbus_message_get_error_name (DBusMessage *message);
183 dbus_bool_t dbus_message_set_destination (DBusMessage *message,
184 const char *destination);
186 const char* dbus_message_get_destination (DBusMessage *message);
188 dbus_bool_t dbus_message_set_sender (DBusMessage *message,
191 const char* dbus_message_get_sender (DBusMessage *message);
193 const char* dbus_message_get_signature (DBusMessage *message);
195 void dbus_message_set_no_reply (DBusMessage *message,
196 dbus_bool_t no_reply);
198 dbus_bool_t dbus_message_get_no_reply (DBusMessage *message);
200 dbus_bool_t dbus_message_is_method_call (DBusMessage *message,
204 dbus_bool_t dbus_message_is_signal (DBusMessage *message,
206 const char *signal_name);
208 dbus_bool_t dbus_message_is_error (DBusMessage *message,
209 const char *error_name);
211 dbus_bool_t dbus_message_has_destination (DBusMessage *message,
212 const char *bus_name);
214 dbus_bool_t dbus_message_has_sender (DBusMessage *message,
215 const char *unique_bus_name);
217 dbus_bool_t dbus_message_has_signature (DBusMessage *message,
218 const char *signature);
220 dbus_uint32_t dbus_message_get_serial (DBusMessage *message);
222 void dbus_message_set_serial (DBusMessage *message,
223 dbus_uint32_t serial);
225 dbus_bool_t dbus_message_set_reply_serial (DBusMessage *message,
226 dbus_uint32_t reply_serial);
228 dbus_uint32_t dbus_message_get_reply_serial (DBusMessage *message);
231 void dbus_message_set_auto_start (DBusMessage *message,
232 dbus_bool_t auto_start);
234 dbus_bool_t dbus_message_get_auto_start (DBusMessage *message);
237 dbus_bool_t dbus_message_get_path_decomposed (DBusMessage *message,
241 dbus_bool_t dbus_message_append_args (DBusMessage *message,
245 dbus_bool_t dbus_message_append_args_valist (DBusMessage *message,
249 dbus_bool_t dbus_message_get_args (DBusMessage *message,
254 dbus_bool_t dbus_message_get_args_valist (DBusMessage *message,
260 dbus_bool_t dbus_message_contains_unix_fds (DBusMessage *message);
263 dbus_bool_t dbus_message_iter_init (DBusMessage *message,
264 DBusMessageIter *iter);
266 dbus_bool_t dbus_message_iter_has_next (DBusMessageIter *iter);
268 dbus_bool_t dbus_message_iter_next (DBusMessageIter *iter);
270 char* dbus_message_iter_get_signature (DBusMessageIter *iter);
272 int dbus_message_iter_get_arg_type (DBusMessageIter *iter);
274 int dbus_message_iter_get_element_type (DBusMessageIter *iter);
276 void dbus_message_iter_recurse (DBusMessageIter *iter,
277 DBusMessageIter *sub);
279 void dbus_message_iter_get_basic (DBusMessageIter *iter,
282 int dbus_message_iter_get_element_count(DBusMessageIter *iter);
284 #ifndef DBUS_DISABLE_DEPRECATED
285 /* This function returns the wire protocol size of the array in bytes,
286 * you do not want to know that probably
289 DBUS_DEPRECATED int dbus_message_iter_get_array_len (DBusMessageIter *iter);
292 void dbus_message_iter_get_fixed_array (DBusMessageIter *iter,
298 void dbus_message_iter_init_append (DBusMessage *message,
299 DBusMessageIter *iter);
301 dbus_bool_t dbus_message_iter_append_basic (DBusMessageIter *iter,
305 dbus_bool_t dbus_message_iter_append_fixed_array (DBusMessageIter *iter,
310 dbus_bool_t dbus_message_iter_open_container (DBusMessageIter *iter,
312 const char *contained_signature,
313 DBusMessageIter *sub);
315 dbus_bool_t dbus_message_iter_close_container (DBusMessageIter *iter,
316 DBusMessageIter *sub);
318 void dbus_message_iter_abandon_container (DBusMessageIter *iter,
319 DBusMessageIter *sub);
322 void dbus_message_lock (DBusMessage *message);
325 dbus_bool_t dbus_set_error_from_message (DBusError *error,
326 DBusMessage *message);
330 dbus_bool_t dbus_message_allocate_data_slot (dbus_int32_t *slot_p);
332 void dbus_message_free_data_slot (dbus_int32_t *slot_p);
334 dbus_bool_t dbus_message_set_data (DBusMessage *message,
337 DBusFreeFunction free_data_func);
339 void* dbus_message_get_data (DBusMessage *message,
343 int dbus_message_type_from_string (const char *type_str);
345 const char* dbus_message_type_to_string (int type);
348 dbus_bool_t dbus_message_marshal (DBusMessage *msg,
349 char **marshalled_data_p,
352 DBusMessage* dbus_message_demarshal (const char *str,
357 int dbus_message_demarshal_bytes_needed (const char *str,
361 void dbus_message_set_allow_interactive_authorization (DBusMessage *message,
365 dbus_bool_t dbus_message_get_allow_interactive_authorization (
366 DBusMessage *message);
369 void dbus_set_protocol_version (unsigned char version);
375 #endif /* DBUS_MESSAGE_H */