summaryrefslogtreecommitdiff
path: root/src/dbus.c
diff options
context:
space:
mode:
authorDaniel Wagner <daniel.wagner@bmw-carit.de>2013-04-18 09:07:26 +0200
committerPatrik Flykt <patrik.flykt@linux.intel.com>2013-04-18 14:17:09 +0300
commitadf04d8c40cdd79da6bcd5a8b74ac775eaebc5e0 (patch)
treed58a70af5610dece5f503322c4c0b9e2e6ded1dd /src/dbus.c
parentc6025eca557d82d9514108ede6ba0aa266746e64 (diff)
downloadconnman-adf04d8c40cdd79da6bcd5a8b74ac775eaebc5e0.tar.gz
connman-adf04d8c40cdd79da6bcd5a8b74ac775eaebc5e0.tar.bz2
connman-adf04d8c40cdd79da6bcd5a8b74ac775eaebc5e0.zip
dbus: Refactor callback helper struct
The helper struct will be used by a new dbus function which uses a different callback signature. Therefore, we need to use a void pointer for storing the callback.
Diffstat (limited to 'src/dbus.c')
-rw-r--r--src/dbus.c15
1 files changed, 8 insertions, 7 deletions
diff --git a/src/dbus.c b/src/dbus.c
index 70af6173..590bafac 100644
--- a/src/dbus.c
+++ b/src/dbus.c
@@ -406,8 +406,8 @@ dbus_bool_t __connman_dbus_append_objpath_dict_array(DBusMessage *msg,
return TRUE;
}
-struct selinux_data {
- connman_dbus_get_context_cb_t func;
+struct callback_data {
+ void *cb;
void *user_data;
};
@@ -448,7 +448,8 @@ static unsigned char *parse_context(DBusMessage *msg)
static void selinux_get_context_reply(DBusPendingCall *call, void *user_data)
{
- struct selinux_data *data = user_data;
+ struct callback_data *data = user_data;
+ connman_dbus_get_context_cb_t cb = data->cb;
DBusMessage *reply;
unsigned char *context = NULL;
int err = 0;
@@ -470,7 +471,7 @@ static void selinux_get_context_reply(DBusPendingCall *call, void *user_data)
context = parse_context(reply);
done:
- (*data->func)(context, data->user_data, err);
+ (*cb)(context, data->user_data, err);
g_free(context);
@@ -484,7 +485,7 @@ int connman_dbus_get_selinux_context(DBusConnection *connection,
connman_dbus_get_context_cb_t func,
void *user_data)
{
- struct selinux_data *data;
+ struct callback_data *data;
DBusPendingCall *call;
DBusMessage *msg = NULL;
int err;
@@ -492,7 +493,7 @@ int connman_dbus_get_selinux_context(DBusConnection *connection,
if (func == NULL)
return -EINVAL;
- data = g_try_new0(struct selinux_data, 1);
+ data = g_try_new0(struct callback_data, 1);
if (data == NULL) {
DBG("Can't allocate data structure");
return -ENOMEM;
@@ -523,7 +524,7 @@ int connman_dbus_get_selinux_context(DBusConnection *connection,
goto err;
}
- data->func = func;
+ data->cb = func;
data->user_data = user_data;
dbus_pending_call_set_notify(call, selinux_get_context_reply,