VersionControlProblems » History » Version 3
« Previous -
Version 3/12
(diff) -
Next » -
Current version
Chris Cannam, 2010-11-07 10:06 AM
Version Control Problems¶
Some problems that complete beginners face when trying to create and work with repositories using current version control systems.
Subversion¶
- Puzzlement over "recommended" trunk/branches/tags structure
When instructing people how to create new projects, it's arguably simplest to ignore this and go for a structure that places them directly in the project directory. But that still results in confusion when checking out other people's projects that do have a difference between root URL and trunk URL.
Note, I'm not counting "difficulty in doing branch merges" etc as a problem for new users of Subversion -- most people will simply never use branches so it's not an issue.
- Difference between repository and working copy
Not a problem for many people, but some seem to find the terminology confusing
- Requirement to update/merge/resolve before commit if someone else has modified the repository
A good user interface can make this workflow clearer
- Forgetting to "svn add" new files
User interface should make a prominent note of files that have been created since the last commit
- Forgetting to use svn when renaming or removing files
- Admin help required for corrupted working copy because of sensitivity to changes in .svn directories (reported)
Mercurial¶
- Requirement to pull/update/merge/resolve/commit before pushing if someone else has modified the repository
A good user interface can make this workflow clearer (a bad one can make it almost impossible), but it is generally more complex than SVN because of:
- Mystification over branches, particularly anonymous branch created when you pull before a merge
A good user interface can still help here by making the branch structure explicit -- many just pile up the change log in a single list