<$BlogRSDURL$> The Change Manager - Version Control Software News and Thoughts

2.05.2004

Version Control and Project Management

Version Control and Project Management

Rarely is software developed solely by one person, sometimes it is developed by two, but most software involves the work of five or more people. Sometimes these people are in the same room, and sometimes they are spread out all over the world. Whenever a project has multiple people working at the same time you will inevitably have situations where their work overlaps. Perhaps two people will have to perform bug fixes on the same file, maybe they will all be adding APIs to a library. In these situations you always run the risk of one person overwriting the work of another. As your group grows in number and in geographic distance these problems become an even bigger problem. A good version control system (like CVS or Perforce) can help to solve these problems.

Scenario A: At 1100 Jose from San Diego begins to fix a bug in the bar method found in foo.py. While he is working on this problem Armen from Yerevan has opened his copy of foo.py and begun to add the baz method to foo.py. At 1115 Armen, being a fast and efficient coder, finishes his addition and saves the file and then copies his changes to the server. Two minutes later (1117) Jose has finished his bug fix and copies his version of the file to the server. Much to Armen's chagrin his baz method has been overwritten and lost forever.

Scenario A (with CVS): At 1100 Jose from San Diego begins to fix a bug in the bar method found in foo.py. While he is working on this problem Armen from Yerevan has opened his copy of foo.py and begun to add the baz method to foo.py. At 1115 Armen, being a fast and efficient coder, finishes his addition and saves the file and then commits his changes to the server. Two minutes later (1117) Jose has finished his bug fix and attempts to commit his change to the server. The server seeing that Jose's file is older then the version currently on the system refuses to commit Jose's file. Jose runs an update from the server merging Armen's changes with his code changes. Jose spends a minute making sure that none of the changes affect the same block of code (if they did he would simply merge both changes together), and commits again. Armen is safe in the knowledge that his changes are not lost forever.

Scenario B: Scott is writing his latest novel. After spending a week agonizing over a passage he saves his novel. A week later he comes back to the novel and decides that he hates that particular passage and in a wave of inspiration rewrites the entire section. After another week he realizes that his "wave of inspiration" was in fact a bucket of stupidity. He wants to go back to his old version but it is sadly lost forever.

Scenario B (with CVS): Scott is writing his latest novel. After spending a week agonizing over a passage he commits the novel to his repository. A week later he comes back to the novel and decides that he hates that particular passage and in a wave of inspiration rewrites the entire section. After another week he realizes that his "wave of inspiration" was in fact a bucket of stupidity. He reviews his cvs commits, finds the commit with which he overwrote his original version and retrieves the old copy. After some cut and paste work he adds the old section back in and commits his copy.

In addition to preventing overwrites and storing a complete history of file changes it also:
  • A complete history of work done, allowing developers to track their time and progress
    Branching which allows you to simultaneously maintain production, testing, stable, and unstable versions of the same code
  • Provides a back-up situation (which can be located on a totally different machine then yours) to protect against hard disk failure, or the infamous "rm -rf /code" mistake
  • Although many solo developers find it a problem to initially adjust to using Version Control Software, once you start to really use it, not only will it become a natural part of your development process, but you may begin to feel nervous when working without it.

    Resources
    CVS: the most commonly used open sourced VC system
    Bitkeeper: proprietary VC system used by Linus Torvalds while developing Linux
    Perforce: popular VC system which has a free basic version for non-commercial projects

     

    Posted by: DTB at 5.2.04    | Permalink


  • PROOF-it-ONLINE unveils new Version Control feature

    PROOF-it-ONLINE has introduced a new Version Control feature in the latest version of ApprovALL, its subscription-based online proofing and creative approval management solution for creative professionals. Version Control provides creative professionals and their clients with a simple, "clear and concise" method of ensuring accuracy throughout the creative review and approval process. Version Control provides access previous versions of a graphic file or proof in order to refer back as needed. Introductory pricing is $30 per month.
    Read Article

     

    Posted by: DTB at 5.2.04    | Permalink


    .::Events

    Feb. 15-18, 2004
    8th Annual International IT Conference and Exhibition
    Las Vegas, NV

    Feb. 22-27, 2004
    SHARE Conference & Exposition
    Long Beach, CA

    March 8-10, 2004
    AIIM 2004
    The Enterprise Content and Document Management Event
    New York, NY


    .::Articles

    InfoWorld - IBM plans industry-focused software reorganization

    CRN - IBM 'Rationalizes' Tool Strategy

    CRN Interview - Mike Devlin, GM of IBM Rational Software

    InfoWorld - IBM makes a Rational choice


    .::CM Blogs

    Enterprise Software Blog

    CM Market Blog


    .::Archives

    02/01/2004 - 03/01/2004

    07/01/2004 - 08/01/2004


    Archives by Title


    .::Marco de Vries

    Marco has spent years tracking and analyzing developments and trends in the change management industry.


    .::rss feeds

    Change Management RSS

    CM RSS Feed

    .::rss feeds

    Supported by

    Merant