X-Git-Url: http://xvm.mit.edu/gitweb/invirt/scripts/git-migration.git/blobdiff_plain/55d9f8723b2aa4d856e9d1fcf3a9d31c75dd27c7..6cd8f7d2c08eb975fe11c92c9534ccd18714634d:/git-migrate-fast.sh diff --git a/git-migrate-fast.sh b/git-migrate-fast.sh index 2fdbe30..1cde7d5 100755 --- a/git-migrate-fast.sh +++ b/git-migrate-fast.sh @@ -1,6 +1,14 @@ #!/bin/bash set -e +# Depends: python-yaml, python-mako +# and svn-all-fast-export, which comes from git://repo.or.cz/svn-all-fast-export +# (except you actually want git://andersk.mit.edu/svn-all-fast-export localtime) +# and builds with `qmake && make` with +# Build-Depends: libqt4-dev, libsvn-dev + +# Usage: ./git-migrate-fast.sh [svn-uri] +# Exports into new subdir ./git . SVN=${1:-/mit/xvm/svn} mako-render rules.mako > rules @@ -10,13 +18,106 @@ mkdir git cd git sed -n 's/^create repository // p' ../rules | while read repo; do - mkdir -p "$repo" && GIT_DIR="$repo" git init --bare + mkdir -p "$repo" && GIT_DIR="$repo" git init --bare && GIT_DIR="$repo" git symbolic-ref HEAD refs/heads/prod done -svn-all-fast-export --identity-map <(sed 's/= //' ../authors) ../rules "$SVN" +svn-all-fast-export --identity-map ../authors ../rules "$SVN" -sed -n 's/^create repository // p' ../rules | while read repo; do - ! [ -e "$repo/refs/heads/tags" ] || \ - cp -a "$repo/refs/heads/tags/." "$repo/refs/tags" && \ - rm -rf "$repo/refs/heads/tags" +pushd packages/invirt-dev.git +GIT_COMMITTER_NAME='Eric Price' GIT_COMMITTER_EMAIL='ecprice@mit.edu' GIT_COMMITTER_DATE='1206829393 -0400' \ + git tag -a sipb-xen-dev/13 sipb-xen-dev/14~2 -F - <> info/grafts +git filter-branch --tag-name-filter cat -- ^invirt-remote-server ^invirt-remote-host --all +rm -rf info/grafts refs/original refs/heads/invirt-remote-server refs/heads/invirt-remote-host +popd + +pushd packages/invirt-console.git +echo $(git rev-parse 0.2.0^0 0.2.0^ invirt-console-host) >> info/grafts +git filter-branch --tag-name-filter cat -- ^0.2.0^ ^invirt-console-host --all +rm -rf info/grafts refs/original refs/heads/invirt-console-host +popd + +pushd packages/invirt-dns.git +echo $(git rev-parse sipb-xen-dns/1~10 sipb-xen-dns/1~11 dns) >> info/grafts +git filter-branch --tag-name-filter cat -- ^sipb-xen-dns/1~11 ^dns --all +rm -rf info/grafts refs/original refs/heads/dns +popd + +pushd packages/invirt-database.git +echo $(git rev-parse invirt-database-server/0.0.1^0 0.0.1^) >> info/grafts +echo $(git rev-parse 0.2.0^0 0.2.0^ invirt-database-server) >> info/grafts +git filter-branch --tag-name-filter cat -- ^0.2.0^ --all +rm -rf info/grafts refs/original refs/heads/invirt-database-server +popd + +pushd packages/invirt-web.git +echo $(git rev-parse 0.1.0^0 0.0.24^0 cherrypy-rebased^1) >> info/grafts +echo $(git rev-parse 0.1.1~3 0.1.0^0 cherrypy-rebased^0) >> info/grafts +git filter-branch --tag-name-filter cat -- ^0.0.24^ --all +rm -rf info/grafts refs/original +popd + +pushd packages/python-routefs.git +git fetch -t git://github.com/ebroder/python-routefs.git +git branch -f upstream 1.0.1 +git branch -f prod 1.0.1-1 +popd + +pushd packages/python-afs.git +git fetch -t git://github.com/ebroder/pyafs.git +git branch -f upstream 0.1.1 +git branch -f prod 0.1.1-1 +popd + +for r in $(ls packages); do + pushd "packages/$r" + git branch dev prod + popd done + +mkdir packages.git +pushd packages.git +git init --bare +git symbolic-ref HEAD refs/heads/prod +( + echo 'commit refs/heads/prod' + echo 'mark :1' + echo 'committer Invirt Git Import now' + echo 'data </dev/null + commit="$(git rev-parse refs/heads/prod)" + popd &>/dev/null + + echo "M 160000 $commit ${r%.git}" + done + + echo 'M 100644 inline .gitmodules' + echo 'data <