diff options
| author | Paul Eggert | 2012-05-20 19:33:13 -0700 |
|---|---|---|
| committer | Paul Eggert | 2012-05-20 19:33:13 -0700 |
| commit | 9b4ee6166fd8da5f8006a265f775d84e60c15be7 (patch) | |
| tree | 93ab66a914aecf8114ce919fab4cc34ed0ae0d5b /admin | |
| parent | b847032c75e0cb4041a8736886e7054beb6f8696 (diff) | |
| download | emacs-9b4ee6166fd8da5f8006a265f775d84e60c15be7.tar.gz emacs-9b4ee6166fd8da5f8006a265f775d84e60c15be7.zip | |
Make merging from gnulib a script, not a makefile action.
Putting it in a makefile has some problems with reflection, as
merging from gnulib updates 'configure', which can update the makefile.
Putting it in a standalone script breaks this loop.
* Makefile.in (gnulib_srcdir, $(gnulib_srcdir), DOS_gnulib_comp.m4)
(GNULIB_MODULES, GNULIB_TOOL_FLAGS, sync-from-gnulib):
Remove, moving the actions to the script admin/merge-gnulib.
* admin/merge-gnulib: New script, with actions moved here from
../Makefile.in.
Diffstat (limited to 'admin')
| -rw-r--r-- | admin/ChangeLog | 6 | ||||
| -rwxr-xr-x | admin/merge-gnulib | 88 |
2 files changed, 94 insertions, 0 deletions
diff --git a/admin/ChangeLog b/admin/ChangeLog index 55504b3d6f8..86069da7f0b 100644 --- a/admin/ChangeLog +++ b/admin/ChangeLog | |||
| @@ -1,3 +1,9 @@ | |||
| 1 | 2012-05-21 Paul Eggert <eggert@cs.ucla.edu> | ||
| 2 | |||
| 3 | Make merging from gnulib a script, not a makefile action. | ||
| 4 | * merge-gnulib: New script, with actions moved here from | ||
| 5 | ../Makefile.in. | ||
| 6 | |||
| 1 | 2012-05-19 Paul Eggert <eggert@cs.ucla.edu> | 7 | 2012-05-19 Paul Eggert <eggert@cs.ucla.edu> |
| 2 | 8 | ||
| 3 | * CPP-DEFINES (HAVE_GETDOMAINNAME): Remove. | 9 | * CPP-DEFINES (HAVE_GETDOMAINNAME): Remove. |
diff --git a/admin/merge-gnulib b/admin/merge-gnulib new file mode 100755 index 00000000000..57b71ee4a74 --- /dev/null +++ b/admin/merge-gnulib | |||
| @@ -0,0 +1,88 @@ | |||
| 1 | #! /bin/sh | ||
| 2 | # Merge gnulib sources into Emacs sources. | ||
| 3 | # Typical usage: | ||
| 4 | # | ||
| 5 | # admin/merge-gnulib | ||
| 6 | |||
| 7 | # Copyright 2012 Free Software Foundation, Inc. | ||
| 8 | |||
| 9 | # This file is part of GNU Emacs. | ||
| 10 | |||
| 11 | # GNU Emacs is free software: you can redistribute it and/or modify | ||
| 12 | # it under the terms of the GNU General Public License as published by | ||
| 13 | # the Free Software Foundation, either version 3 of the License, or | ||
| 14 | # (at your option) any later version. | ||
| 15 | |||
| 16 | # GNU Emacs is distributed in the hope that it will be useful, | ||
| 17 | # but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 18 | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
| 19 | # GNU General Public License for more details. | ||
| 20 | |||
| 21 | # You should have received a copy of the GNU General Public License | ||
| 22 | # along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. | ||
| 23 | |||
| 24 | # written by Paul Eggert | ||
| 25 | |||
| 26 | GNULIB_URL=git://git.savannah.gnu.org/gnulib.git | ||
| 27 | |||
| 28 | GNULIB_MODULES=' | ||
| 29 | alloca-opt | ||
| 30 | careadlinkat crypto/md5 crypto/sha1 crypto/sha256 crypto/sha512 | ||
| 31 | dtoastr dup2 | ||
| 32 | filemode getloadavg getopt-gnu ignore-value intprops lstat | ||
| 33 | manywarnings mktime pthread_sigmask readlink | ||
| 34 | socklen stdarg stdio strftime strtoimax strtoumax symlink sys_stat | ||
| 35 | warnings | ||
| 36 | ' | ||
| 37 | |||
| 38 | GNULIB_TOOL_FLAGS=' | ||
| 39 | --avoid=msvc-inval --avoid=msvc-nothrow | ||
| 40 | --avoid=raise --avoid=threadlib | ||
| 41 | --conditional-dependencies --import --no-changelog --no-vc-files | ||
| 42 | --makefile-name=gnulib.mk | ||
| 43 | ' | ||
| 44 | |||
| 45 | # The source directory, with a trailing '/'. | ||
| 46 | # If empty, the source directory is the working directory. | ||
| 47 | src=$2 | ||
| 48 | case $src in | ||
| 49 | */ | '') ;; | ||
| 50 | *) src=$src/ ;; | ||
| 51 | esac | ||
| 52 | |||
| 53 | # Gnulib's source directory. | ||
| 54 | gnulib_srcdir=${1-$src../gnulib} | ||
| 55 | |||
| 56 | case $gnulib_srcdir in | ||
| 57 | -*) src=- ;; | ||
| 58 | esac | ||
| 59 | case $src in | ||
| 60 | -*) | ||
| 61 | echo >&2 "$0: usage: $0 [GNULIB_SRCDIR [SRCDIR]] | ||
| 62 | |||
| 63 | SRCDIR is the Emacs source directory (default: working directory). | ||
| 64 | GNULIB_SRCDIR is the Gnulib source directory (default: SRCDIR/../gnulib)." | ||
| 65 | exit 1 ;; | ||
| 66 | esac | ||
| 67 | |||
| 68 | test -x "$src"autogen.sh || { | ||
| 69 | echo >&2 "$0: '${src:-.}' is not an Emacs source directory." | ||
| 70 | exit 1 | ||
| 71 | } | ||
| 72 | |||
| 73 | test -d "$gnulib_srcdir" || | ||
| 74 | git clone -- "$GNULIB_URL" "$gnulib_srcdir" || | ||
| 75 | exit | ||
| 76 | |||
| 77 | test -x "$gnulib_srcdir"/gnulib-tool || { | ||
| 78 | echo >&2 "$0: '$gnulib_srcdir' is not a Gnulib source directory." | ||
| 79 | exit 1 | ||
| 80 | } | ||
| 81 | |||
| 82 | cp -- "$src"m4/gl-comp.m4 "$src"m4/gnulib-comp.m4 && | ||
| 83 | "$gnulib_srcdir"/gnulib-tool --dir="$src" $GNULIB_TOOL_FLAGS $GNULIB_MODULES && | ||
| 84 | rm -- "$src"m4/gnulib-cache.m4 "$src"m4/warn-on-use.m4 && | ||
| 85 | mv -- "$src"m4/gnulib-comp.m4 "$src"m4/gl-comp.m4 && | ||
| 86 | cp -- "$gnulib_srcdir"/build-aux/texinfo.tex "$src"doc/misc && | ||
| 87 | cp -- "$gnulib_srcdir"/build-aux/move-if-change "$src"build-aux && | ||
| 88 | autoreconf -i -I m4 -- ${src:+"$src"} | ||