X-Git-Url: http://git.ozlabs.org/?p=ccan;a=blobdiff_plain;f=tools%2Fcreate-ccan-tree;h=64fc36e7efd7db832f0759c24974fa01e2ff3d34;hp=88644b78651b267281e4abab2a375693f262caec;hb=d218dcd458cbec7a1b958af39b70cd068da7b040;hpb=70a438e87551b1e0775e3c785bc07a71cb4de314 diff --git a/tools/create-ccan-tree b/tools/create-ccan-tree index 88644b78..64fc36e7 100755 --- a/tools/create-ccan-tree +++ b/tools/create-ccan-tree @@ -7,18 +7,18 @@ usage() { Usage: $progname [options] ... options: - -a, --copy-all copy all files in module tree (not just - sources required for build) - -c, --exclude-configurator exclude configurator. config.h must be - supplied by another method (eg, autotools) + -a, --copy-all copy all files in module tree (not just sources + required for build) + -b, --build-type=TYPE generate build infrastructure of TYPE + (one of 'make', 'make+config', 'automake', 'waf') EOF } # parse options, setting the following flags copy_all= -exclude_configurator= +build_type= -opts=$(getopt -o ac --long copy-all,exclude-configurator -n $progname -- "$@") +opts=$(getopt -o ab: --long copy-all,build-type: -n $progname -- "$@") if [ $? != 0 ] then @@ -35,9 +35,9 @@ do copy_all=1 shift ;; - -c|--exclude-configurator) - exclude_configurator=1 - shift + -b|--build-type) + build_type="$2" + shift 2 ;; --) shift @@ -58,6 +58,15 @@ then exit 1 fi +# check --build-type argument sanity +case "$build_type" in + ''|'make'|'make+config'|'automake'|'waf') + ;; + *) + echo "Invalid build type '$build_type'" >&2 + exit 1 +esac + srcdir=$(dirname $0)/../ outdir="$1" shift @@ -151,26 +160,43 @@ do cp "$license_src" "$license_dest" done -# add ccan Makefile echo "Adding build infrastructure" -cp "$srcdir/Makefile-ccan" "$tmpdir/" -# add top-level Makefile -top_makefile="$tmpdir/Makefile" -cat > "$top_makefile" << EOF +# generate automake Makefile.am +automakefile="$tmpdir/Makefile.am" +if [ "$build_type" = "automake" ] +then + ( + echo "noinst_LIBRARIES = libccan.a" + echo "libccan_a_SOURCES = \\" + cd "$tmpdir" + find ccan -maxdepth 2 -name '*.[ch]' | + sed -e 's,^,\t,;$!s,$, \\,' + ) > "$automakefile" +fi + +makefile="$tmpdir/Makefile" +if [ "$build_type" = "make" -o "$build_type" = "make+config" ] +then + # add ccan Makefile + cp "$srcdir/Makefile-ccan" "$tmpdir/" + + # add top-level Makefile + cat > "$makefile" << EOF all: libccan.a include Makefile-ccan EOF +fi # optionally add configurator, and relevant parts to top-level Makefile -if [ -z "$exclude_configurator" ] +if [ "$build_type" = "make+config" ] then echo "Adding configurator" mkdir -p "$tmpdir/tools/configurator" cp -a "$srcdir/tools/configurator" "$tmpdir/tools/" - cat >> "$top_makefile" <> "$makefile" < "$tmpdir/wscript" << EOF +def build(ctx): + ctx(features = 'c cstlib', + source = ctx.path.ant_glob('**/*.c'), + target = 'ccan', + includes = '.') +EOF +fi + mv "$tmpdir" "$outdir" echo "Done. ccan source tree built in $outdir"