hal/hald hald_dbus.c,1.36,1.37

Kay Sievers kay at freedesktop.org
Thu Jul 7 09:19:22 PDT 2005


Update of /cvs/hal/hal/hald
In directory gabe:/tmp/cvs-serv22747/hald

Modified Files:
	hald_dbus.c 
Log Message:
2005-07-07  Kay Sievers  <kay.sievers at vrfy.org>

        * hald/hald_dbus.c: (raise_error), (raise_no_such_device),
        (raise_no_such_property), (raise_property_type_error),
        (raise_syntax), (raise_device_not_locked),
        (raise_device_already_locked), (raise_permission_denied),
        (foreach_device_get_udi), (device_send_signal_condition),
        (local_server_message_handler):
        Unify the error handling into one common function.
        Thanks to Steffen Winterfeldt <snwint at suse.de>.



Index: hald_dbus.c
===================================================================
RCS file: /cvs/hal/hal/hald/hald_dbus.c,v
retrieving revision 1.36
retrieving revision 1.37
diff -u -d -r1.36 -r1.37
--- hald_dbus.c	23 May 2005 14:06:27 -0000	1.36
+++ hald_dbus.c	7 Jul 2005 16:19:16 -0000	1.37
@@ -40,11 +40,19 @@
 #include "hald_dbus.h"
 #include "device.h"
 #include "device_store.h"
+#include "device_info.h"
 #include "logger.h"
 #include "osspec.h"
+#include "util.h"
 
 static DBusConnection *dbus_connection = NULL;
 
+static void
+raise_error (DBusConnection *connection,
+	     DBusMessage *in_reply_to,
+	     const char *error_name,
+	     char *format, ...) __attribute__((format (printf, 4, 5)));
+
 /**
  * @defgroup DaemonErrors Error conditions
  * @ingroup HalDaemon
@@ -52,24 +60,29 @@
  * @{
  */
 
-/** Raise the org.freedesktop.Hal.NoSuchDevice error
+/** Raise HAL error
  *
  *  @param  connection          D-Bus connection
  *  @param  in_reply_to         message to report error on
- *  @param  udi                 Unique device id given
+ *  @param  error_name          D-Bus error name
+ *  @param  format              printf-style format for error message
  */
 static void
-raise_no_such_device (DBusConnection * connection,
-		      DBusMessage * in_reply_to, const char *udi)
+raise_error (DBusConnection *connection,
+	     DBusMessage *in_reply_to,
+	     const char *error_name,
+	     char *format, ...)
 {
 	char buf[512];
 	DBusMessage *reply;
 
-	snprintf (buf, 511, "No device with id %s", udi);
+	va_list args;
+	va_start(args, format);
+	vsnprintf(buf, sizeof buf, format, args);
+	va_end(args);
+
 	HAL_WARNING ((buf));
-	reply = dbus_message_new_error (in_reply_to,
-					"org.freedesktop.Hal.NoSuchDevice",
-					buf);
+	reply = dbus_message_new_error (in_reply_to, error_name, buf);
 	if (reply == NULL)
 		DIE (("No memory"));
 	if (!dbus_connection_send (connection, reply, NULL))
@@ -77,6 +90,24 @@
 	dbus_message_unref (reply);
 }
 
+/** Raise the org.freedesktop.Hal.NoSuchDevice error
+ *
+ *  @param  connection          D-Bus connection
+ *  @param  in_reply_to         message to report error on
+ *  @param  udi                 Unique device id given
+ */
+static void
+raise_no_such_device (DBusConnection *connection,
+		      DBusMessage *in_reply_to, const char *udi)
+{
+	raise_error (
+		connection, in_reply_to,
+		"org.freedesktop.Hal.NoSuchDevice",
+		"No device with id %s",
+		udi
+	);
+}
+
 /** Raise the org.freedesktop.Hal.NoSuchProperty error
  *
  *  @param  connection          D-Bus connection
@@ -85,24 +116,16 @@
  *  @param  key                 Key of the property that didn't exist
  */
 static void
-raise_no_such_property (DBusConnection * connection,
-			DBusMessage * in_reply_to,
+raise_no_such_property (DBusConnection *connection,
+			DBusMessage *in_reply_to,
 			const char *device_id, const char *key)
 {
-	char buf[512];
-	DBusMessage *reply;
-
-	snprintf (buf, 511, "No property %s on device with id %s", key,
-		  device_id);
-	/*HAL_WARNING ((buf));*/
-	reply = dbus_message_new_error (in_reply_to,
-					"org.freedesktop.Hal.NoSuchProperty",
-					buf);
-	if (reply == NULL)
-		DIE (("No memory"));
-	if (!dbus_connection_send (connection, reply, NULL))
-		DIE (("No memory"));
-	dbus_message_unref (reply);
+	raise_error (
+		connection, in_reply_to,
+		"org.freedesktop.Hal.NoSuchProperty",
+		"No property %s on device with id %s",
+		key, device_id
+	);
 }
 
 /** Raise the org.freedesktop.Hal.TypeMismatch error
@@ -113,25 +136,16 @@
  *  @param  key                 Key of the property
  */
 static void
-raise_property_type_error (DBusConnection * connection,
-			   DBusMessage * in_reply_to,
+raise_property_type_error (DBusConnection *connection,
+			   DBusMessage *in_reply_to,
 			   const char *device_id, const char *key)
 {
-	char buf[512];
-	DBusMessage *reply;
-
-	snprintf (buf, 511,
-		  "Type mismatch setting property %s on device with id %s",
-		  key, device_id);
-	HAL_WARNING ((buf));
-	reply = dbus_message_new_error (in_reply_to,
-					"org.freedesktop.Hal.TypeMismatch",
-					buf);
-	if (reply == NULL)
-		DIE (("No memory"));
-	if (!dbus_connection_send (connection, reply, NULL))
-		DIE (("No memory"));
-	dbus_message_unref (reply);
+	raise_error (
+		connection, in_reply_to,
+		"org.freedesktop.Hal.TypeMismatch",
+		"Type mismatch setting property %s on device with id %s",
+		key, device_id
+	);
 }
 
 /** Raise the org.freedesktop.Hal.SyntaxError error
@@ -142,24 +156,15 @@
  *                              the wrong signature
  */
 static void
-raise_syntax (DBusConnection * connection,
-	      DBusMessage * in_reply_to, const char *method_name)
+raise_syntax (DBusConnection *connection,
+	      DBusMessage *in_reply_to, const char *method_name)
 {
-	char buf[512];
-	DBusMessage *reply;
-
-	snprintf (buf, 511,
-		  "There is a syntax error in the invocation of "
-		  "the method %s", method_name);
-	HAL_WARNING ((buf));
-	reply = dbus_message_new_error (in_reply_to,
-					"org.freedesktop.Hal.SyntaxError",
-					buf);
-	if (reply == NULL)
-		DIE (("No memory"));
-	if (!dbus_connection_send (connection, reply, NULL))
-		DIE (("No memory"));
-	dbus_message_unref (reply);
+	raise_error (
+		connection, in_reply_to,
+		"org.freedesktop.Hal.SyntaxError",
+		"There is a syntax error in the invocation of the method %s",
+		method_name
+	);
 }
 
 /** Raise the org.freedesktop.Hal.DeviceNotLocked error
@@ -173,20 +178,12 @@
 			 DBusMessage    *in_reply_to,
 			 HalDevice      *device)
 {
-	char buf[512];
-	DBusMessage *reply;
-
-	snprintf (buf, 511, "The device %s is not locked",
-		  hal_device_get_udi (device));
-	HAL_WARNING ((buf));
-	reply = dbus_message_new_error (in_reply_to,
-					"org.freedesktop.Hal.DeviceNotLocked",
-					buf);
-
-	if (reply == NULL || !dbus_connection_send (connection, reply, NULL))
-		DIE (("No memory"));
-
-	dbus_message_unref (reply);
+	raise_error (
+		connection, in_reply_to,
+		"org.freedesktop.Hal.DeviceNotLocked",
+		"The device %s is not locked",
+		 hal_device_get_udi (device)
+	);
 }
 
 /** Raise the org.freedesktop.Hal.DeviceAlreadyLocked error
@@ -210,7 +207,6 @@
 
 	reply = dbus_message_new_error (in_reply_to,
 					"org.freedesktop.Hal.DeviceAlreadyLocked",
-					
 					reason);
 
 	if (reply == NULL || !dbus_connection_send (connection, reply, NULL))
@@ -230,19 +226,12 @@
 			 DBusMessage    *in_reply_to,
 			 const char     *reason)
 {
-	char buf[512];
-	DBusMessage *reply;
-
-	snprintf (buf, 511, "Permission denied: %s", reason);
-	HAL_WARNING ((buf));
-	reply = dbus_message_new_error (in_reply_to,
-					"org.freedesktop.Hal.PermissionDenied",
-					buf);
-
-	if (reply == NULL || !dbus_connection_send (connection, reply, NULL))
-		DIE (("No memory"));
-
-	dbus_message_unref (reply);
+	raise_error (
+		connection, in_reply_to,
+		"org.freedesktop.Hal.PermissionDenied",
+		"Permission denied: %s",
+		 reason
+	);
 }
 
 /** @} */
@@ -263,7 +252,6 @@
 	const char *udi;
 
 	udi = hal_device_get_udi (device);
-
 	dbus_message_iter_append_basic (iter, DBUS_TYPE_STRING, &udi);
 
 	return TRUE;
@@ -2032,19 +2020,19 @@
 					   "org.freedesktop.Hal.Device",
 					   "Condition");
 	dbus_message_iter_init_append (message, &iter);
-	dbus_message_iter_append_basic (&iter, 
-	                                DBUS_TYPE_STRING, 
-	                                &condition_name);
-	dbus_message_iter_append_basic (&iter, 
-	                                DBUS_TYPE_STRING, 
-	                                &condition_details);
+	dbus_message_iter_append_basic (&iter,
+					DBUS_TYPE_STRING, 
+					&condition_name);
+	dbus_message_iter_append_basic (&iter,
+					DBUS_TYPE_STRING, 
+					&condition_details);
 
 	if (!dbus_connection_send (dbus_connection, message, NULL))
 		DIE (("error broadcasting message"));
 
 	dbus_message_unref (message);
 out:
-	;
+	return;
 }
 
 
@@ -2427,7 +2415,7 @@
 	if (dbus_message_is_method_call (message, "org.freedesktop.DBus", "AddMatch")) {
 		DBusMessage *reply;
 
-                /* cheat, and handle AddMatch since libhal will try to invoke this method */
+		/* cheat, and handle AddMatch since libhal will try to invoke this method */
 		reply = dbus_message_new_method_return (message);
 		if (reply == NULL)
 			DIE (("No memory"));




More information about the hal-commit mailing list