From cfcf7e6516de771bff1feb1f7be8a3e0d5e03358 Mon Sep 17 00:00:00 2001 From: Denis Kenzior Date: Tue, 22 Sep 2009 10:59:17 -0500 Subject: Simplify: Use dbus_message_iter_get_args --- src/call-meter.c | 15 +++++---------- 1 file changed, 5 insertions(+), 10 deletions(-) (limited to 'src/call-meter.c') diff --git a/src/call-meter.c b/src/call-meter.c index 45c41c51..e264029c 100644 --- a/src/call-meter.c +++ b/src/call-meter.c @@ -606,26 +606,21 @@ static DBusMessage *cm_acm_reset(DBusConnection *conn, DBusMessage *msg, void *data) { struct ofono_call_meter *cm = data; - DBusMessageIter iter; const char *pin2; + if (!cm->driver->acm_reset) + return __ofono_error_not_implemented(msg); + if (cm->pending) return __ofono_error_busy(msg); - if (!dbus_message_iter_init(msg, &iter)) + if (dbus_message_get_args(msg, NULL, DBUS_TYPE_STRING, &pin2, + DBUS_TYPE_INVALID) == FALSE) return __ofono_error_invalid_args(msg); - if (dbus_message_iter_get_arg_type(&iter) != DBUS_TYPE_STRING) - return __ofono_error_invalid_args(msg); - - dbus_message_iter_get_basic(&iter, &pin2); - if (!is_valid_pin(pin2)) return __ofono_error_invalid_format(msg); - if (!cm->driver->acm_reset) - return __ofono_error_not_implemented(msg); - cm->pending = dbus_message_ref(msg); cm->driver->acm_reset(cm, pin2, acm_reset_callback, cm); -- cgit v1.2.3