diff options
-rw-r--r-- | ChangeLog | 8 | ||||
-rw-r--r-- | configure.ac | 15 | ||||
-rw-r--r-- | m4/gecko.m4 | 40 |
3 files changed, 55 insertions, 8 deletions
@@ -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 |