[csw-devel] SF.net SVN: gar:[5302] csw/mgar/pkg/etckeeper/trunk

bdwalton at users.sourceforge.net bdwalton at users.sourceforge.net
Thu Jun 18 03:56:52 CEST 2009


Revision: 5302
          http://gar.svn.sourceforge.net/gar/?rev=5302&view=rev
Author:   bdwalton
Date:     2009-06-18 01:56:51 +0000 (Thu, 18 Jun 2009)

Log Message:
-----------
* First crack at a patch to add autoconf support
* Stages up to install work.

Modified Paths:
--------------
    csw/mgar/pkg/etckeeper/trunk/Makefile
    csw/mgar/pkg/etckeeper/trunk/checksums

Added Paths:
-----------
    csw/mgar/pkg/etckeeper/trunk/files/autoconf.patch

Modified: csw/mgar/pkg/etckeeper/trunk/Makefile
===================================================================
--- csw/mgar/pkg/etckeeper/trunk/Makefile	2009-06-18 00:46:04 UTC (rev 5301)
+++ csw/mgar/pkg/etckeeper/trunk/Makefile	2009-06-18 01:56:51 UTC (rev 5302)
@@ -18,13 +18,16 @@
 CATALOGNAME = CSWetckeeper
 ARCHALL_CSWetckeeper = 1
 
+PREREQUISITE_PKGS = CSWgnulinks
+
 REQUIRED_PKGS_CSWetckeeper = CSWgit CSWbash
 
 SPKG_DESC_CSWetckeeper = Versioning for /etc
 
-GIT_REPOS = git://git.kitenet.net/etckeeper
-GIT_TREEISH_etckeeper.git = HEAD
+GIT_REPOS = git://git.kitenet.net/etckeeper.git
+GIT_TREEISH_etckeeper.git = 0.37
 GIT_USE_PROXY = 1
+PATCHFILES = autoconf.patch
 
 # We define upstream file regex so we can be notifed of new upstream
 # software release
@@ -35,6 +38,27 @@
 # default to the value of MASTER_SITES
 # UPSTREAM_MASTER_SITES = 
 
+
+sysconfdir = /etc/opt/csw
+localstatedir = /var/opt/csw
+
 CONFIGURE_ARGS = $(DIRPATHS)
 
+BUILD_SCRIPTS =
+
+TEST_SCRIPTS =
+
 include gar/category.mk
+
+PATH := /opt/csw/gnu:$(PATH)
+
+pre-configure-modulated:
+	@(cd $(WORKSRC); autoreconf )
+	@$(MAKECOOKIE)
+
+post-install-modulated:
+	( for d in apt cruft; do \
+		dir=$(DESTDIR)$(sysconfdir)/$$d; \
+		[ -d $$dir ] && rm -rf $$dir; \
+	    done )
+	@$(MAKECOOKIE)

Modified: csw/mgar/pkg/etckeeper/trunk/checksums
===================================================================
--- csw/mgar/pkg/etckeeper/trunk/checksums	2009-06-18 00:46:04 UTC (rev 5301)
+++ csw/mgar/pkg/etckeeper/trunk/checksums	2009-06-18 01:56:51 UTC (rev 5302)
@@ -0,0 +1 @@
+99d020d8cfaa6734cd40f81cffff55c9  download/autoconf.patch

Added: csw/mgar/pkg/etckeeper/trunk/files/autoconf.patch
===================================================================
--- csw/mgar/pkg/etckeeper/trunk/files/autoconf.patch	                        (rev 0)
+++ csw/mgar/pkg/etckeeper/trunk/files/autoconf.patch	2009-06-18 01:56:51 UTC (rev 5302)
@@ -0,0 +1,867 @@
+diff --git a/.gitignore b/.gitignore
+new file mode 100644
+index 0000000..6a517ac
+--- /dev/null
++++ b/.gitignore
+@@ -0,0 +1,6 @@
++configure
++autom4te.cache
++Makefile
++config.log
++config.status
++etckeeper
+diff --git a/Makefile b/Makefile
+deleted file mode 100644
+index b2d6565..0000000
+--- a/Makefile
++++ /dev/null
+@@ -1,48 +0,0 @@
+-# You should configure etckeeper.conf for your distribution before
+-# installing etckeeper.
+-CONFFILE=etckeeper.conf
+-include $(CONFFILE)
+-
+-DESTDIR?=
+-prefix=/usr
+-sbindir=${prefix}/sbin
+-etcdir=/etc
+-mandir=${prefix}/share/man
+-vardir=/var
+-
+-INSTALL=install 
+-INSTALL_EXE=${INSTALL} -D
+-INSTALL_DATA=${INSTALL} -m 0644 -D
+-
+-build: etckeeper.spec
+-	-./etckeeper-bzr/__init__.py build || echo "** bzr support not built"
+-	
+-install:
+-	mkdir -p $(DESTDIR)$(etcdir)/etckeeper/ $(DESTDIR)$(vardir)/cache/etckeeper/
+-	cp -a *.d $(DESTDIR)$(etcdir)/etckeeper/
+-	$(INSTALL_DATA) $(CONFFILE) $(DESTDIR)$(etcdir)/etckeeper/etckeeper.conf
+-	$(INSTALL_EXE) etckeeper $(DESTDIR)$(sbindir)/etckeeper
+-	$(INSTALL_DATA) etckeeper.8 $(DESTDIR)$(mandir)/man8/etckeeper.8
+-	$(INSTALL_DATA) bash_completion $(DESTDIR)$(etcdir)/bash_completion.d/etckeeper
+-ifeq ($(HIGHLEVEL_PACKAGE_MANAGER),apt)
+-	$(INSTALL_DATA) apt.conf $(DESTDIR)$(etcdir)/apt/apt.conf.d/05etckeeper
+-	mkdir -p $(DESTDIR)$(etcdir)/cruft/filters-unex
+-	$(INSTALL_DATA) cruft_filter $(DESTDIR)$(etcdir)/cruft/filters-unex/etckeeper
+-endif
+-ifeq ($(LOWLEVEL_PACKAGE_MANAGER),pacman-g2)
+-	$(INSTALL_DATA) pacman-g2.hook $(DESTDIR)$(etcdir)/pacman-g2/hooks/etckeeper
+-endif
+-ifeq ($(HIGHLEVEL_PACKAGE_MANAGER),yum)
+-	$(INSTALL_DATA) yum-etckeeper.py $(DESTDIR)$(prefix)/lib/yum-plugins/etckeeper.py
+-	$(INSTALL_DATA) yum-etckeeper.conf $(DESTDIR)$(etcdir)/yum/pluginconf.d/etckeeper.conf
+-endif
+-	-./etckeeper-bzr/__init__.py install --root=$(DESTDIR) || echo "** bzr support not installed"
+-	echo "** installation successful"
+-
+-clean: etckeeper.spec
+-	rm -rf build
+-
+-etckeeper.spec:
+-	sed -i "s/Version:.*/Version: $$(perl -e '$$_=<>;print m/\((.*?)\)/'<debian/changelog)/" etckeeper.spec
+-
+-.PHONY: etckeeper.spec
+diff --git a/Makefile.in b/Makefile.in
+new file mode 100644
+index 0000000..874bab9
+--- /dev/null
++++ b/Makefile.in
+@@ -0,0 +1,54 @@
++# You should configure etckeeper.conf for your distribution before
++# installing etckeeper.
++CONFFILE=etckeeper.conf
++include $(CONFFILE)
++
++DESTDIR?=
++prefix = @prefix@
++exec_prefix = @exec_prefix@
++datarootdir = @datarootdir@
++sbindir = @sbindir@
++etcdir = @sysconfdir@
++libdir = @libdir@
++mandir = @mandir@
++vardir = @localstatedir@
++
++INSTALL = @INSTALL@
++INSTALL_DATA = @INSTALL_DATA@
++
++MKDIR_P = @MKDIR_P@
++
++build: etckeeper.spec
++	-./etckeeper-bzr/__init__.py build || echo "** bzr support not built"
++
++install:
++	$(MKDIR_P) $(DESTDIR)$(etcdir)/etckeeper/ $(DESTDIR)$(vardir)/cache/etckeeper/ $(DESTDIR)$(sbindir) $(DESTDIR)$(mandir)/man8 $(DESTDIR)$(etcdir)/bash_completion.d/
++	cp -a *.d $(DESTDIR)$(etcdir)/etckeeper/
++	$(INSTALL_DATA) $(CONFFILE) $(DESTDIR)$(etcdir)/etckeeper/etckeeper.conf
++	$(INSTALL) etckeeper $(DESTDIR)$(sbindir)/etckeeper
++	$(INSTALL_DATA) etckeeper.8 $(DESTDIR)$(mandir)/man8/etckeeper.8
++	$(INSTALL_DATA) bash_completion $(DESTDIR)$(etcdir)/bash_completion.d/etckeeper
++ifeq ($(HIGHLEVEL_PACKAGE_MANAGER),apt)
++	$(MKDIR_P) $(DESTDIR)$(etcdir)/apt/apt.conf.d/ $(DESTDIR)$(etcdir)/cruft/filters-unex
++	$(INSTALL_DATA) apt.conf $(DESTDIR)$(etcdir)/apt/apt.conf.d/05etckeeper
++	$(INSTALL_DATA) cruft_filter $(DESTDIR)$(etcdir)/cruft/filters-unex/etckeeper
++endif
++ifeq ($(LOWLEVEL_PACKAGE_MANAGER),pacman-g2)
++	$(MKDIR_P) $(DESTDIR)$(etcdir)/pacman-g2/hooks
++	$(INSTALL_DATA) pacman-g2.hook $(DESTDIR)$(etcdir)/pacman-g2/hooks/etckeeper
++endif
++ifeq ($(HIGHLEVEL_PACKAGE_MANAGER),yum)
++	$(MKDIR_P) $(DESTDIR)$(libdir)/yum-plugins $(DESTDIR)$(etcdir)/yum/pluginconf.d
++	$(INSTALL_DATA) yum-etckeeper.py $(DESTDIR)$(libdir)/yum-plugins/etckeeper.py
++	$(INSTALL_DATA) yum-etckeeper.conf $(DESTDIR)$(etcdir)/yum/pluginconf.d/etckeeper.conf
++endif
++	-./etckeeper-bzr/__init__.py install --root=$(DESTDIR) || echo "** bzr support not installed"
++	echo "** installation successful"
++
++clean: etckeeper.spec
++	rm -rf build
++
++etckeeper.spec:
++	sed -i "s/Version:.*/Version: $$(perl -e '$$_=<>;print m/\((.*?)\)/'<debian/changelog)/" etckeeper.spec
++
++.PHONY: etckeeper.spec
+diff --git a/configure.ac b/configure.ac
+new file mode 100644
+index 0000000..209d58c
+--- /dev/null
++++ b/configure.ac
+@@ -0,0 +1,13 @@
++AC_INIT([etckeeper], [0.37])
++
++dnl for MKDIR_P
++AC_PREREQ([2.60])
++
++AC_CONFIG_SRCDIR([etckeeper.8])
++
++AC_CONFIG_FILES([Makefile etckeeper])
++
++AC_PROG_INSTALL
++AC_PROG_MKDIR_P
++
++AC_OUTPUT
+\ No newline at end of file
+diff --git a/etckeeper b/etckeeper
+deleted file mode 100755
+index 1b6c76c..0000000
+--- a/etckeeper
++++ /dev/null
+@@ -1,92 +0,0 @@
+-#!/bin/sh
+-set -e
+-
+-if [ -z "$ETCKEEPER_CONF_DIR" ]; then
+-	ETCKEEPER_CONF_DIR=/etc/etckeeper
+-fi
+-
+-conf="$ETCKEEPER_CONF_DIR/etckeeper.conf"
+-
+-usage() {
+-	echo "usage: etckeeper command [-d directory]" >&2
+-	exit 1
+-}
+-
+-if [ -e $conf ]; then
+-	. $conf
+-fi
+-
+-if [ -z "$VCS" ]; then
+-	echo "Please configure a VCS in $conf" >&2
+-	exit 1
+-fi
+-export VCS
+-
+-if [ ! -z "$GIT_COMMIT_OPTIONS" ]; then
+-	export GIT_COMMIT_OPTIONS
+-fi
+-if [ ! -z "$HG_COMMIT_OPTIONS" ]; then
+-	export HG_COMMIT_OPTIONS
+-fi
+-if [ ! -z "$BZR_COMMIT_OPTIONS" ]; then
+-	export BZR_COMMIT_OPTIONS
+-fi
+-if [ ! -z "$DARCS_COMMIT_OPTIONS" ]; then
+-	export DARCS_COMMIT_OPTIONS
+-fi
+-
+-if [ ! -z "$HIGHLEVEL_PACKAGE_MANAGER" ]; then
+-	export HIGHLEVEL_PACKAGE_MANAGER
+-fi
+-if [ ! -z "$LOWLEVEL_PACKAGE_MANAGER" ]; then
+-	export LOWLEVEL_PACKAGE_MANAGER
+-fi
+-if [ ! -z "$AVOID_COMMIT_BEFORE_INSTALL" ]; then
+-	export AVOID_COMMIT_BEFORE_INSTALL
+-fi
+-
+-if [ -z "$1" ]; then
+-	usage
+-fi
+-command="$1"
+-shift 1
+-
+-# compatability code
+-if [ "$command" = "post-apt" ]; then
+-	command=post-install
+-elif [ "$command" = "pre-apt" ]; then
+-	command=pre-install
+-fi
+-
+-if [ ! -d "$ETCKEEPER_CONF_DIR/$command.d" ]; then
+-	echo "etckeeper: $ETCKEEPER_CONF_DIR/$command.d does not exist" >&2
+-	exit 1
+-fi
+-
+-if [ "x$1" = "x-d" ]; then
+-	if [ -n "$2" ]; then
+-		ETCKEEPER_DIR="$2"
+-		shift 2
+-	else
+-		usage
+-	fi
+-fi
+-
+-if [ -z "$ETCKEEPER_DIR" ]; then
+-	ETCKEEPER_DIR=/etc
+-fi
+-cd "$ETCKEEPER_DIR"
+-export ETCKEEPER_DIR
+-
+-lsscripts() {
+-	perl -e '
+-		$dir=shift;
+-		print join "\n", grep { ! -d $_ && -x $_ }
+-			grep /^\Q$dir\/\E[-a-zA-Z0-9]+$/,
+-			glob "$dir/*";
+-	' "$1"
+-}
+-
+-for script in $(lsscripts "$ETCKEEPER_CONF_DIR/$command.d"); do
+-	"$script" "$@"
+-done
+diff --git a/etckeeper.in b/etckeeper.in
+new file mode 100644
+index 0000000..6d91e8c
+--- /dev/null
++++ b/etckeeper.in
+@@ -0,0 +1,92 @@
++#!/bin/sh
++set -e
++
++if [ -z "$ETCKEEPER_CONF_DIR" ]; then
++	ETCKEEPER_CONF_DIR=@sysconfdir@/etckeeper
++fi
++
++conf="$ETCKEEPER_CONF_DIR/etckeeper.conf"
++
++usage() {
++	echo "usage: etckeeper command [-d directory]" >&2
++	exit 1
++}
++
++if [ -e $conf ]; then
++	. $conf
++fi
++
++if [ -z "$VCS" ]; then
++	echo "Please configure a VCS in $conf" >&2
++	exit 1
++fi
++export VCS
++
++if [ ! -z "$GIT_COMMIT_OPTIONS" ]; then
++	export GIT_COMMIT_OPTIONS
++fi
++if [ ! -z "$HG_COMMIT_OPTIONS" ]; then
++	export HG_COMMIT_OPTIONS
++fi
++if [ ! -z "$BZR_COMMIT_OPTIONS" ]; then
++	export BZR_COMMIT_OPTIONS
++fi
++if [ ! -z "$DARCS_COMMIT_OPTIONS" ]; then
++	export DARCS_COMMIT_OPTIONS
++fi
++
++if [ ! -z "$HIGHLEVEL_PACKAGE_MANAGER" ]; then
++	export HIGHLEVEL_PACKAGE_MANAGER
++fi
++if [ ! -z "$LOWLEVEL_PACKAGE_MANAGER" ]; then
++	export LOWLEVEL_PACKAGE_MANAGER
++fi
++if [ ! -z "$AVOID_COMMIT_BEFORE_INSTALL" ]; then
++	export AVOID_COMMIT_BEFORE_INSTALL
++fi
++
++if [ -z "$1" ]; then
++	usage
++fi
++command="$1"
++shift 1
++
++# compatability code
++if [ "$command" = "post-apt" ]; then
++	command=post-install
++elif [ "$command" = "pre-apt" ]; then
++	command=pre-install
++fi
++
++if [ ! -d "$ETCKEEPER_CONF_DIR/$command.d" ]; then
++	echo "etckeeper: $ETCKEEPER_CONF_DIR/$command.d does not exist" >&2
++	exit 1
++fi
++
++if [ "x$1" = "x-d" ]; then
++	if [ -n "$2" ]; then
++		ETCKEEPER_DIR="$2"
++		shift 2
++	else
++		usage
++	fi
++fi
++
++if [ -z "$ETCKEEPER_DIR" ]; then
++	ETCKEEPER_DIR=/etc
++fi
++cd "$ETCKEEPER_DIR"
++export ETCKEEPER_DIR
++
++lsscripts() {
++	perl -e '
++		$dir=shift;
++		print join "\n", grep { ! -d $_ && -x $_ }
++			grep /^\Q$dir\/\E[-a-zA-Z0-9]+$/,
++			glob "$dir/*";
++	' "$1"
++}
++
++for script in $(lsscripts "$ETCKEEPER_CONF_DIR/$command.d"); do
++	"$script" "$@"
++done
+diff --git a/install-sh b/install-sh
+new file mode 100755
+index 0000000..a5897de
+--- /dev/null
++++ b/install-sh
+@@ -0,0 +1,519 @@
++#!/bin/sh
++# install - install a program, script, or datafile
++
++scriptversion=2006-12-25.00
++
++# This originates from X11R5 (mit/util/scripts/install.sh), which was
++# later released in X11R6 (xc/config/util/install.sh) with the
++# following copyright and license.
++#
++# Copyright (C) 1994 X Consortium
++#
++# Permission is hereby granted, free of charge, to any person obtaining a copy
++# of this software and associated documentation files (the "Software"), to
++# deal in the Software without restriction, including without limitation the
++# rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
++# sell copies of the Software, and to permit persons to whom the Software is
++# furnished to do so, subject to the following conditions:
++#
++# The above copyright notice and this permission notice shall be included in
++# all copies or substantial portions of the Software.
++#
++# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
++# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
++# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL THE
++# X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
++# AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNEC-
++# TION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
++#
++# Except as contained in this notice, the name of the X Consortium shall not
++# be used in advertising or otherwise to promote the sale, use or other deal-
++# ings in this Software without prior written authorization from the X Consor-
++# tium.
++#
++#
++# FSF changes to this file are in the public domain.
++#
++# Calling this script install-sh is preferred over install.sh, to prevent
++# `make' implicit rules from creating a file called install from it
++# when there is no Makefile.
++#
++# This script is compatible with the BSD install script, but was written
++# from scratch.
++
++nl='
++'
++IFS=" ""	$nl"
++
++# set DOITPROG to echo to test this script
++
++# Don't use :- since 4.3BSD and earlier shells don't like it.
++doit=${DOITPROG-}
++if test -z "$doit"; then
++  doit_exec=exec
++else
++  doit_exec=$doit
++fi
++
++# Put in absolute file names if you don't have them in your path;
++# or use environment vars.
++
++chgrpprog=${CHGRPPROG-chgrp}
++chmodprog=${CHMODPROG-chmod}
++chownprog=${CHOWNPROG-chown}
++cmpprog=${CMPPROG-cmp}
++cpprog=${CPPROG-cp}
++mkdirprog=${MKDIRPROG-mkdir}
++mvprog=${MVPROG-mv}
++rmprog=${RMPROG-rm}
++stripprog=${STRIPPROG-strip}
++
++posix_glob='?'
++initialize_posix_glob='
++  test "$posix_glob" != "?" || {
++    if (set -f) 2>/dev/null; then
++      posix_glob=
++    else
++      posix_glob=:
++    fi
++  }
++'
++
++posix_mkdir=
++
++# Desired mode of installed file.
++mode=0755
++
++chgrpcmd=
++chmodcmd=$chmodprog
++chowncmd=
++mvcmd=$mvprog
++rmcmd="$rmprog -f"
++stripcmd=
++
++src=
++dst=
++dir_arg=
++dst_arg=
++
++copy_on_change=false
++no_target_directory=
++
++usage="\
++Usage: $0 [OPTION]... [-T] SRCFILE DSTFILE
++   or: $0 [OPTION]... SRCFILES... DIRECTORY
++   or: $0 [OPTION]... -t DIRECTORY SRCFILES...
++   or: $0 [OPTION]... -d DIRECTORIES...
++
++In the 1st form, copy SRCFILE to DSTFILE.
++In the 2nd and 3rd, copy all SRCFILES to DIRECTORY.
++In the 4th, create DIRECTORIES.
++
++Options:
++     --help     display this help and exit.
++     --version  display version info and exit.
++
++  -c            (ignored)
++  -C            install only if different (preserve the last data modification time)
++  -d            create directories instead of installing files.
++  -g GROUP      $chgrpprog installed files to GROUP.
++  -m MODE       $chmodprog installed files to MODE.
++  -o USER       $chownprog installed files to USER.
++  -s            $stripprog installed files.
++  -t DIRECTORY  install into DIRECTORY.
++  -T            report an error if DSTFILE is a directory.
++
++Environment variables override the default commands:
++  CHGRPPROG CHMODPROG CHOWNPROG CMPPROG CPPROG MKDIRPROG MVPROG
++  RMPROG STRIPPROG
++"
++
++while test $# -ne 0; do
++  case $1 in
++    -c) ;;
++
++    -C) copy_on_change=true;;
++
++    -d) dir_arg=true;;
++
++    -g) chgrpcmd="$chgrpprog $2"
++	shift;;
++
++    --help) echo "$usage"; exit $?;;
++
++    -m) mode=$2
++	case $mode in
++	  *' '* | *'	'* | *'
++'*	  | *'*'* | *'?'* | *'['*)
++	    echo "$0: invalid mode: $mode" >&2
++	    exit 1;;
++	esac
++	shift;;
++
++    -o) chowncmd="$chownprog $2"
++	shift;;
++
++    -s) stripcmd=$stripprog;;
++
++    -t) dst_arg=$2
++	shift;;
++
++    -T) no_target_directory=true;;
++
++    --version) echo "$0 $scriptversion"; exit $?;;
++
++    --)	shift
++	break;;
++
++    -*)	echo "$0: invalid option: $1" >&2
++	exit 1;;
++
++    *)  break;;
++  esac
++  shift
++done
++
++if test $# -ne 0 && test -z "$dir_arg$dst_arg"; then
++  # When -d is used, all remaining arguments are directories to create.
++  # When -t is used, the destination is already specified.
++  # Otherwise, the last argument is the destination.  Remove it from $@.
++  for arg
++  do
++    if test -n "$dst_arg"; then
++      # $@ is not empty: it contains at least $arg.
++      set fnord "$@" "$dst_arg"
++      shift # fnord
++    fi
++    shift # arg
++    dst_arg=$arg
++  done
++fi
++
++if test $# -eq 0; then
++  if test -z "$dir_arg"; then
++    echo "$0: no input file specified." >&2
++    exit 1
++  fi
++  # It's OK to call `install-sh -d' without argument.
++  # This can happen when creating conditional directories.
++  exit 0
++fi
++
++if test -z "$dir_arg"; then
++  trap '(exit $?); exit' 1 2 13 15
++
++  # Set umask so as not to create temps with too-generous modes.
++  # However, 'strip' requires both read and write access to temps.
++  case $mode in
++    # Optimize common cases.
++    *644) cp_umask=133;;
++    *755) cp_umask=22;;
++
++    *[0-7])
++      if test -z "$stripcmd"; then
++	u_plus_rw=
++      else
++	u_plus_rw='% 200'
++      fi
++      cp_umask=`expr '(' 777 - $mode % 1000 ')' $u_plus_rw`;;
++    *)
++      if test -z "$stripcmd"; then
++	u_plus_rw=
++      else
++	u_plus_rw=,u+rw
++      fi
++      cp_umask=$mode$u_plus_rw;;
++  esac
++fi
++
++for src
++do
++  # Protect names starting with `-'.
++  case $src in
++    -*) src=./$src;;
++  esac
++
++  if test -n "$dir_arg"; then
++    dst=$src
++    dstdir=$dst
++    test -d "$dstdir"
++    dstdir_status=$?
++  else
++
++    # Waiting for this to be detected by the "$cpprog $src $dsttmp" command
++    # might cause directories to be created, which would be especially bad
++    # if $src (and thus $dsttmp) contains '*'.
++    if test ! -f "$src" && test ! -d "$src"; then
++      echo "$0: $src does not exist." >&2
++      exit 1
++    fi
++
++    if test -z "$dst_arg"; then
++      echo "$0: no destination specified." >&2
++      exit 1
++    fi
++
++    dst=$dst_arg
++    # Protect names starting with `-'.
++    case $dst in
++      -*) dst=./$dst;;
++    esac
++
++    # If destination is a directory, append the input filename; won't work
++    # if double slashes aren't ignored.
++    if test -d "$dst"; then
++      if test -n "$no_target_directory"; then
++	echo "$0: $dst_arg: Is a directory" >&2
++	exit 1
++      fi
++      dstdir=$dst
++      dst=$dstdir/`basename "$src"`
++      dstdir_status=0
++    else
++      # Prefer dirname, but fall back on a substitute if dirname fails.
++      dstdir=`
++	(dirname "$dst") 2>/dev/null ||
++	expr X"$dst" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
++	     X"$dst" : 'X\(//\)[^/]' \| \
++	     X"$dst" : 'X\(//\)$' \| \
++	     X"$dst" : 'X\(/\)' \| . 2>/dev/null ||
++	echo X"$dst" |
++	    sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{
++		   s//\1/
++		   q
++		 }
++		 /^X\(\/\/\)[^/].*/{
++		   s//\1/
++		   q
++		 }
++		 /^X\(\/\/\)$/{
++		   s//\1/
++		   q
++		 }
++		 /^X\(\/\).*/{
++		   s//\1/
++		   q
++		 }
++		 s/.*/./; q'
++      `
++
++      test -d "$dstdir"
++      dstdir_status=$?
++    fi
++  fi
++
++  obsolete_mkdir_used=false
++
++  if test $dstdir_status != 0; then
++    case $posix_mkdir in
++      '')
++	# Create intermediate dirs using mode 755 as modified by the umask.
++	# This is like FreeBSD 'install' as of 1997-10-28.
++	umask=`umask`
++	case $stripcmd.$umask in
++	  # Optimize common cases.
++	  *[2367][2367]) mkdir_umask=$umask;;
++	  .*0[02][02] | .[02][02] | .[02]) mkdir_umask=22;;
++
++	  *[0-7])
++	    mkdir_umask=`expr $umask + 22 \
++	      - $umask % 100 % 40 + $umask % 20 \
++	      - $umask % 10 % 4 + $umask % 2
++	    `;;
++	  *) mkdir_umask=$umask,go-w;;
++	esac
++
++	# With -d, create the new directory with the user-specified mode.
++	# Otherwise, rely on $mkdir_umask.
++	if test -n "$dir_arg"; then
++	  mkdir_mode=-m$mode
++	else
++	  mkdir_mode=
++	fi
++
++	posix_mkdir=false
++	case $umask in
++	  *[123567][0-7][0-7])
++	    # POSIX mkdir -p sets u+wx bits regardless of umask, which
++	    # is incompatible with FreeBSD 'install' when (umask & 300) != 0.
++	    ;;
++	  *)
++	    tmpdir=${TMPDIR-/tmp}/ins$RANDOM-$$
++	    trap 'ret=$?; rmdir "$tmpdir/d" "$tmpdir" 2>/dev/null; exit $ret' 0
++
++	    if (umask $mkdir_umask &&
++		exec $mkdirprog $mkdir_mode -p -- "$tmpdir/d") >/dev/null 2>&1
++	    then
++	      if test -z "$dir_arg" || {
++		   # Check for POSIX incompatibilities with -m.
++		   # HP-UX 11.23 and IRIX 6.5 mkdir -m -p sets group- or
++		   # other-writeable bit of parent directory when it shouldn't.
++		   # FreeBSD 6.1 mkdir -m -p sets mode of existing directory.
++		   ls_ld_tmpdir=`ls -ld "$tmpdir"`
++		   case $ls_ld_tmpdir in
++		     d????-?r-*) different_mode=700;;
++		     d????-?--*) different_mode=755;;
++		     *) false;;
++		   esac &&
++		   $mkdirprog -m$different_mode -p -- "$tmpdir" && {
++		     ls_ld_tmpdir_1=`ls -ld "$tmpdir"`
++		     test "$ls_ld_tmpdir" = "$ls_ld_tmpdir_1"
++		   }
++		 }
++	      then posix_mkdir=:
++	      fi
++	      rmdir "$tmpdir/d" "$tmpdir"
++	    else
++	      # Remove any dirs left behind by ancient mkdir implementations.
++	      rmdir ./$mkdir_mode ./-p ./-- 2>/dev/null
++	    fi
++	    trap '' 0;;
++	esac;;
++    esac
++
++    if
++      $posix_mkdir && (
++	umask $mkdir_umask &&
++	$doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir"
++      )
++    then :
++    else
++
++      # The umask is ridiculous, or mkdir does not conform to POSIX,
++      # or it failed possibly due to a race condition.  Create the
++      # directory the slow way, step by step, checking for races as we go.
++
++      case $dstdir in
++	/*) prefix='/';;
++	-*) prefix='./';;
++	*)  prefix='';;
++      esac
++
++      eval "$initialize_posix_glob"
++
++      oIFS=$IFS
++      IFS=/
++      $posix_glob set -f
++      set fnord $dstdir
++      shift
++      $posix_glob set +f
++      IFS=$oIFS
++
++      prefixes=
++
++      for d
++      do
++	test -z "$d" && continue
++
++	prefix=$prefix$d
++	if test -d "$prefix"; then
++	  prefixes=
++	else
++	  if $posix_mkdir; then
++	    (umask=$mkdir_umask &&
++	     $doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir") && break
++	    # Don't fail if two instances are running concurrently.
++	    test -d "$prefix" || exit 1
++	  else
++	    case $prefix in
++	      *\'*) qprefix=`echo "$prefix" | sed "s/'/'\\\\\\\\''/g"`;;
++	      *) qprefix=$prefix;;
++	    esac
++	    prefixes="$prefixes '$qprefix'"
++	  fi
++	fi
++	prefix=$prefix/
++      done
++
++      if test -n "$prefixes"; then
++	# Don't fail if two instances are running concurrently.
++	(umask $mkdir_umask &&
++	 eval "\$doit_exec \$mkdirprog $prefixes") ||
++	  test -d "$dstdir" || exit 1
++	obsolete_mkdir_used=true
++      fi
++    fi
++  fi
++
++  if test -n "$dir_arg"; then
++    { test -z "$chowncmd" || $doit $chowncmd "$dst"; } &&
++    { test -z "$chgrpcmd" || $doit $chgrpcmd "$dst"; } &&
++    { test "$obsolete_mkdir_used$chowncmd$chgrpcmd" = false ||
++      test -z "$chmodcmd" || $doit $chmodcmd $mode "$dst"; } || exit 1
++  else
++
++    # Make a couple of temp file names in the proper directory.
++    dsttmp=$dstdir/_inst.$$_
++    rmtmp=$dstdir/_rm.$$_
++
++    # Trap to clean up those temp files at exit.
++    trap 'ret=$?; rm -f "$dsttmp" "$rmtmp" && exit $ret' 0
++
++    # Copy the file name to the temp name.
++    (umask $cp_umask && $doit_exec $cpprog "$src" "$dsttmp") &&
++
++    # and set any options; do chmod last to preserve setuid bits.
++    #
++    # If any of these fail, we abort the whole thing.  If we want to
++    # ignore errors from any of these, just make sure not to ignore
++    # errors from the above "$doit $cpprog $src $dsttmp" command.
++    #
++    { test -z "$chowncmd" || $doit $chowncmd "$dsttmp"; } &&
++    { test -z "$chgrpcmd" || $doit $chgrpcmd "$dsttmp"; } &&
++    { test -z "$stripcmd" || $doit $stripcmd "$dsttmp"; } &&
++    { test -z "$chmodcmd" || $doit $chmodcmd $mode "$dsttmp"; } &&
++
++    # If -C, don't bother to copy if it wouldn't change the file.
++    if $copy_on_change &&
++       old=`LC_ALL=C ls -dlL "$dst"	2>/dev/null` &&
++       new=`LC_ALL=C ls -dlL "$dsttmp"	2>/dev/null` &&
++
++       eval "$initialize_posix_glob" &&
++       $posix_glob set -f &&
++       set X $old && old=:$2:$4:$5:$6 &&
++       set X $new && new=:$2:$4:$5:$6 &&
++       $posix_glob set +f &&
++
++       test "$old" = "$new" &&
++       $cmpprog "$dst" "$dsttmp" >/dev/null 2>&1
++    then
++      rm -f "$dsttmp"
++    else
++      # Rename the file to the real destination.
++      $doit $mvcmd -f "$dsttmp" "$dst" 2>/dev/null ||
++
++      # The rename failed, perhaps because mv can't rename something else
++      # to itself, or perhaps because mv is so ancient that it does not
++      # support -f.
++      {
++	# Now remove or move aside any old file at destination location.
++	# We try this two ways since rm can't unlink itself on some
++	# systems and the destination file might be busy for other
++	# reasons.  In this case, the final cleanup might fail but the new
++	# file should still install successfully.
++	{
++	  test ! -f "$dst" ||
++	  $doit $rmcmd -f "$dst" 2>/dev/null ||
++	  { $doit $mvcmd -f "$dst" "$rmtmp" 2>/dev/null &&
++	    { $doit $rmcmd -f "$rmtmp" 2>/dev/null; :; }
++	  } ||
++	  { echo "$0: cannot unlink or rename $dst" >&2
++	    (exit 1); exit 1
++	  }
++	} &&
++
++	# Now rename the file to the real destination.
++	$doit $mvcmd "$dsttmp" "$dst"
++      }
++    fi || exit 1
++
++    trap '' 0
++  fi
++done
++
++# Local variables:
++# eval: (add-hook 'write-file-hooks 'time-stamp)
++# time-stamp-start: "scriptversion="
++# time-stamp-format: "%:y-%02m-%02d.%02H"
++# time-stamp-end: "$"
++# End:


This was sent by the SourceForge.net collaborative development platform, the world's largest Open Source development site.



More information about the devel mailing list