bug-gnulib
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Bug-gnulib] Re: gnulib-tool --import


From: Simon Josefsson
Subject: [Bug-gnulib] Re: gnulib-tool --import
Date: Sat, 07 Aug 2004 18:32:03 +0200
User-agent: Gnus/5.110003 (No Gnus v0.3) Emacs/21.3.50 (gnu/linux)

"Gary V.Vaughan" <address@hidden> writes:

> Hi Simon,
>
> On 7 Aug 2004, at 15:57, Simon Josefsson wrote:
>> Here's how I use it for Shishi:
>>
>> address@hidden:~/src/shishi$ ../gnulib/gnulib-tool --import
>> --source-base=gl --m4-base=gl/m4 --libtool error getopt realloc
>> setenv strcase strchrnul strnlen strdup strndup xstrndup vasprintf
>> vasnprintf xalloc getdate timegm gethostname xgethostname
>> xgetdomainname getline xreadlink progname getsubopt
>>
>> Thoughts, comments and suggestions appreciated.
>
> Great work!
>
> I have cobbled together a script that I use to import gnulib
> modules into CVS m4, which is a bit hackish, but works for me,
> and might give you some snippets of shell that are helpful.
>
> One nice feature of my script is that it pulls the list of
> modules to import from the contents of an m4_GNULIB_MODULES
> call in configure.ac, and then does a recursive dependency
> analysis to make sure everything required is pulled in to the
> full list of modules that must be imported.

Nice idea!  With the updated gnulib-tool below, and a configure.ac
that say:

gl_SOURCE_BASE(gl)
gl_M4_BASE(gl/m4)
gl_MODULES(error getopt realloc setenv strcase strchrnul strnlen strdup strndup 
xstrndup vasprintf vasnprintf xalloc getdate timegm gethostname xgethostname 
xgetdomainname getline xreadlink progname getsubopt)
gl_INIT

I can now import all I need by:

address@hidden:~/src/shishi$ ../gnulib/gnulib-tool --import

Users can still specify --source-base and --m4-base and modules, if
they don't use the configure.ac approach.

Autoconf --trace seem a bit unreliable though; it doesn't work if the
user hasn't invoked autoreconf or equivalent.  Perhaps grep/sed should
be used.

Thanks,
Simon

Index: gnulib-tool
===================================================================
RCS file: /cvsroot/gnulib/gnulib/gnulib-tool,v
retrieving revision 1.13
diff -u -p -u -w -r1.13 gnulib-tool
--- gnulib-tool 17 Sep 2003 18:30:23 -0000      1.13
+++ gnulib-tool 7 Aug 2004 16:27:05 -0000
@@ -1,6 +1,6 @@
 #! /bin/sh
 #
-# Copyright (C) 2002, 2003 Free Software Foundation, Inc.
+# Copyright (C) 2002, 2003, 2004 Free Software Foundation, Inc.
 #
 # This program is free software; you can redistribute it and/or modify
 # it under the terms of the GNU General Public License as published by
@@ -46,7 +46,7 @@ func_usage ()
 {
   echo "\
 Usage: gnulib-tool --list
-       gnulib-tool --import module1 ... moduleN
+       gnulib-tool --import [MODULE...]
        gnulib-tool --create-testdir --dir=directory module1 ... moduleN
        gnulib-tool --create-megatestdir --dir=directory [module1 ... moduleN]
        gnulib-tool --test --dir=directory module1 ... moduleN
@@ -79,7 +79,16 @@ Operation modes:
 
 Options:
       --dir=DIRECTORY       specify the target directory
-      --lib=LIBRARY         specify the library name
+                            For --import, this specify where your
+                            configure.ac can be found.  Defaults to current
+                            directory.
+      --lib=LIBRARY         Specify the library name.  Defaults to 'libgnu'.
+      --source-base=DIRECTORY
+                            Directory relative --dir where source code is
+                            placed (default \"lib\"), for --import.
+      --m4-base=DIRECTORY   Directory relative --dir where *.m4 macros are
+                            placed (default \"m4\"), for --import.
+      --libtool             Use libtool rules, for --import.
       --no-changelog        don't update or create ChangeLog files
 
 Report bugs to <address@hidden>."
@@ -110,11 +119,17 @@ func_fatal_error ()
 # - mode            list or import or create-testdir or create-megatestdir
 # - destdir         from --dir
 # - libname         from --lib
+# - sourcebase      from --source-base
+# - m4base          from --m4-base
+# - libtool         true if --libtool was given, blank otherwise
 # - do_changelog    false if --no-changelog was given, : otherwise
 {
   mode=
   destdir=
-  libname=libfoo
+  libname=libgnu
+  sourcebase=lib
+  m4base=m4
+  libtool=
   do_changelog=:
 
   while test $# -gt 0; do
@@ -160,6 +175,29 @@ func_fatal_error ()
       --lib=* )
         libname=`echo "X$1" | sed -e 's/^X--lib=//'`
         shift ;;
+      --source-base )
+        shift
+        if test $# = 0; then
+          func_fatal_error "missing argument for --source-base"
+        fi
+        sourcebase=$1
+        shift ;;
+      --source-base=* )
+        sourcebase=`echo "X$1" | sed -e 's/^X--source-base=//'`
+        shift ;;
+      --m4-base )
+        shift
+        if test $# = 0; then
+          func_fatal_error "missing argument for --m4-base"
+        fi
+        m4base=$1
+        shift ;;
+      --m4-base=* )
+        m4base=`echo "X$1" | sed -e 's/^X--m4-base=//'`
+        shift ;;
+      --libtool )
+        libtool=true
+        shift ;;
       --no-changelog | --no-changelo | --no-changel | --no-change | --no-chang 
| --no-chan | --no-cha | --no-ch | --no-c )
         do_changelog=false
         shift ;;
@@ -534,7 +572,171 @@ case $mode in
     ;;
 
   import )
-    func_fatal_error "NYI" ;;
+       if test -z "$destdir"; then
+           destdir=.
+       fi
+       test -d "$destdir" \
+           || func_fatal_error "destination directory does not exist: $destdir"
+       sourcebase=`cd $destdir; $AUTOCONF --trace=gl_SOURCE_BASE | sed 
's,^.*:,,g'`
+       test -d "$destdir/$sourcebase" || \
+           mkdir "$destdir/$sourcebase" || \
+           func_fatal_error \
+           "could not create source base directory: $destdir/$sourcebase"
+       m4base=`cd $destdir; $AUTOCONF --trace=gl_M4_BASE | sed 's,^.*:,,g'`
+       test -d "$destdir/$m4base" || \
+           mkdir "$destdir/$m4base" || \
+           func_fatal_error \
+           "could not create m4 base directory: $destdir/$m4base"
+       supplied_modules="$*"
+       modules=`for m in $supplied_modules; do echo $m; done | sort | uniq`
+       if test -z "$modules"; then
+           modules=`cd $destdir; $AUTOCONF --trace=gl_MODULES | sed 
's,^.*:,,g'`
+       fi
+       if test x`cd $destdir; $AUTOCONF --trace=AC_PROG_LIBTOOL` != x; then
+           libtool=true
+       fi
+
+        # Determine final module list.
+       while true; do
+           xmodules=
+           for module in $modules; do
+               func_verify_module
+               if test -n "$module"; then
+                    # Duplicate dependenies are harmless, but Jim wants a 
warning.
+                   duplicated_deps=`func_get_dependencies $module | sort | 
uniq -d`
+                   if test -n "$duplicated_deps"; then
+                       echo "warning: module $module has duplicated 
dependencies: "`echo $duplicated_deps` 1>&2
+                   fi
+                   xmodules="$xmodules $module "`func_get_dependencies $module`
+               fi
+           done
+           xmodules=`for m in $xmodules; do echo $m; done | sort | uniq`
+           if test "$xmodules" = "$modules"; then
+               break
+           fi
+           modules="$xmodules"
+       done
+       echo "Module list with included dependencies:"
+       echo "$modules" | sed -e 's/^/  /'
+
+        # Determine final file list.
+       files=
+       for module in $modules; do
+           func_verify_module
+           if test -n "$module"; then
+               files="$files "`func_get_filelist $module`
+           fi
+       done
+       files=`for f in $files; do echo $f; done | sort | uniq`
+       echo "File list:"
+       echo "$files" | sed -e 's/^/  /'
+
+        # Copy files.
+       for f in $files; do
+           case "$f" in
+               config/*) g=`echo "$f" | sed -e 's,^config/,,'` ;;
+               lib/*) g=`echo "$f" | sed -e "s,^lib/,$sourcebase/,"` ;;
+               m4/*) g=`echo "$f" | sed -e "s,^m4/,$m4base/,"` ;;
+               *) g="$f" ;;
+           esac
+           cp -p "$gnulib_dir/$f" "$destdir/$g"
+       done
+
+        # Create lib/Makefile.am.
+       if test -n "$libtool"; then
+           libext=la
+           perhapsLT=LT
+       else
+           libext=a
+           perhapsLT=
+       fi
+       (echo "## Process this file with automake to produce Makefile.in."
+           echo "# Copyright (C) 2004 Free Software Foundation, Inc."
+           echo "#"
+           echo "# This file is free software, distributed under the terms of 
the GNU"
+           echo "# General Public License.  As a special exception to the GNU 
General"
+           echo "# Public License, this file may be distributed as part of a 
program"
+           echo "# that contains a configuration script generated by Automake, 
under"
+           echo "# the same distribution terms as the rest of that program."
+           echo "#"
+           echo "# Generated by gnulib-tool."
+           echo "#"
+           opt_libtool=
+           if test -n "$libtool"; then
+               opt_libtool="--libtool"
+           fi
+           echo "# gnulib-tool --import --dir=$destdir --lib=$libname 
--source-base=$sourcebase --m4-base=$m4base $opt_libtool $supplied_modules"
+           echo
+           echo "AUTOMAKE_OPTIONS = 1.8 gnits"
+           echo
+           echo "noinst_${perhapsLT}LIBRARIES = $libname.$libext"
+           echo
+           echo "${libname}_${libext}_SOURCES ="
+           echo "${libname}_${libext}_LIBADD = @${perhapsLT}LIBOBJS@"
+           echo "EXTRA_DIST ="
+           echo "BUILT_SOURCES ="
+           echo "SUFFIXES ="
+           echo "MOSTLYCLEANFILES ="
+           echo "CLEANFILES ="
+           echo "DISTCLEANFILES ="
+           echo "MAINTAINERCLEANFILES ="
+           for module in $modules; do
+               func_verify_module
+               if test -n "$module"; then
+                   func_get_automake_snippet "$module" | sed -e 
"s,lib_SOURCES,${libname}_${libext}_SOURCES,g" -e 
"s,lib_OBJECTS,${libname}_${libext}_OBJECTS,g"
+                   if test "$module" = 'alloca'; then
+                       echo "${libname}_${libext}_LIBADD += @ALLOCA@"
+                   fi
+               fi
+           done
+       ) > "$destdir/$sourcebase/Makefile.am"
+
+        # Create gnulib.m4.
+       (echo "# Copyright (C) 2004 Free Software Foundation, Inc."
+           echo "# This file is free software, distributed under the terms of 
the GNU"
+           echo "# General Public License.  As a special exception to the GNU 
General"
+           echo "# Public License, this file may be distributed as part of a 
program"
+           echo "# that contains a configuration script generated by Autoconf, 
under"
+           echo "# the same distribution terms as the rest of that program."
+           echo "#"
+           echo "# Generated by gnulib-tool."
+           echo "#"
+           opt_libtool=
+           if test -n "$libtool"; then
+               opt_libtool="--libtool"
+           fi
+           echo "# gnulib-tool --import --dir=$destdir --lib=$libname 
--source-base=$sourcebase --m4-base=$m4base $opt_libtool $supplied_modules"
+           echo
+           echo "AC_DEFUN([gl_EARLY],"
+           echo "["
+           if grep AC_GNU_SOURCE "$destdir"/$m4base/*.m4 > /dev/null; then
+               echo "  AC_GNU_SOURCE"
+           fi
+           if grep gl_USE_SYSTEM_EXTENSIONS "$destdir"/$m4base/*.m4 > 
/dev/null; then
+               echo "  gl_USE_SYSTEM_EXTENSIONS"
+           fi
+           echo "])"
+           echo
+           echo "AC_DEFUN([gl_INIT],"
+           echo "["
+           for module in $modules; do
+               func_verify_module
+               if test -n "$module"; then
+                   func_get_autoconf_snippet "$module" | sed -e '/^$/d;' -e 
's/^/  /' -e 's/AM_GNU_GETTEXT(\[external\])/dnl you must add 
AM_GNU_GETTEXT([external]) or similar to configure.ac./'
+               fi
+           done
+           echo "])"
+           echo
+           echo "dnl Usage: gl_MODULES(module1 module2 ...)"
+           echo "AC_DEFUN([gl_MODULES], [])"
+           echo
+           echo "dnl Usage: gl_SOURCE_BASE(DIR)"
+           echo "AC_DEFUN([gl_SOURCE_BASE], [])"
+           echo
+           echo "dnl Usage: gl_M4_BASE(DIR)"
+           echo "AC_DEFUN([gl_M4_BASE], [])"
+       ) > "$destdir/$m4base/gnulib.m4"
+       ;;
 
   create-testdir )
     if test -z "$destdir"; then




reply via email to

[Prev in Thread] Current Thread [Next in Thread]