Ceci est une ancienne révision du document !
Table des matières
Notes git svn
Voir :
Config
Source : http://labs.excilys.com/2012/04/30/git-svn/
git svn init -s http://subversion-server/monprojet/
Changer .git/config
- .git/config
[svn-remote "svn"] url = svn://serveur-svn:3690 fetch = monprojet/trunk:refs/remotes/origin/trunk branches = monprojet/branches/*:refs/remotes/origin/* tags = monprojet/tags/*:refs/remotes/origin/tags/*
En
- .git/config
[svn-remote "svn"] url = svn://serveur-svn:3690/monprojet fetch = trunk:refs/remotes/svn/trunk branches = branches/*:refs/remotes/svn/branches/* tags = tags/*:refs/remotes/svn/tags/*
Récupération
git svn fetch
Utilisation
Commande locales normales (add, commit)
git commit -a -m "* test"
Push sur SVN
git svn fetch git svn rebase --dry-run git svn rebase git svn dcommit
Push sur git (si utilisation en parallèle d'un dépôt git)
git pull git push
Exemple - fichier .git/config
- .git/config
[core] repositoryformatversion = 0 filemode = true bare = false logallrefupdates = true [svn-remote "svn"] url = svn://serveur-svn:3690/monprojet fetch = trunk:refs/remotes/svn/trunk branches = branches/*:refs/remotes/svn/branches/* tags = tags/*:refs/remotes/svn/tags/* [remote "origin"] url = ssh://git@git.acme.fr:443/ACME/monprojet fetch = +refs/heads/*:refs/remotes/origin/* [branch "master"] remote = origin merge = refs/heads/master
Migration
Voir https://git-scm.com/book/fr/v1/Git-et-les-autres-syst%C3%A8mes-Migrer-sur-Git
Clone du dépôt subversion
git svn clone svn://serveur-svn:3690/monprojet
The code will be available as a git repository. You can do your work there and make local commits as you please. There is a command line option to get a “shallow” checkout rather than the entire repository which is often useful. I forget what it is.
Anytime, you want to run the equivalent of
svn update, do a git svn rebase
. This will fetch new commits which were checked into SVN after you last synchronised and then rebase your changes onto the new tip.
When you're ready with your commits, do a git svn dcommit. This will send all your new commits to svn one by one. You can also squash your local commits into a single one and send it by first doing a local rebase and then an svn dcommit. This should be done on the initial branch (usually master).
The very fact that you're checking out from subversion and then working locally in git means that there is “interaction” between them so your last statement is not valid.
