2005-01-27 Havoc Pennington <hp@redhat.com>
[platform/upstream/dbus.git] / dbus / dbus-types.h
1 /* -*- mode: C; c-file-style: "gnu" -*- */
2 /* dbus-types.h  types such as dbus_bool_t
3  *
4  * Copyright (C) 2002  Red Hat Inc.
5  *
6  * Licensed under the Academic Free License version 2.1
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.
12  *
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.
17  * 
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., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
21  *
22  */
23 #if !defined (DBUS_INSIDE_DBUS_H) && !defined (DBUS_COMPILATION)
24 #error "Only <dbus/dbus.h> can be included directly, this file may disappear or change contents."
25 #endif
26
27 #ifndef DBUS_TYPES_H
28 #define DBUS_TYPES_H
29
30 #include <stddef.h>
31 #include <dbus/dbus-arch-deps.h>
32
33 typedef dbus_uint32_t  dbus_unichar_t;
34 /* boolean size must be fixed at 4 bytes due to wire protocol! */
35 typedef dbus_uint32_t  dbus_bool_t;
36
37 /* Normally docs are in .c files, but there isn't a .c file for this. */
38 /**
39  * @defgroup DBusTypes Basic types
40  * @ingroup  DBus
41  * @brief dbus_bool_t, dbus_int32_t, etc.
42  *
43  * Typedefs for common primitive types.
44  *
45  * @{
46  */
47
48 /**
49  * @typedef dbus_bool_t
50  *
51  * A boolean, valid values are #TRUE and #FALSE.
52  */
53
54 /**
55  * @typedef dbus_uint32_t
56  *
57  * A 32-bit unsigned integer on all platforms.
58  */
59
60 /**
61  * @typedef dbus_int32_t
62  *
63  * A 32-bit signed integer on all platforms.
64  */
65
66 /**
67  * @typedef dbus_uint16_t
68  *
69  * A 16-bit unsigned integer on all platforms.
70  */
71
72 /**
73  * @typedef dbus_int16_t
74  *
75  * A 16-bit signed integer on all platforms.
76  */
77
78
79 /**
80  * @typedef dbus_uint64_t
81  *
82  * A 64-bit unsigned integer on all platforms that support it.
83  * If supported, #DBUS_HAVE_INT64 will be defined.
84  *
85  * C99 requires a 64-bit type and most likely all interesting
86  * compilers support one. GLib for example flat-out requires
87  * a 64-bit type.
88  */
89
90 /**
91  * @typedef dbus_int64_t
92  *
93  * A 64-bit signed integer on all platforms that support it.
94  * If supported, #DBUS_HAVE_INT64 will be defined.
95  *
96  * C99 requires a 64-bit type and most likely all interesting
97  * compilers support one. GLib for example flat-out requires
98  * a 64-bit type.
99  */
100
101 /**
102  * @def DBUS_INT64_CONSTANT
103  *
104  * Declare a 64-bit signed integer constant. The macro
105  * adds the necessary "LL" or whatever after the integer,
106  * giving a literal such as "325145246765LL"
107  */
108
109 /**
110  * @def DBUS_UINT64_CONSTANT
111  *
112  * Declare a 64-bit unsigned integer constant. The macro
113  * adds the necessary "ULL" or whatever after the integer,
114  * giving a literal such as "325145246765ULL"
115  */
116
117 /** @} */
118
119 #endif /* DBUS_TYPES_H */