Skip to content

Commit

Permalink
build: make gobject-introspection support optional
Browse files Browse the repository at this point in the history
Imported the introspection.m4 file in the project so we're sure the
GOBJECT_INTROSPECTION_CHECK macro can be safely used. Also build the
gir header only if introspection support is enabled.
  • Loading branch information
philn authored and sdroege committed Mar 24, 2015
1 parent f961d5b commit 838d6ee
Show file tree
Hide file tree
Showing 3 changed files with 105 additions and 6 deletions.
9 changes: 4 additions & 5 deletions configure.ac
Expand Up @@ -46,14 +46,10 @@ if test "x$enable_bridge" = xyes; then
fi fi
AM_CONDITIONAL(OWR_BRIDGE, test x$enable_bridge = xyes) AM_CONDITIONAL(OWR_BRIDGE, test x$enable_bridge = xyes)


AC_CONFIG_MACRO_DIR(m4)


# check for gobject-introspection # check for gobject-introspection
m4_ifdef([GOBJECT_INTROSPECTION_CHECK], [
GOBJECT_INTROSPECTION_CHECK([1.30.0]) GOBJECT_INTROSPECTION_CHECK([1.30.0])
],[
AM_CONDITIONAL([ENABLE_GOBJECT_INTROSPECTION], false)
])
AC_CONFIG_MACRO_DIR(m4)


m4_ifdef([GTK_DOC_CHECK], [ m4_ifdef([GTK_DOC_CHECK], [
GTK_DOC_CHECK([1.18],[--flavour no-tmpl]) GTK_DOC_CHECK([1.18],[--flavour no-tmpl])
Expand Down Expand Up @@ -148,6 +144,9 @@ AC_HELP_STRING(
esac],[enable_owr_java=no]) esac],[enable_owr_java=no])
AC_MSG_RESULT([$enable_owr_java]) AC_MSG_RESULT([$enable_owr_java])
if test "x$enable_owr_java" = xyes; then if test "x$enable_owr_java" = xyes; then
if test "x$found_introspection" != xyes; then
AC_MSG_ERROR([--enable-owr-java requires GObject-instrospection support])
fi
if test "x$enable_shared" != xyes; then if test "x$enable_shared" != xyes; then
AC_MSG_ERROR([--enable-owr-java needs --enabled-shared]) AC_MSG_ERROR([--enable-owr-java needs --enabled-shared])
fi fi
Expand Down
96 changes: 96 additions & 0 deletions m4/introspection.m4
@@ -0,0 +1,96 @@
dnl -*- mode: autoconf -*-
dnl Copyright 2009 Johan Dahlin
dnl
dnl This file is free software; the author(s) gives unlimited
dnl permission to copy and/or distribute it, with or without
dnl modifications, as long as this notice is preserved.
dnl

# serial 1

m4_define([_GOBJECT_INTROSPECTION_CHECK_INTERNAL],
[
AC_BEFORE([AC_PROG_LIBTOOL],[$0])dnl setup libtool first
AC_BEFORE([AM_PROG_LIBTOOL],[$0])dnl setup libtool first
AC_BEFORE([LT_INIT],[$0])dnl setup libtool first
dnl enable/disable introspection
m4_if([$2], [require],
[dnl
enable_introspection=yes
],[dnl
AC_ARG_ENABLE(introspection,
AS_HELP_STRING([--enable-introspection[=@<:@no/auto/yes@:>@]],
[Enable introspection for this build]),,
[enable_introspection=auto])
])dnl
AC_MSG_CHECKING([for gobject-introspection])
dnl presence/version checking
AS_CASE([$enable_introspection],
[no], [dnl
found_introspection="no (disabled, use --enable-introspection to enable)"
],dnl
[yes],[dnl
PKG_CHECK_EXISTS([gobject-introspection-1.0],,
AC_MSG_ERROR([gobject-introspection-1.0 is not installed]))
PKG_CHECK_EXISTS([gobject-introspection-1.0 >= $1],
found_introspection=yes,
AC_MSG_ERROR([You need to have gobject-introspection >= $1 installed to build AC_PACKAGE_NAME]))
],dnl
[auto],[dnl
PKG_CHECK_EXISTS([gobject-introspection-1.0 >= $1], found_introspection=yes, found_introspection=no)
dnl Canonicalize enable_introspection
enable_introspection=$found_introspection
],dnl
[dnl
AC_MSG_ERROR([invalid argument passed to --enable-introspection, should be one of @<:@no/auto/yes@:>@])
])dnl
AC_MSG_RESULT([$found_introspection])
INTROSPECTION_SCANNER=
INTROSPECTION_COMPILER=
INTROSPECTION_GENERATE=
INTROSPECTION_GIRDIR=
INTROSPECTION_TYPELIBDIR=
if test "x$found_introspection" = "xyes"; then
INTROSPECTION_SCANNER=`$PKG_CONFIG --variable=g_ir_scanner gobject-introspection-1.0`
INTROSPECTION_COMPILER=`$PKG_CONFIG --variable=g_ir_compiler gobject-introspection-1.0`
INTROSPECTION_GENERATE=`$PKG_CONFIG --variable=g_ir_generate gobject-introspection-1.0`
INTROSPECTION_GIRDIR=`$PKG_CONFIG --variable=girdir gobject-introspection-1.0`
INTROSPECTION_TYPELIBDIR="$($PKG_CONFIG --variable=typelibdir gobject-introspection-1.0)"
INTROSPECTION_CFLAGS=`$PKG_CONFIG --cflags gobject-introspection-1.0`
INTROSPECTION_LIBS=`$PKG_CONFIG --libs gobject-introspection-1.0`
INTROSPECTION_MAKEFILE=`$PKG_CONFIG --variable=datadir gobject-introspection-1.0`/gobject-introspection-1.0/Makefile.introspection
fi
AC_SUBST(INTROSPECTION_SCANNER)
AC_SUBST(INTROSPECTION_COMPILER)
AC_SUBST(INTROSPECTION_GENERATE)
AC_SUBST(INTROSPECTION_GIRDIR)
AC_SUBST(INTROSPECTION_TYPELIBDIR)
AC_SUBST(INTROSPECTION_CFLAGS)
AC_SUBST(INTROSPECTION_LIBS)
AC_SUBST(INTROSPECTION_MAKEFILE)
AM_CONDITIONAL(HAVE_INTROSPECTION, test "x$found_introspection" = "xyes")
])


dnl Usage:
dnl GOBJECT_INTROSPECTION_CHECK([minimum-g-i-version])

AC_DEFUN([GOBJECT_INTROSPECTION_CHECK],
[
_GOBJECT_INTROSPECTION_CHECK_INTERNAL([$1])
])

dnl Usage:
dnl GOBJECT_INTROSPECTION_REQUIRE([minimum-g-i-version])


AC_DEFUN([GOBJECT_INTROSPECTION_REQUIRE],
[
_GOBJECT_INTROSPECTION_CHECK_INTERNAL([$1], [require])
])
6 changes: 5 additions & 1 deletion owr/Makefile.am
Expand Up @@ -57,11 +57,15 @@ include_HEADERS = \
owr_types.h owr_types.h


noinst_HEADERS = \ noinst_HEADERS = \
Owr-0.1.gir.h \
owr_private.h \ owr_private.h \
owr_media_source_private.h \ owr_media_source_private.h \
owr_utils.h owr_utils.h


if HAVE_INTROSPECTION
noinst_HEADERS += \
Owr-0.1.gir.h
endif

pkgconfigdir = $(libdir)/pkgconfig pkgconfigdir = $(libdir)/pkgconfig
pkgconfig_DATA = openwebrtc-0.1.pc pkgconfig_DATA = openwebrtc-0.1.pc


Expand Down

0 comments on commit 838d6ee

Please sign in to comment.