annotate extra/soundsoftware/export-git.sh @ 1549:28cde511f312 feature_1136

Force flag is needed here
author Chris Cannam
date Tue, 12 Jan 2016 17:32:54 +0000
parents bca3b5e5bbf2
children 7d825cbd76c8
rev   line source
Chris@1543 1 #!/bin/bash
Chris@1543 2
Chris@1543 3 set -e
Chris@1543 4
Chris@1543 5 progdir=$(dirname $0)
Chris@1543 6 case "$progdir" in
Chris@1543 7 /*) ;;
Chris@1543 8 *) progdir="$(pwd)/$progdir" ;;
Chris@1543 9 esac
Chris@1543 10
Chris@1543 11 rails_scriptdir="$progdir/../../script"
Chris@1543 12 rails="$rails_scriptdir/rails"
Chris@1543 13
Chris@1543 14 if [ ! -x "$rails" ]; then
Chris@1543 15 echo "Expected to find rails executable at $rails"
Chris@1543 16 exit 2
Chris@1543 17 fi
Chris@1543 18
Chris@1543 19 fastexport="$progdir/../fast-export/hg-fast-export.sh"
Chris@1543 20 if [ ! -x "$fastexport" ]; then
Chris@1543 21 echo "Expected to find hg-fast-export.sh executable at $fastexport"
Chris@1543 22 exit 2
Chris@1543 23 fi
Chris@1543 24
Chris@1546 25 environment="$1"
Chris@1546 26 hgdir="$2"
Chris@1546 27 gitdir="$3"
Chris@1543 28
Chris@1543 29 if [ -z "$hgdir" ] || [ -z "$gitdir" ]; then
Chris@1546 30 echo "Usage: $0 <environment> <hgdir> <gitdir>"
Chris@1546 31 echo " where"
Chris@1546 32 echo " - environment is the Rails environment (development or production)"
Chris@1546 33 echo " - hgdir is the directory containing project Mercurial repositories"
Chris@1546 34 echo " - gitdir is the directory in which output git repositories are to be"
Chris@1546 35 echo " created or updated"
Chris@1543 36 exit 2
Chris@1543 37 fi
Chris@1543 38
Chris@1543 39 if [ ! -d "$hgdir" ]; then
Chris@1543 40 echo "Mercurial repository directory $hgdir not found"
Chris@1543 41 exit 1
Chris@1543 42 fi
Chris@1543 43
Chris@1543 44 if [ ! -d "$gitdir" ]; then
Chris@1543 45 echo "Target git repository dir $gitdir not found (please create at least the empty directory)"
Chris@1543 46 exit 1
Chris@1543 47 fi
Chris@1543 48
Chris@1543 49 set -u
Chris@1543 50
Chris@1543 51 authordir="$gitdir/AUTHORMAPS"
Chris@1543 52
Chris@1543 53 mkdir -p "$authordir"
Chris@1543 54
Chris@1547 55 echo "Extracting author maps..."
Chris@1546 56
Chris@1546 57 "$rails" runner -e "$environment" "$progdir/create-repo-authormaps.rb" \
Chris@1543 58 -s "$hgdir" -o "$authordir"
Chris@1543 59
Chris@1543 60 for hgrepo in "$hgdir"/*; do
Chris@1543 61
Chris@1543 62 if [ ! -d "$hgrepo/.hg" ]; then
Chris@1543 63 echo "Directory $hgrepo does not appear to be a Mercurial repo, skipping"
Chris@1543 64 continue
Chris@1543 65 fi
Chris@1543 66
Chris@1543 67 reponame=$(basename "$hgrepo")
Chris@1543 68 authormap="$authordir/authormap_$reponame"
Chris@1543 69 gitrepo="$gitdir/$reponame"
Chris@1543 70
Chris@1543 71 if [ ! -f "$authormap" ]; then
Chris@1547 72 echo "No authormap file was created for repo $reponame, skipping"
Chris@1543 73 continue
Chris@1543 74 fi
Chris@1543 75
Chris@1543 76 if [ ! -d "$gitrepo" ]; then
Chris@1543 77 git init "$gitrepo"
Chris@1543 78 fi
Chris@1543 79
Chris@1547 80 echo
Chris@1546 81 echo "About to run fast export for repo $reponame..."
Chris@1543 82
Chris@1543 83 (
Chris@1543 84 cd "$gitrepo"
Chris@1549 85
Chris@1549 86 # Force is necessary because git-fast-import (or git) can't handle
Chris@1549 87 # branches having more than one head ("Error: repository has at
Chris@1549 88 # least one unnamed head"), which happens from time to time in
Chris@1549 89 # valid Hg repos. With --force apparently it will just pick one
Chris@1549 90 # of the two heads arbitrarily, which is also alarming but is
Chris@1549 91 # more likely to be useful
Chris@1549 92 "$fastexport" --quiet -r "$hgrepo" -A "$authormap" --hg-hash --force
Chris@1543 93 )
Chris@1543 94
Chris@1543 95 echo "Fast export done"
Chris@1543 96
Chris@1543 97 done
Chris@1543 98
Chris@1543 99 echo "All done"
Chris@1543 100