From: Eli Zaretskii Date: Thu, 18 Apr 2013 16:20:48 +0000 (+0300) Subject: Merge from trunk. X-Git-Tag: emacs-24.3.90~173^2^2~42^2~45^2~387^2~2026^2~229^2~63^2~26 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=4f0e6095fc0bcc8b9e8bcf6bf907b957b15cf699;p=emacs.git Merge from trunk. --- 4f0e6095fc0bcc8b9e8bcf6bf907b957b15cf699 diff --cc configure.ac index d0515147584,39a0477a693..4dfbc224335 --- a/configure.ac +++ b/configure.ac @@@ -812,18 -799,39 +812,49 @@@ dnl AC_PROG_MKDIR_ dnl if test "x$RANLIB" = x; then dnl AC_PROG_RANLIB dnl fi - AC_PROG_LN_S + + + dnl Sadly, AC_PROG_LN_S is too restrictive. It also tests whether links + dnl can be made to directories. This is not relevant for our usage, and + dnl excludes some cases that work fine for us. Eg MS Windows or files + dnl hosted on AFS, both examples where simple links work, but links to + dnl directories fail. We use a cut-down version instead. + dnl AC_PROG_LN_S + + AC_MSG_CHECKING([whether ln -s works for files in the same directory]) + rm -f conf$$ conf$$.file + + LN_S_FILEONLY='cp -p' + + if (echo >conf$$.file) 2>/dev/null; then + if ln -s conf$$.file conf$$ 2>/dev/null; then + LN_S_FILEONLY='ln -s' + elif ln conf$$.file conf$$ 2>/dev/null; then + LN_S_FILEONLY=ln + fi + fi + + rm -f conf$$ conf$$.file + + if test "$LN_S_FILEONLY" = "ln -s"; then + AC_MSG_RESULT([yes]) + else + AC_MSG_RESULT([no, using $LN_S_FILEONLY]) + fi + + AC_SUBST(LN_S_FILEONLY) + +dnl AC_PROG_LN_S sets LN_S to 'cp -pR' for MinGW, on the premise that 'ln' +dnl doesn't support links to directories, as in "ln file dir". But that +dnl use is non-portable, and OTOH MinGW wants to use hard links for Emacs +dnl executables at "make install" time. +dnl See http://lists.gnu.org/archive/html/emacs-devel/2013-04/msg00475.html +dnl for more details. +if test "$opsys" = "mingw32"; then + LN_S="ln" +fi + AC_PATH_PROG(INSTALL_INFO, install-info, :, $PATH$PATH_SEPARATOR/usr/sbin$PATH_SEPARATOR/sbin) dnl Don't use GZIP, which is used by gzip for additional parameters.