aboutsummaryrefslogtreecommitdiff
path: root/include/swaybar/tray/dbus.h
diff options
context:
space:
mode:
authorDrew DeVault <sir@cmpwn.com>2017-12-29 14:24:23 -0500
committerGitHub <noreply@github.com>2017-12-29 14:24:23 -0500
commit1e87c90923eef75b7d032322dfef38def944c2bb (patch)
treeed17f848e7ac95c919d23424671a8a8ad5651a86 /include/swaybar/tray/dbus.h
parentd85ad05fa857cd7d7af2c8e2c33616d7895e1955 (diff)
parent4d34bc393e7b144fbc105537f17bee329c44814d (diff)
Merge pull request #1431 from 4e554c4c/sni_sucks
Support libappindicator
Diffstat (limited to 'include/swaybar/tray/dbus.h')
-rw-r--r--include/swaybar/tray/dbus.h31
1 files changed, 31 insertions, 0 deletions
diff --git a/include/swaybar/tray/dbus.h b/include/swaybar/tray/dbus.h
index eb9cfea7..c693e6f7 100644
--- a/include/swaybar/tray/dbus.h
+++ b/include/swaybar/tray/dbus.h
@@ -5,6 +5,37 @@
#include <dbus/dbus.h>
extern DBusConnection *conn;
+enum property_status {
+ PROP_EXISTS, /* Will give iter */
+ PROP_ERROR, /* Will not give iter */
+ PROP_BAD_DATA, /* Will not give iter */
+ PROP_WRONG_SIG, /* Will give iter, please be careful */
+};
+
+/**
+ * Checks the signature of the given iter against `sig`. Prefer to
+ * `dbus_message_iter_get_signature` as this one frees the intermediate string.
+ */
+bool dbus_message_iter_check_signature(DBusMessageIter *iter, const char *sig);
+
+/**
+ * Fetches the property and calls `callback` with a message iter pointing it.
+ * Performs error handling and signature checking.
+ *
+ * Returns: true if message is successfully sent and false otherwise. If there
+ * is an error getting a property, `callback` will still be run, but with
+ * `status` set to the error.
+ *
+ * NOTE: `expected_signature` must remain valid until the message reply is
+ * received, please only use 'static signatures.
+ */
+bool dbus_get_prop_async(const char *destination,
+ const char *path,
+ const char *iface,
+ const char *prop,
+ const char *expected_signature,
+ void(*callback)(DBusMessageIter *iter, void *data, enum property_status status),
+ void *data);
/**
* Should be called in main loop to dispatch events
*/