]> matita.cs.unibo.it Git - helm.git/blobdiff - helm/configuration/configure.in
ocaml 3.09 transition
[helm.git] / helm / configuration / configure.in
index 1e48c932e2d7fd13bb7164a4a9dfdeb5b4de2a2e..03c923e9d4d89a9ec7f5231a288094db40e67cc2 100644 (file)
@@ -1,5 +1,23 @@
 AC_INIT(etc/configuration.xml.in)
 
+PACKAGE=helm_configuration
+
+HELM_MAJOR_VERSION=0
+HELM_MINOR_VERSION=0
+HELM_MICRO_VERSION=2
+HELM_VERSION=$HELM_MAJOR_VERSION.$HELM_MINOR_VERSION.$HELM_MICRO_VERSION
+VERSION=$HELM_VERSION
+
+DEFAULT_HELM_VAR_DIR=/var/local/helm
+DEFAULT_HELM_TMP_DIR=/tmp
+
+AC_ARG_ENABLE(
+       defaults,
+       [  --enable-defaults[=ARG] if yes then use defaults (don't ask user) [default=auto]],
+       USE_DEFAULTS=$enableval,
+       USE_DEFAULTS=auto
+)
+
 if test "x$prefix" != xNONE; then
   RESOLVED_PREFIX=$prefix
 else
@@ -13,133 +31,156 @@ else
 fi
 
 dnl General
-AC_MSG_CHECKING("for the lib/helm dir")
+HELM_BIN_DIR=$RESOLVED_EXEC_PREFIX/bin
 HELM_LIB_DIR=$RESOLVED_EXEC_PREFIX/lib/helm
-AC_MSG_RESULT($HELM_LIB_DIR)
-
-AC_MSG_CHECKING("for the etc/helm dir")
 HELM_ETC_DIR=$RESOLVED_PREFIX/etc/helm
-AC_MSG_RESULT($HELM_ETC_DIR)
-
-AC_MSG_CHECKING("for the lib/helm dir")
 HELM_SHARE_DIR=$RESOLVED_PREFIX/share/helm
-AC_MSG_RESULT($HELM_SHARE_DIR)
 
-dnl Only for GtkMathview XML configuration
-HELM_DICTIONARY_PATH=$HELM_ETC_DIR/helm-dictionary.xml
+dnl Checking for the variable directory
+if test $USE_DEFAULTS != yes; then
+       echo
+       echo "Now you have to choose a suitable directory for variable files."
+       echo "Normally, this directory would be something like /var/local/helm, you"
+       echo "have to be sure that the directory (and the subdirectories in it)"
+       echo "is world-writable."
+       echo
+       echo -n "[[$DEFAULT_HELM_VAR_DIR]] ? "
+       read HELM_VAR_DIR
+       echo
+       if test x$HELM_VAR_DIR = x; then
+               HELM_VAR_DIR="/var/local/helm"
+       fi
+else
+       HELM_VAR_DIR=$DEFAULT_HELM_VAR_DIR
+fi
+
+AC_MSG_CHECKING(for HELM variable dir)
+AC_MSG_RESULT($HELM_VAR_DIR)
+
+dnl Checking for the /tmp directory
+DEFAULTS=$USE_DEFAULTS
+if test $DEFAULTS = auto; then
+       if test -d $DEFAULT_HELM_TMP_DIR ; then
+               HELM_TMP_DIR=$DEFAULT_HELM_TMP_DIR
+       else
+               DEFAULTS=no
+       fi
+fi
 
-AC_CHECK_PROG(HAVE_GTKMATHVIEW_CONFIG,gtkmathview-config,yes,no)
-if test $HAVE_GTKMATHVIEW_CONFIG = no ; then
+if test $DEFAULTS = no; then
+       echo
+       echo "Please, tell me the name of a directory which can be used to store"
+       echo "temporary files (normally it is something like /tmp)"
+       echo
+       echo -n "[[$DEFAULT_HELM_TMP_DIR]]"
+       read HELM_TMP_DIR
+       echo
+       if test x$HELM_TMP_DIR = x; then
+               HELM_TMP_DIR=$DEFAULT_HELM_TMP_DIR
+       fi
+else
+       HELM_TMP_DIR=$DEFAULT_HELM_TMP_DIR
+fi
+
+AC_MSG_CHECKING(for $HELM_TMP_DIR)
+if test ! -d $HELM_TMP_DIR; then
+       AC_MSG_RESULT(no)
+       AC_MSG_ERROR(please check your installation)
+fi
+AC_MSG_RESULT(ok)
+
+dnl Checks for GtkMathView
+AC_CHECK_PROG(HAVE_GTKMATHVIEW_CONFIG, gtkmathview-config, yes, no)
+if test $HAVE_GTKMATHVIEW_CONFIG = no; then
    AC_MSG_ERROR(Could not find gtkmathview-config)
 fi
 GTKMATHVIEW_PREFIX=`gtkmathview-config --prefix`
 
-AC_MSG_CHECKING("for dictionary.xml")
-AC_CACHE_VAL(helm_cv_GTKMATHVIEW_DICTIONARY_PATH,
-   helm_cv_GTKMATHVIEW_DICTIONARY_PATH=$GTKMATHVIEW_PREFIX/share/gtkmathview/dictionary.xml
-   if test ! -f $helm_cv_GTKMATHVIEW_DICTIONARY_PATH ; then
-      echo ""
-      AC_MSG_WARN(Could not find dictionary.xml. Where is it?)
-      read helm_cv_GTKMATHVIEW_DICTIONARY_PATH
-      RES="Asked"
-   fi
+AC_CACHE_CHECK(
+  for dictionary.xml,
+  helm_cv_GTKMATHVIEW_DICTIONARY_PATH,
+  helm_cv_GTKMATHVIEW_DICTIONARY_PATH=$GTKMATHVIEW_PREFIX/share/gtkmathview/dictionary.xml
+  if test ! -f $helm_cv_GTKMATHVIEW_DICTIONARY_PATH; then
+    read helm_cv_GTKMATHVIEW_DICTIONARY_PATH
+  fi
 )
 GTKMATHVIEW_DICTIONARY_PATH=$helm_cv_GTKMATHVIEW_DICTIONARY_PATH
-if test "$RES" != "Asked" ; then
-   AC_MSG_RESULT($GTKMATHVIEW_DICTIONARY_PATH)
-fi
-AC_CACHE_SAVE
-
-AC_MSG_CHECKING("for font-configuration.xml")
-RES=""
-AC_CACHE_VAL(helm_cv_GTKMATHVIEW_FONT_CONFIGURATION_PATH,
-   helm_cv_GTKMATHVIEW_FONT_CONFIGURATION_PATH=$GTKMATHVIEW_PREFIX/share/gtkmathview/font-configuration.xml
-   if test ! -f $helm_cv_GTKMATHVIEW_FONT_CONFIGURATION_PATH ; then
-      echo ""
-      AC_MSG_WARN(Could not find font-configuration.xml. Where is it?)
-      read helm_cv_GTKMATHVIEW_FONT_CONFIGURATION_PATH
-      RES="Asked"
-   fi
+
+AC_CACHE_CHECK(
+  for font-configuration.xml,
+  helm_cv_GTKMATHVIEW_FONT_CONFIGURATION_PATH,
+  helm_cv_GTKMATHVIEW_FONT_CONFIGURATION_PATH=$GTKMATHVIEW_PREFIX/share/gtkmathview/font-configuration.xml
+  if test ! -f $helm_cv_GTKMATHVIEW_FONT_CONFIGURATION_PATH; then
+    read helm_cv_GTKMATHVIEW_FONT_CONFIGURATION_PATH
+  fi
 )
 GTKMATHVIEW_FONT_CONFIGURATION_PATH=$helm_cv_GTKMATHVIEW_FONT_CONFIGURATION_PATH
-if test "$RES" != "Asked" ; then
-   AC_MSG_RESULT($GTKMATHVIEW_FONT_CONFIGURATION_PATH)
-fi
-AC_CACHE_SAVE
-
-AC_MSG_CHECKING("for t1.config")
-RES=""
-AC_CACHE_VAL(helm_cv_GTKMATHVIEW_T1_CONFIG_FILE,
-   helm_cv_GTKMATHVIEW_T1_CONFIG_FILE=$GTKMATHVIEW_PREFIX/share/gtkmathview/t1.config
-   if test ! -f $helm_cv_GTKMATHVIEW_T1_CONFIG_FILE ; then
-      echo ""
-      AC_MSG_WARN(Could not find t1.config. Where is it?)
-      read helm_cv_GTKMATHVIEW_T1_CONFIG_FILE
-      RES="Asked"
-   fi
+
+AC_CACHE_CHECK(
+  for t1lib configuration file,
+    helm_cv_GTKMATHVIEW_T1_CONFIG_FILE,
+    helm_cv_GTKMATHVIEW_T1_CONFIG_FILE=$GTKMATHVIEW_PREFIX/share/gtkmathview/t1.config
+    if test ! -f $helm_cv_GTKMATHVIEW_T1_CONFIG_FILE; then
+      read GTKMATHVIEW_T1_CONFIG_FILE
+    fi
 )
 GTKMATHVIEW_T1_CONFIG_FILE=$helm_cv_GTKMATHVIEW_T1_CONFIG_FILE
-if test "$RES" != "Asked" ; then
-   AC_MSG_RESULT($GTKMATHVIEW_T1_CONFIG_FILE)
-fi
-AC_CACHE_SAVE
 
+HELM_DICTIONARY_PATH=$HELM_ETC_DIR/helm-dictionary.xml
 HELM_FONT_CONFIGURATION_PATH=$HELM_ETC_DIR/helm-font-configuration.xml
 
 dnl Only for HELM XML configuration
+HELM_LIBRARY_DIR=$HELM_VAR_DIR/library
+HELM_SERVERS_FILE=$HELM_VAR_DIR/servers.txt
+HELM_URIS_DBM=$HELM_VAR_DIR/urls_of_uris.db
 
-AC_MSG_CHECKING("for the library path")
-RES=""
-AC_CACHE_VAL(helm_cv_HELM_LIBRARY_DIR,
-  echo "Where should I put the downloaded library? Note: the \"library\" subdirectory and all the files and subdirectories recursively in it should be world writeable"
-  read helm_cv_HELM_LIBRARY_DIR
-  RES="Asked"
-)
-HELM_LIBRARY_DIR=$helm_cv_HELM_LIBRARY_DIR
-if test "$RES" != "Asked" ; then
-   AC_MSG_RESULT($HELM_LIBRARY_DIR)
-fi
-AC_CACHE_SAVE
-
+dnl CSC: FIXME: getters should download the DTDs
+HELM_DTD_DIR=$HELM_SHARE_DIR/dtd
+HELM_STYLE_DIR=$HELM_SHARE_DIR/style
 
-CONFIGURATION_HELM_DIR=$HELM_LIBRARY_DIR/library
+dnl HELM prefixes
+AC_SUBST(RESOLVED_PREFIX)
+AC_SUBST(RESOLVED_EXEC_PREFIX)
 
-dnl CSC: ERROR: getters should download the DTDs
-CONFIGURATION_DTD_DIR=$HELM_SHARE_DIR/dtd
-
-CONFIGURATION_SERVERS_FILE=$HELM_LIBRARY_DIR/servers.txt
-CONFIGURATION_URIS_DBM=$HELM_LIBRARY_DIR/urls_of_uris
-
-AC_MSG_CHECKING("for the tmp dir")
-RES=""
-if test -d "/tmp" ; then
-   CONFIGURATION_TMPDIR=/tmp
-else
-   AC_MSG_WARN(Could not find /tmp. What directory could I use instead?)
-   read $CONFIGURATION_TMPDIR
-   RES="Asked"
-fi
-if test "$RES" != "Asked" ; then
-   AC_MSG_RESULT($CONFIGURATION_TMPDIR)
-fi
+dnl HELM version
+AC_SUBST(PACKAGE)
+AC_SUBST(VERSION)
 
+dnl HELM directories
+AC_SUBST(HELM_BIN_DIR)
 AC_SUBST(HELM_LIB_DIR)
 AC_SUBST(HELM_ETC_DIR)
+AC_SUBST(HELM_SHARE_DIR)
+AC_SUBST(HELM_VAR_DIR)
+AC_SUBST(HELM_TMP_DIR)
+
+dnl HELM download directory
 AC_SUBST(HELM_LIBRARY_DIR)
+
+dnl HELM servers
+AC_SUBST(HELM_SERVERS_FILE)
+
+dnl HELM URIS data-base
+AC_SUBST(HELM_URIS_DBM)
+
+dnl HELM DTDs
+AC_SUBST(HELM_DTD_DIR)
+
+dnl HELM stylesheets
+AC_SUBST(HELM_STYLE_DIR)
+
+dnl HELM customized GtkMathView configuration
 AC_SUBST(HELM_DICTIONARY_PATH)
-AC_SUBST(GTKMATHVIEW_DICTIONARY_PATH)
 AC_SUBST(HELM_FONT_CONFIGURATION_PATH)
+AC_SUBST(GTKMATHVIEW_DICTIONARY_PATH)
 AC_SUBST(GTKMATHVIEW_FONT_CONFIGURATION_PATH)
 AC_SUBST(GTKMATHVIEW_T1_CONFIG_FILE)
-AC_SUBST(CONFIGURATION_HELM_DIR)
-AC_SUBST(CONFIGURATION_DTD_DIR)
-AC_SUBST(CONFIGURATION_SERVERS_FILE)
-AC_SUBST(CONFIGURATION_URIS_DBM)
-AC_SUBST(CONFIGURATION_TMPDIR)
 
 AC_OUTPUT(
-[Makefile
- lib/configuration.pl
- etc/helm-math-engine-configuration.xml
- etc/configuration.xml
-])
+[ Makefile
+  helm-config
+  lib/configuration.pl
+  etc/helm-math-engine-configuration.xml
+  etc/configuration.xml
+  helm_configuration.spec
+], chmod +x helm-config)