2003-02-14 Havoc Pennington <hp@pobox.com>
[platform/upstream/dbus.git] / dbus / dbus-errors.h
1 /* -*- mode: C; c-file-style: "gnu" -*- */
2 /* dbus-errors.h Error reporting
3  *
4  * Copyright (C) 2002  Red Hat Inc.
5  * Copyright (C) 2003  CodeFactory AB
6  *
7  * Licensed under the Academic Free License version 1.2
8  * 
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.
13  *
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.
18  * 
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., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
22  *
23  */
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."
26 #endif
27
28 #ifndef DBUS_ERROR_H
29 #define DBUS_ERROR_H
30
31 #include <dbus/dbus-macros.h>
32 #include <dbus/dbus-types.h>
33
34 DBUS_BEGIN_DECLS;
35
36 typedef struct DBusError DBusError;
37
38 struct DBusError
39 {
40   const char *name;    /**< error name */
41   const char *message; /**< error message */
42
43   unsigned int dummy1 : 1; /**< placeholder */
44   unsigned int dummy2 : 1; /**< placeholder */
45   unsigned int dummy3 : 1; /**< placeholder */
46   unsigned int dummy4 : 1; /**< placeholder */
47   unsigned int dummy5 : 1; /**< placeholder */
48
49   void *padding1; /**< placeholder */
50 };
51
52 typedef enum
53 {
54   DBUS_RESULT_SUCCESS,         /**< Operation was successful. */
55   DBUS_RESULT_FAILED,          /**< Operation failed for unspecified reason. */
56   DBUS_RESULT_NO_MEMORY,       /**< Operation failed for lack of memory. */
57   DBUS_RESULT_IO_ERROR,        /**< Operation failed because of an IO error,
58                                 *   typically the other end closed the
59                                 *   connection.
60                                 */
61   DBUS_RESULT_BAD_ADDRESS,     /**< Address was bad, could not be parsed. */
62   DBUS_RESULT_NOT_SUPPORTED,   /**< Feature is not supported. */
63   DBUS_RESULT_LIMITS_EXCEEDED, /**< Some kernel resource limit exceeded. */
64   DBUS_RESULT_ACCESS_DENIED,   /**< Some sort of permissions/security problem. */
65   DBUS_RESULT_AUTH_FAILED,     /**< Could not authenticate. */
66   DBUS_RESULT_NO_SERVER,       /**< No one listening on the other end. */
67   DBUS_RESULT_TIMEOUT,         /**< Timed out trying to connect. */
68   DBUS_RESULT_NO_NETWORK,      /**< Can't find the network */
69   DBUS_RESULT_ADDRESS_IN_USE,  /**< Someone's already using the address */
70   DBUS_RESULT_DISCONNECTED,    /**< No more connection. */
71   DBUS_RESULT_INVALID_ARGS,    /**< One or more invalid arguments encountered. */
72   DBUS_RESULT_NO_REPLY,        /**< Did not get a reply message. */
73   DBUS_RESULT_FILE_NOT_FOUND   /**< File doesn't exist */
74 } DBusResultCode;
75
76 void        dbus_error_init      (DBusError  *error);
77 void        dbus_error_free      (DBusError  *error);
78 dbus_bool_t dbus_set_error       (DBusError  *error,
79                                   const char *name,
80                                   const char *message,
81                                   ...);
82 void        dbus_set_error_const (DBusError  *error,
83                                   const char *name,
84                                   const char *message); 
85                                    
86 void        dbus_set_result       (DBusResultCode *code_address,
87                                    DBusResultCode  code);
88 const char* dbus_result_to_string (DBusResultCode  code);
89
90 DBUS_END_DECLS;
91
92 #endif /* DBUS_ERROR_H */