I'm currently working on several projects on my own (at least the developing part is done only by me :). Using Eclipse with different Java, R, SQL and other source files I'm wondering what version control system would be best for me.
At the time the history of Eclipse IDE seems to be enough, but I'm not sure if this will be true in a month/year...
What solution would you recommend and why?
To be more precise: I'm quite sure to use SVN or git if I decide to use a full version control system. But I'm just not sure if it is necessary...
small update: has the release of Eclipse Helios added new opinions?
a/ It is necessary to have a VCS
b/ CVCS and DVCS are quite different
c/ Eclipse is currently moving all its project to Git (and is improving on EGit), so Git will be the VCS target on Eclipse.
I'd recommend pretty much any of the distributed version control systems. I've used git
and hg
in anger, and poked at fossil
(I include it because it offers some features that git
and hg
lack). I'll break down the major pros and cons in my eyes (NOTE: if they all have the same advantage I'm not going to mention it, e.g., they're all fast and lightweight):
git
- Pros
- Very flexible
- GitHub
- Cons
- Steep learning curve
- More flexible
- Eclipse integration was lame the last time I looked
- Pros
hg
- Pros
- (IMO) more consistent commands
- Less flexible
- BitBucket
- Cons
- Less flexible
- Doesn't have quite as much momentum as
git
- Caveats
- I haven't checked on Eclipse support lately; it used to be better than
git
's, but seemed rather stagnant
- I haven't checked on Eclipse support lately; it used to be better than
- Pros
fossil
(disclaimer: I haven't used this one in anger)- Pros
- Written by the man behind SQLite, so you can be fairly sure it's SOLID code
- Provides more than just version control, e.g., a distributed bug tracker
- Easy to set up for others to access
- Cons
- Not nearly as much momentum as
git
orhg
- I'm pretty sure Eclipse integration for
fossil
is non-existent (it was the last time I looked) - No free hosting that I know of to parallel GitHub or BitBucket, so you actually have to host your repo yourself
- Not nearly as much momentum as
- Pros
There are other DVCSs out there, notably including darcs
and bzr
, but I've not used them enough to have a worthwhile opinion on them.
Git, because you can start right away and don't need a central repository server.
Some other advantages (compared to other SCMs):
- Less cluttered filesystem: Git only creates a folder at the root of the repository (unlike e.g. SVN).
- Does not interfere that much with "normal" file handling functions. E.g. in SVN you need to use custom commands to rename or move files. That is not the case with Git.
I have the feeling Git is very lightweight, so there no reason to wait until your project is "big enough" or whatever.
Your comment makes it seem like your real question is whether or not you really need to use version control, given that it's a one-person project.
It takes very little time to set up and use git or mercurial. Just do it. If you don't need it, you've lost a few minutes. If you do need it, it could potentially save you weeks.
As far as I understand, it is just a question of which version control system you prefer most.
But the most performant system is probably git I think. http://www.eclipse.org/egit/ for the eclipse plugin :)
I would recommend to use a version control system anyway. Even in small projects you will come very fast to the point that a previous solution maybe would have been better. Without a version control system you will do hard reverting changes or revert to previous versions (well, that is one of the great advantages of these systems, right? ;) ).
Git and Mercurial (hg) do have a lot of momentum as distributed source code repositories but in my opinion, for a one man band, you will find the most support with Subversion. If you are in Windows there's TortoiseSVN shell integration which is fantastic (it even integrates with Trac) and free Subversion hosting is all over the place and have some personal experience with ProjectLocker.com (they do Git and SVN). Also, Subversion is pretty straightforward to get integrated directly into the Eclipse IDE.
There are many benefits from using a SCM instead of just Eclipse histoiry even for just a single person:
comments on commits: you can say WHY you did something. This will help you when you need to figure out why some code does as it does, based on its history.
backups: Oh, you messed up your Eclipse workspace completely? Just create a new one, and pull in a fresh copy of the code.
continuous integration: check that code builds after every save, runs tests (this is important), and creates the actual binary to send to the customer.
It is your safety net. Take the time to learn it, and use it right. You will end up liking it :)
来源:https://stackoverflow.com/questions/3097598/version-control-for-one-man-project-using-eclipse