2008-01-07 Richard Jones <rjones@redhat.com>
+ Bundle Gtk DLLs and support files in the Windows installer.
+ * configure.ac: Detect library paths instead of hard-
+ coding them.
+ * wininstaller.nsis (removed): This file is now autogenerated.
+ * wininstaller.nsis.in: Bundle Gtk DLLs and support files.
+ * Makefile.in: More verbose messages from NSIS.
+
Include required libraries in the Windows installer.
* wininstaller.nsis: Include *.dll files.
dnl Check for optional perldoc (for building manual pages).
AC_CHECK_PROG(HAVE_PERLDOC,perldoc,perldoc)
-dnl Check for optional NSIS.
+dnl Check for optional NSIS (for building a Windows installer).
AC_ARG_WITH([nsis],
[AS_HELP_STRING([--with-nsis],
[use NSIS to build a Windows installer])],
[],
[with_nsis=no])
+
MAKENSIS=
+LIBVIRT_DLL_PATH=
+LIBXDR_DLL_PATH=
+LIBXML2_DLL_PATH=
+GNUTLS_DLL_PATH=
+GTK_PATH=
+GTK_DLL_PATH=
+
+[
+msys_to_win_dir () {
+ eval pushd "\$$1" > /dev/null
+ eval $1=`pwd -W`
+ popd > /dev/null
+}
+]
+
if test "x$with_nsis" != "xno"; then
AC_PATH_PROG(MAKENSIS,makensis,[],[$with_nsis:$PATH])
if test "x$MAKENSIS" = "x"; then
AC_MSG_FAILURE([--with-nsis was given, but could not find MAKENSIS.EXE])
fi
+
+ # MAKENSIS is set so we will build a rule for making a Windows
+ # installer. To support this, generate wininstaller.nsis.
+ saved_IFS=$IFS
+ IFS=$PATH_SEPARATOR
+ for d in $PATH; do
+ IFS=$saved_IFS
+ echo Checking $d for DLLs ... >&5
+ if test -f "$d/libvirt-0.dll"; then
+ LIBVIRT_DLL_PATH="$d"
+ fi
+ if test -f "$d/libxdr.dll"; then
+ LIBXDR_DLL_PATH="$d"
+ fi
+ if test -f "$d/libxml2-2.dll"; then
+ LIBXML2_DLL_PATH="$d"
+ fi
+ if test -f "$d/libgpg-error-0.dll"; then
+ GNUTLS_DLL_PATH="$d"
+ fi
+ if test -f "$d/libgtk-win32-2.0-0.dll"; then
+ GTK_DLL_PATH="$d"
+ GTK_PATH="$d/.."
+ fi
+ done
+ IFS=$saved_IFS
+
+ if test "x$LIBVIRT_DLL_PATH" = "x"; then
+ AC_MSG_FAILURE([cannot find libvirt-0.dll in PATH])
+ fi
+ if test "x$LIBXDR_DLL_PATH" = "x"; then
+ AC_MSG_FAILURE([cannot find libxdr.dll in PATH])
+ fi
+ if test "x$LIBXML2_DLL_PATH" = "x"; then
+ AC_MSG_FAILURE([cannot find libxml2-2.dll in PATH])
+ fi
+ if test "x$GNUTLS_DLL_PATH" = "x"; then
+ AC_MSG_FAILURE([cannot find GnuTLS DLLs in PATH])
+ fi
+ if test "x$GTK_DLL_PATH" = "x"; then
+ AC_MSG_WARN([cannot find GTK DLLs in PATH])
+ fi
+
+ # Change the paths to Windows paths.
+ msys_to_win_dir LIBVIRT_DLL_PATH
+ msys_to_win_dir LIBXDR_DLL_PATH
+ msys_to_win_dir LIBXML2_DLL_PATH
+ msys_to_win_dir GNUTLS_DLL_PATH
+ if test "x$GTK_DLL_PATH" != "x"; then
+ msys_to_win_dir GTK_DLL_PATH
+ msys_to_win_dir GTK_PATH
+ fi
fi
AC_SUBST(MAKENSIS)
+AC_SUBST(LIBVIRT_DLL_PATH)
+AC_SUBST(LIBXDR_DLL_PATH)
+AC_SUBST(LIBXML2_DLL_PATH)
+AC_SUBST(GNUTLS_DLL_PATH)
+AC_SUBST(GTK_DLL_PATH)
+AC_SUBST(GTK_PATH)
dnl Summary.
echo "------------------------------------------------------------"
virt-top/Makefile
virt-df/Makefile
])
+if test "x$MAKENSIS" != "x"; then
+ AC_CONFIG_FILES([wininstaller.nsis])
+fi
AC_OUTPUT
#!Nsis Installer Command Script\r
+# @configure_input@\r
# Copyright (C) 2008 Red Hat Inc., Richard W.M. Jones\r
#\r
# This library is free software; you can redistribute it and/or\r
SectionIn RO\r
\r
SetOutPath $INSTDIR\r
- # XXX Get these paths automatically.\r
- File "c:\msys\1.0\local\bin\libvirt-?.dll"\r
- File "c:\msys\1.0\local\bin\libxdr.dll"\r
- File "c:\msys\1.0\local\bin\libxml2-?.dll"\r
- File "c:\gnutls\bin\libgcrypt-??.dll"\r
- File "c:\gnutls\bin\libgnutls-??.dll"\r
- File "c:\gnutls\bin\libgpg-error-?.dll"\r
- File "c:\gnutls\bin\libtasn1-?.dll"\r
+ File "@LIBVIRT_DLL_PATH@\libvirt-0.dll"\r
+ File "@LIBXDR_DLL_PATH@\libxdr.dll"\r
+ File "@LIBXML2_DLL_PATH@\libxml2-2.dll"\r
+ File "@GNUTLS_DLL_PATH@\libgcrypt-??.dll"\r
+ File "@GNUTLS_DLL_PATH@\libgnutls-??.dll"\r
+ File "@GNUTLS_DLL_PATH@\libgpg-error-?.dll"\r
+ File "@GNUTLS_DLL_PATH@\libtasn1-?.dll"\r
+ File "@GTK_DLL_PATH@\*.dll"\r
+\r
+ SetOutPath $INSTDIR\lib\r
+ File /r "@GTK_PATH@\lib\gtk-2.0"\r
+ File /r "@GTK_PATH@\lib\pango"\r
+\r
+ SetOutPath $INSTDIR\r
+ File /r "@GTK_PATH@\etc"\r
+\r
+ SetOutPath $INSTDIR\r
SectionEnd\r
\r
Section "Programs (recommended)"\r
SetOutPath $INSTDIR\r
File "/oname=mlvirsh.exe" "mlvirsh\mlvirsh.opt"\r
+ #File "/oname=mlvirtmanager.exe" "mlvirsh\mlvirtmanager.opt"\r
SectionEnd\r
\r
Section "OCaml Libvirt bindings (for developers only)"\r
RMDir "$SMPROGRAMS\${PACKAGE}"\r
\r
# Files in installation directory.\r
+ RMDir /r "$INSTDIR\etc"\r
+ RMDir /r "$INSTDIR\lib"\r
Delete /rebootok "$INSTDIR\*.exe"\r
Delete /rebootok "$INSTDIR\*.dll"\r
\r