diff options
author | Jeremy Lainé <jeremy.laine@m4x.org> | 2008-12-15 11:25:57 +0100 |
---|---|---|
committer | Jeremy Lainé <jeremy.laine@m4x.org> | 2008-12-15 11:25:57 +0100 |
commit | 14f8f793b6a3de55e352b4b7d2099fed537e71ff (patch) | |
tree | 8b9ec1516a9db22ff93a3bd190d44091651d6f25 | |
parent | 45169babbbc9d5a7872aabb4a01ae207615e7197 (diff) |
dnsmasq-dbus: add patch for DBus introspection
-rw-r--r-- | packages/dnsmasq/dnsmasq-dbus_2.46.bb | 3 | ||||
-rw-r--r-- | packages/dnsmasq/files/dbus_introspection.patch | 63 |
2 files changed, 66 insertions, 0 deletions
diff --git a/packages/dnsmasq/dnsmasq-dbus_2.46.bb b/packages/dnsmasq/dnsmasq-dbus_2.46.bb index d03dbdb06e..f6070a1987 100644 --- a/packages/dnsmasq/dnsmasq-dbus_2.46.bb +++ b/packages/dnsmasq/dnsmasq-dbus_2.46.bb @@ -2,9 +2,12 @@ require dnsmasq.inc +PR = "r1" DEPENDS = "dbus" EXTRA_OEMAKE = "COPTS=-DHAVE_DBUS" +SRC_URI += "file://dbus_introspection.patch;patch=1" + do_install_append () { install -d ${D}${sysconfdir}/dbus-1/system.d install -m 644 dbus/dnsmasq.conf ${D}${sysconfdir}/dbus-1/system.d/ diff --git a/packages/dnsmasq/files/dbus_introspection.patch b/packages/dnsmasq/files/dbus_introspection.patch new file mode 100644 index 0000000000..52cbb6e25b --- /dev/null +++ b/packages/dnsmasq/files/dbus_introspection.patch @@ -0,0 +1,63 @@ +diff -urN dnsmasq-2.46.orig/src/dbus.c dnsmasq-2.46/src/dbus.c +--- dnsmasq-2.46.orig/src/dbus.c 2008-11-14 21:02:08.000000000 +0100 ++++ dnsmasq-2.46/src/dbus.c 2008-12-15 10:45:48.000000000 +0100 +@@ -21,6 +21,42 @@ + #define DBUS_API_SUBJECT_TO_CHANGE + #include <dbus/dbus.h> + ++const char* introspection_xml = ++"<!DOCTYPE node PUBLIC \"-//freedesktop//DTD D-BUS Object Introspection 1.0//EN\"\n" ++"\"http://www.freedesktop.org/standards/dbus/1.0/introspect.dtd\">\n" ++"<node name=\"" DNSMASQ_PATH "\">\n" ++" <interface name=\"org.freedesktop.DBus.Introspectable\">\n" ++" <method name=\"Introspect\">\n" ++" <arg name=\"data\" direction=\"out\" type=\"s\"/>\n" ++" </method>\n" ++" </interface>\n" ++" <interface name=\"" DNSMASQ_SERVICE "\">\n" ++" <method name=\"ClearCache\">\n" ++" </method>\n" ++" <method name=\"GetVersion\">\n" ++" <arg name=\"version\" direction=\"out\" type=\"s\"/>\n" ++" </method>\n" ++" <method name=\"SetServers\">\n" ++" <arg name=\"servers\" direction=\"in\" type=\"av\"/>\n" ++" </method>\n" ++" <signal name=\"DhcpLeaseAdded\">\n" ++" <arg name=\"ipaddr\" type=\"s\"/>\n" ++" <arg name=\"hwaddr\" type=\"s\"/>\n" ++" <arg name=\"hostname\" type=\"s\"/>\n" ++" </signal>\n" ++" <signal name=\"DhcpLeaseDeleted\">\n" ++" <arg name=\"ipaddr\" type=\"s\"/>\n" ++" <arg name=\"hwaddr\" type=\"s\"/>\n" ++" <arg name=\"hostname\" type=\"s\"/>\n" ++" </signal>\n" ++" <signal name=\"DhcpLeaseUpdated\">\n" ++" <arg name=\"ipaddr\" type=\"s\"/>\n" ++" <arg name=\"hwaddr\" type=\"s\"/>\n" ++" <arg name=\"hostname\" type=\"s\"/>\n" ++" </signal>\n" ++" </interface>\n" ++"</node>\n"; ++ + struct watch { + DBusWatch *watch; + struct watch *next; +@@ -229,7 +265,15 @@ + { + char *method = (char *)dbus_message_get_member(message); + +- if (strcmp(method, "GetVersion") == 0) ++ if (dbus_message_is_method_call(message, DBUS_INTERFACE_INTROSPECTABLE, "Introspect")) ++ { ++ DBusMessage *reply = dbus_message_new_method_return(message); ++ ++ dbus_message_append_args(reply, DBUS_TYPE_STRING, &introspection_xml, DBUS_TYPE_INVALID); ++ dbus_connection_send (connection, reply, NULL); ++ dbus_message_unref (reply); ++ } ++ else if (strcmp(method, "GetVersion") == 0) + { + char *v = VERSION; + DBusMessage *reply = dbus_message_new_method_return(message); |