[systemd-devel] [PATCH] buildsys: allow building without libnotify
Kay Sievers
kay.sievers at vrfy.org
Thu Nov 25 15:45:22 PST 2010
On Thu, 2010-11-25 at 21:53 +0300, Andrey Borzenkov wrote:
> On Thu, Nov 25, 2010 at 8:49 PM, Kay Sievers <kay.sievers at vrfy.org> wrote:
> > On Wed, 2010-11-24 at 21:20 +0100, Lennart Poettering wrote:
> >> On Wed, 24.11.10 11:57, Kay Sievers (kay.sievers at vrfy.org) wrote:
> >> > On Wed, Nov 24, 2010 at 08:36, Thierry Reding
> >> > <thierry.reding at avionic-design.de> wrote:
> >> > > This patch makes the libnotify dependency optional and doesn't build the
> >> > > systemd-gnome-ask-password-agent utility if libnotify is not available.
> >> > >
> >> > > Since libnotify >= 0.7.0 requires gtk+-3.0, this patch may be useful for
> >> > > environments where upgrading Gtk is not an option.
> >> >
> >> > Yeah, would be good to solve that. Maybe that's the simplest way to do it.
> >> >
> >> > One other option would be to use some #ifdef in vala und also support
> >> > the still common older libnotify.
> >>
> >> I'd be happy to take a patch which uses vala's new ifdef support to
> >> make the gtk stuff buildable on both old and new libnotify. If somebody
> >> cares enough.
> >
> > Untested and really ugly. :)
> >
>
> tested with vala 0.10.1 and libnotify 0.4.5.
>
> Cannot comment on ugliness :)
Here is an updated patch. Seems to work here with the old libnotify, but
'make distcheck' still fails.
Kay
diff --git a/Makefile.am b/Makefile.am
index 471954b..9e1b117 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -965,6 +965,11 @@ systemd_gnome_ask_password_agent_VALAFLAGS = \
--pkg=libnotify \
-g
+if LIBNOTIFY07
+systemd_gnome_ask_password_agent_VALAFLAGS += \
+ -D LIBNOTIFY07
+endif
+
systemd_gnome_ask_password_agent_LDADD = \
$(DBUSGLIB_LIBS) \
$(LIBNOTIFY_LIBS) \
diff --git a/configure.ac b/configure.ac
index 5a6f3c7..dfbce11 100644
--- a/configure.ac
+++ b/configure.ac
@@ -259,12 +259,16 @@ if test "$have_gtk" = "yes"; then
AC_SUBST(DBUSGLIB_CFLAGS)
AC_SUBST(DBUSGLIB_LIBS)
- PKG_CHECK_MODULES(LIBNOTIFY, [ libnotify >= 0.7.0 ])
+ PKG_CHECK_MODULES(LIBNOTIFY, [ libnotify >= 0.7.0 ],
+ [ libnotify07=yes ],
+ [ PKG_CHECK_MODULES(LIBNOTIFY, [ libnotify ]) ]
+ )
+ AM_CONDITIONAL(LIBNOTIFY07, [ test "$libnotify07" = "yes" ])
AC_SUBST(LIBNOTIFY_CFLAGS)
AC_SUBST(LIBNOTIFY_LIBS)
fi
-AM_PROG_VALAC([0.11])
+AM_PROG_VALAC([0.10])
AC_SUBST(VAPIDIR)
AM_CONDITIONAL(HAVE_VALAC, test x"$VALAC" != x)
diff --git a/src/gnome-ask-password-agent.vala b/src/gnome-ask-password-agent.vala
index 6cab6f9..61bbba0 100644
--- a/src/gnome-ask-password-agent.vala
+++ b/src/gnome-ask-password-agent.vala
@@ -38,8 +38,13 @@ public class PasswordDialog : Dialog {
set_default_response(ResponseType.OK);
set_icon_name(icon);
+#if LIBNOTIFY07
add_button(Stock.CANCEL, ResponseType.CANCEL);
add_button(Stock.OK, ResponseType.OK);
+#else
+ add_button(STOCK_CANCEL, ResponseType.CANCEL);
+ add_button(STOCK_OK, ResponseType.OK);
+#endif
Container content = (Container) get_content_area();
@@ -181,7 +186,12 @@ public class MyStatusIcon : StatusIcon {
set_visible(true);
+#if LIBNOTIFY07
Notification n = new Notification(title, message, icon);
+#else
+ Notification n = new Notification(title, message, icon, null);
+ n.attach_to_status_icon(this);
+#endif
n.set_timeout(5000);
n.show();
@@ -225,7 +235,11 @@ public class MyStatusIcon : StatusIcon {
OutputStream stream = new UnixOutputStream(to_process, true);
+#if LIBNOTIFY07
stream.write(password.data, null);
+#else
+ stream.write(password, password.length, null);
+#endif
}
}
More information about the systemd-devel
mailing list