2010-03-29 7 views

Répondre

7

Disons que nous avons un dépôt Subversion squelette avec vide trunk/, branches/ et tags/:

/tmp$ git svn clone -s file:///tmp/svn-repo/ git-svn-repo 
Initialized empty Git repository in /tmp/git-svn-repo/.git/ 
r1 = 80bdcfc0cf248b74b914a1b5f99ab89fb4e31b6c (refs/remotes/trunk) 
Checked out HEAD: 
    file:///tmp/svn-repo/trunk r1 

/tmp$ cd git-svn-repo/ 

/tmp/git-svn-repo$ git svn branch my-branch 
Copying file:///tmp/svn-repo/trunk at r1 to file:///tmp/svn-repo/branches/my-branch... 
Found possible branch point: file:///tmp/svn-repo/trunk => file:///tmp/svn-repo/branches/my-branch, 1 
Found branch parent: (refs/remotes/my-branch) 80bdcfc0cf248b74b914a1b5f99ab89fb4e31b6c 
Following parent with do_switch 
Successfully followed parent 
r2 = 56150bbd9d3aec94972ff46d030e30ec726595ab (refs/remotes/my-branch)

L'explication ci-dessous repassera-et-vient entre deux vues du même référentiel, une Subversion copie de travail le repo entier (pas seulement trunk) et un clone git-svn. Pour plus de clarté, le préfixe de chaque invite de shell indiquera le répertoire courant.

Du côté svn, vous allez maintenant voir

/tmp/svn-repo-wc$ svn up 
A branches/my-branch 
Updated to revision 2.

Vous verrez également la nouvelle branche du côté git:

/tmp/git-svn-repo$ git branch -r 
    my-branch 
    trunk

Commettre à la branche nouvellement créée, d'abord passer à elle:

/tmp/git-svn-repo$ git reset --hard remotes/my-branch 
HEAD is now at 2c9bef2 Create branch my-branch

Ensuite, nous allons créer un git commit factice

/tmp/git-svn-repo$ touch on-my-branch 
/tmp/git-svn-repo$ git add on-my-branch 
/tmp/git-svn-repo$ git commit -m 'First commit to my-branch' 
[master b94a0eb] First commit to my-branch 
0 files changed, 0 insertions(+), 0 deletions(-) 
create mode 100644 on-my-branch

et enfin l'envoyer à Subversion:

/tmp/git-svn-repo$ git svn dcommit 
Committing to file:///tmp/svn-repo/branches/my-branch ... 
    A on-my-branch 
Committed r3 
    A on-my-branch 
r3 = d3c5ba3e03e5cdee96f470ff4c9898eb7c523ed8 (refs/remotes/my-branch) 
No changes between current HEAD and refs/remotes/my-branch 
Resetting to the latest refs/remotes/my-branch

Le travail Subversion copie nous donne confirmation:

/tmp/svn-repo-wc$ svn up 
A branches/my-branch/on-my-branch 
Updated to revision 3.
+0

comme indiqué sur http://stackoverflow.com/questions/266395/ git-svn-comment-je-crée-une-nouvelle-svn-branche-via-git vous pouvez maintenant passer à une branche svn au lieu de faire la réinitialisation --hard: 'git checkout -b my-local -branch remote-branch' '# edit' 'git commit' ' git svn dcommit' 'git checkout master # pour travailler de nouveau sur le tronc' – jackbravo

Questions connexes