aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--ChangeLog8
-rw-r--r--configure.ac15
-rw-r--r--m4/gecko.m440
3 files changed, 55 insertions, 8 deletions
diff --git a/ChangeLog b/ChangeLog
index 1b8c6c342..cfacd7881 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,11 @@
+2006-03-05 Christian Persch <chpe@cvs.gnome.org>
+
+ * configure.ac:
+ * m4/gecko.m4:
+
+ Before running any test programs, check that we can compile and run
+ any XPCOM programs at all.
+
2006-03-03 Jean-François Rameau <jframeau@cvs.gnome.org>
* configure.ac:
diff --git a/configure.ac b/configure.ac
index 1061cefe7..44d5acfe6 100644
--- a/configure.ac
+++ b/configure.ac
@@ -187,6 +187,11 @@ AC_SUBST([GECKO_LIBS])
# now tests for mozilla API variance
# **********************************
+# First build a test program to see whether compiling and running XPCOM
+# programs works at all, so we don't get false test failures below
+
+GECKO_XPCOM_PROGRAM_CHECK
+
# Changed from PRUnichar* to nsAString& in 1.8a1 and on aviary branch
AC_MSG_CHECKING([whether nsIFilePicker methods expect nsAString&])
@@ -344,9 +349,15 @@ if test "x$enable_filepicker" = "xyes"; then
fi
# Check for nsINonBlockingAlertService
+# Added in 1.8.1 and 1.9
GECKO_CHECK_HEADERS([windowwatcher],[nsINonBlockingAlertService.h])
+# Check for nsIGlobalHistory3
+# Added in 1.8.1 and 1.9
+
+GECKO_CHECK_HEADERS([docshell],[nsIGlobalHistory3.h])
+
# Check for some contractIDs that we need but are provided by extensions
# which may or may not have been built.
@@ -361,10 +372,6 @@ fi
GECKO_CHECK_CONTRACTIDS([$REQUIRED_CONTRACTS],
[],[AC_MSG_ERROR([$gecko_cv_gecko needs to be compiled with at least --enable-extensions=default,$REQUIRED_EXTENSIONS])])
-# Check for nsIGlobalHistory3
-
-GECKO_CHECK_HEADERS([docshell],[nsIGlobalHistory3.h])
-
# Needed since 1.8b2
# Define this down here so it doesn't affect the API checks above
diff --git a/m4/gecko.m4 b/m4/gecko.m4
index cf5ef77f3..e0926c029 100644
--- a/m4/gecko.m4
+++ b/m4/gecko.m4
@@ -365,7 +365,7 @@ AC_DEFUN([GECKO_RUN_IFELSE],[_GECKO_DISPATCH([AC_RUN_IFELSE],$@)])
# ***************************************************************************
# ***************************************************************************
-# GECKO_XPCOMPROGRAM([PROLOGUE], [BODY])
+# GECKO_XPCOM_PROGRAM([PROLOGUE], [BODY])
#
# Produce a template C++ program which starts XPCOM up and shuts it down after
# the BODY part has run. In BODY, the the following variables are predeclared:
@@ -373,7 +373,7 @@ AC_DEFUN([GECKO_RUN_IFELSE],[_GECKO_DISPATCH([AC_RUN_IFELSE],$@)])
# nsresult rv
# PRBool retval (set to PR_FALSE)
#
-# The program's exit status will be EXIT_FAILURE if you retval is PR_FALSE;
+# The program's exit status will be EXIT_FAILURE if retval is PR_FALSE;
# else it will be EXIT_SUCCESS.
#
# To jump out of the BODY and exit the test program, you can use |break|.
@@ -431,6 +431,38 @@ exit (retval ? EXIT_SUCCESS : EXIT_FAILURE);
# ***************************************************************************
# ***************************************************************************
+# GECKO_XPCOM_PROGRAM_CHECK([ACTION-IF-FOUND], [ACTION-IF-NOT-FOUND], [ACTION-IF-CROSS-COMPILING])
+#
+# Checks whether we can build and run any XPCOM test programs at all
+
+AC_DEFUN([GECKO_XPCOM_PROGRAM_CHECK],
+[AC_REQUIRE([GECKO_INIT])dnl
+
+AC_CACHE_CHECK([whether we can compile and run XPCOM programs],
+[gecko_cv_xpcom_program_check],
+[
+gecko_cv_xpcom_program_check=no
+
+GECKO_RUN_IFELSE([],
+ [GECKO_XPCOM_PROGRAM([],[[retval = PR_TRUE;]])],
+ [gecko_cv_xpcom_program_check=yes],
+ [gecko_cv_xpcom_program_check=no],
+ [gecko_cv_xpcom_program_check=maybe])
+])
+
+if test "$gecko_cv_xpcom_program_check" = "yes"; then
+ ifelse([$2],,[:],[$2])
+else
+ ifelse([$3],,[AC_MSG_FAILURE([Cannot compile and run XPCOM programs])],
+ [$3])
+fi
+
+]) # GECKO_XPCOM_PROGRAM_CHECK
+
+# ***************************************************************************
+# ***************************************************************************
+# ***************************************************************************
+
# GECKO_CHECK_CONTRACTID(CONTRACTID, [ACTION-IF-FOUND], [ACTION-IF-NOT-FOUND])
#
# Checks wheter CONTRACTID is a registered contract ID
@@ -467,7 +499,7 @@ retval = NS_SUCCEEDED (rv) && isRegistered;
if test AS_VAR_GET(gecko_cv_have_CID) = "yes"; then
ifelse([$2],,[:],[$2])
else
- ifelse([$3],,[AC_MSG_FAILURE([dnl
+ ifelse([$3],,[AC_MSG_ERROR([dnl
Contract ID "$1" is not registered, but $PACKAGE_NAME depends on it.])],
[$3])
fi
@@ -495,7 +527,7 @@ done
if test "$result" = "yes"; then
ifelse([$2],,[:],[$2])
else
- ifelse([$3],,[AC_MSG_FAILURE([dnl
+ ifelse([$3],,[AC_MSG_ERROR([dnl
Contract ID "$as_contractid" is not registered, but $PACKAGE_NAME depends on it.])],
[$3])
fi