2003-02-13 Anders Carlsson <andersca@codefactory.se>
[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 };
46
47 typedef enum
48 {
49   DBUS_RESULT_SUCCESS,         /**< Operation was successful. */
50   DBUS_RESULT_FAILED,          /**< Operation failed for unspecified reason. */
51   DBUS_RESULT_NO_MEMORY,       /**< Operation failed for lack of memory. */
52   DBUS_RESULT_IO_ERROR,        /**< Operation failed because of an IO error,
53                                 *   typically the other end closed the
54                                 *   connection.
55                                 */
56   DBUS_RESULT_BAD_ADDRESS,     /**< Address was bad, could not be parsed. */
57   DBUS_RESULT_NOT_SUPPORTED,   /**< Feature is not supported. */
58   DBUS_RESULT_LIMITS_EXCEEDED, /**< Some kernel resource limit exceeded. */
59   DBUS_RESULT_ACCESS_DENIED,   /**< Some sort of permissions/security problem. */
60   DBUS_RESULT_AUTH_FAILED,     /**< Could not authenticate. */
61   DBUS_RESULT_NO_SERVER,       /**< No one listening on the other end. */
62   DBUS_RESULT_TIMEOUT,         /**< Timed out trying to connect. */
63   DBUS_RESULT_NO_NETWORK,      /**< Can't find the network */
64   DBUS_RESULT_ADDRESS_IN_USE,  /**< Someone's already using the address */
65   DBUS_RESULT_DISCONNECTED,    /**< No more connection. */
66   DBUS_RESULT_INVALID_ARGS,    /**< One or more invalid arguments encountered. */
67   DBUS_RESULT_NO_REPLY,        /**< Did not get a reply message. */
68   DBUS_RESULT_FILE_NOT_FOUND   /**< File doesn't exist */
69 } DBusResultCode;
70
71 void        dbus_error_init      (DBusError  *error);
72 void        dbus_error_free      (DBusError  *error);
73 dbus_bool_t dbus_set_error       (DBusError  *error,
74                                   const char *name,
75                                   const char *message,
76                                   ...);
77 void        dbus_set_error_const (DBusError  *error,
78                                   const char *name,
79                                   const char *message);
80
81                            
82                                    
83 void        dbus_set_result       (DBusResultCode *code_address,
84                                    DBusResultCode  code);
85 const char* dbus_result_to_string (DBusResultCode  code);
86
87 DBUS_END_DECLS;
88
89 #endif /* DBUS_ERROR_H */