Revision: 17631 http://gar.svn.sourceforge.net/gar/?rev=17631&view=rev Author: bdwalton Date: 2012-04-09 01:59:12 +0000 (Mon, 09 Apr 2012) Log Message: ----------- git/trunk: revert to default SANE_TOOL_PATH, work around bug in xpg4/sed
Modified Paths: -------------- csw/mgar/pkg/git/trunk/Makefile Added Paths: ----------- csw/mgar/pkg/git/trunk/files/0009-Avoid-bug-in-Solaris-xpg4-sed-as-used-in-submodule.patch Modified: csw/mgar/pkg/git/trunk/Makefile =================================================================== --- csw/mgar/pkg/git/trunk/Makefile 2012-04-07 19:18:22 UTC (rev 17630) +++ csw/mgar/pkg/git/trunk/Makefile 2012-04-09 01:59:12 UTC (rev 17631) @@ -117,6 +117,7 @@ PATCHFILES += 0007-on-solaris-we-need-to-use-lintl-to-allow-the-new-i18.patch PATCHFILES += 0008-run-command.c-Define-SHELL_PATH-macro-for-use-in-pre.patch PATCHFILES += 0009-Makefile-Set-EXTRA_CPPFLAGS-during-the-compilation-o.patch +PATCHFILES += 0009-Avoid-bug-in-Solaris-xpg4-sed-as-used-in-submodule.patch fdirs = $(bindir_install) $(mandir) $(libexecdir_install) define _git_files @@ -152,7 +153,6 @@ CONFIGURE_ARGS += --with-gitconfig=$(sysconfdir)/gitconfig CONFIGURE_ARGS += --with-pager=/opt/csw/bin/less CONFIGURE_ARGS += --without-python -CONFIGURE_ARGS += --with-sane-tool-path=/opt/csw/gnu:/opt/csw/bin:/usr/xpg6/bin:/usr/xpg4/bin BUILD_ARGS = MSGFMT=gmsgfmt SHELL_PATH=/opt/csw/bin/bash \ ASCIIDOC_NO_ROFF=YesPlease \ Added: csw/mgar/pkg/git/trunk/files/0009-Avoid-bug-in-Solaris-xpg4-sed-as-used-in-submodule.patch =================================================================== --- csw/mgar/pkg/git/trunk/files/0009-Avoid-bug-in-Solaris-xpg4-sed-as-used-in-submodule.patch (rev 0) +++ csw/mgar/pkg/git/trunk/files/0009-Avoid-bug-in-Solaris-xpg4-sed-as-used-in-submodule.patch 2012-04-09 01:59:12 UTC (rev 17631) @@ -0,0 +1,56 @@ +From 097f067a25220fc3cc315163dfef07de6a1c5f20 Mon Sep 17 00:00:00 2001 +From: Ben Walton <bwal...@opencsw.org> +Date: Mon, 9 Apr 2012 03:14:18 +0200 +Subject: [PATCH] Avoid bug in Solaris xpg4/sed as used in submodule + +The sed provided by Solaris in /usr/xpg4/bin has a bug whereby an +unanchored regex using * for zero or more repetitions sees two +separate matches fed to the substitution engine in some cases. + +This is evidenced by: + +$ for sed in /usr/xpg4/bin/sed /usr/bin/sed /opt/csw/gnu/sed; do \ +echo 'ab' | $sed -e 's|[a]*|X|g' \ +done +XXbX +XbX +XbX + +This bug was triggered during a git submodule clone operation as +exercised in the setup stage of t5526-fetch-submodules when using the +default SANE_TOOL_PATH for Solaris. It led to paths such as +..../.. being used in the submodule .git gitdir reference. + +Using the expression 's|\([^/]*\(/*\)\)|..\2|g' provides the desired +result with all three three tested sed implementations but is harder +to read. Instead, use an additional -e script to clean up after the +bug on Solaris. The second script will be a functional no-op on most +sed implementations. + +Signed-off-by: Ben Walton <bwal...@opencsw.org> +--- + git-submodule.sh | 6 ++++-- + 1 files changed, 4 insertions(+), 2 deletions(-) + +diff --git a/git-submodule.sh b/git-submodule.sh +index efc86ad..0adad22 100755 +--- a/git-submodule.sh ++++ b/git-submodule.sh +@@ -167,10 +167,12 @@ module_clone() + a=${a%/} + b=${b%/} + +- rel=$(echo $b | sed -e 's|[^/]*|..|g') ++ # Note: The second -e is to work around a bug in Solairs' ++ # xpg4/sed. It will be a no-op in a working implementation. ++ rel=$(echo $b | sed -e 's|[^/]*|..|g' -e 's|\.\{4\}|..|g') + echo "gitdir: $rel/$a" >"$path/.git" + +- rel=$(echo $a | sed -e 's|[^/]*|..|g') ++ rel=$(echo $a | sed -e 's|[^/]*|..|g' -e 's|\.\{4\}|..|g') + (clear_local_git_env; cd "$path" && GIT_WORK_TREE=. git config core.worktree "$rel/$b") + } + +-- +1.7.9 + This was sent by the SourceForge.net collaborative development platform, the world's largest Open Source development site. _______________________________________________ devel mailing list devel@lists.opencsw.org https://lists.opencsw.org/mailman/listinfo/devel