From: Junio C Hamano Date: Mon, 11 Jul 2005 20:30:54 +0000 (-0700) Subject: [PATCH] git-clone-script local optimization tweaks X-Git-Tag: v0.99.1~59 X-Git-Url: https://git.verplant.org/?a=commitdiff_plain;h=ab6625e06a647c4be555cadc63dfa8f0d4a7f48e;p=git.git [PATCH] git-clone-script local optimization tweaks - When local optimization is used, the variable repo has already been passed through get_repo_base so there is no need to check for .git subdirectory in there. - Use cpio -l instead of "cp -l". Signed-off-by: Junio C Hamano Signed-off-by: Linus Torvalds --- diff --git a/git-clone-script b/git-clone-script index 5a241fb2..f92851ca 100755 --- a/git-clone-script +++ b/git-clone-script @@ -48,11 +48,8 @@ test -d "$D" || usage case "$local,$use_local" in yes,yes) ( cd "$repo/objects" ) || { - repo="$repo/.git" - ( cd "$repo/objects" ) || { - echo >&2 "-l flag seen but $repo is not local." - exit 1 - } + echo >&2 "-l flag seen but $repo is not local." + exit 1 } # See if we can hardlink and drop "l" if not. @@ -68,7 +65,9 @@ yes,yes) l=l fi && rm -f "$D/.git/objects/sample" && - cp -r$l "$repo/objects" "$D/.git/" || exit 1 + cd "$repo" && + find objects -type f -print | + cpio -puamd$l "$D/.git/" || exit 1 # Make a duplicate of refs and HEAD pointer HEAD=