using source code control effectively

Post on 23-Feb-2016

87 Views

Category:

Documents

0 Downloads

Preview:

Click to see full reader

DESCRIPTION

Using Source Code Control Effectively. Gang Cheng gacheng@syr.edu. Why?. Why we need source code control? Keep track of code changes Prevent code loss Retrieve older versions of software that customers are currently using to examine problems they are having. Three Levels. - PowerPoint PPT Presentation

TRANSCRIPT

Using Source Code Control Effectively

Gang Chenggacheng@syr.edu

Why?

Why we need source code control?– Keep track of code changes– Prevent code loss– Retrieve older versions of software

that customers are currently using to examine problems they are having

Three Levels

Level 1: Opening Your Eyes Level 2: The SCC Journeyman Level 3: Experts Only

Level 1

Opening Your Eyes– Create: creates a new area in the repository– Add: adds a file to the repository– Get: gets the current version of a file from

the repository– Checkout: works on a particular file actively– Undo Checkout: throws away any changes

and unlocks the file– Checkin: puts the current version of the file

back to the repository

Level 2

The SCC Journeyman– Label: assigns a name to a specific version

of a file– Share: allows a file to appear in more than

one project– Branch: lets development diverge– Merge: takes changes from one branch and

applies them to another branch

Level 3

Experts Only– Cloak: hides a project in the repository– Delete: removes a file from the repository– Move: relocates a file or subproject to a new

parent project– Pin: freezes a shared file at a particular

version– Rename: rename a file or project– Rollback: reverts a file to an earlier version

SCC Alternatives

Some Representative SCC– AccuRev www.accurev.com– BitKeeper www.bitkeeper.com– ClearCase www.rational.com/products/clearcase– CVS www.cvshome.org– Perforce www.perforce.com– StarTeam www.borland.com/starteam/– Subversion http://subversion.tigris.org/– Vault www.sourcegear.com/vault/index.asp– Visual Source Safe http://msdn.microsoft.com/ssafe

Choose?

Price Concurrent Development Style

– Checkout/edit/checkin (VSS)– Edit/merge/commit (CVS)

The repository Internet Friendliness IDE Integration Advanced Commands Cross-Platform Support

Discussion

SCC Etiquette– Work with as few files as possible at one time– Two styles compare

Proper use of Label (Tags)– Easy to remember and find– At significant points

Branching Discipline– When different developers in the same project

follows different rules– Create only when needed– Handles branching by actually creating branches

Miscellaneous Rules– Use the integration– Chapter 9 “Tracking and Squashing Bugs”

SCC Checklist

Use it Use command efficiently Choose your SCC Place all dev. Artifacts to SCC Checkout only when you need it Comment changes when checkin Label at significant points Create a branch whenever the rules

change Use SCC with bug tracking

CVS

General– CVS Homepage https://www.cvshome.org/– Introducton ppt

http://www.geocities.com/durairaj_77/wincvs.ppt– CVS Book http://cvsbook.red-bean.com/cvsbook.html– CVS Commmand http://www.cvsnt.org/wiki/CvsCommand

CVSNT (CVS Window Server)– CVSNT Homepage http://www.cvsnt.org– Installation Guide

http://w1.862.telia.com/~u86216121/InstallCVSNT.html WinCVS (CVS Window Client)

– WinCVS Homepage http://www.wincvs.org/index.html– Installation & Config Guide

http://www.cmcrossroads.com/ubbthreads/showflat.php?Cat=0&Number=31083&page=0&view=collapsed&sb=2&o=&fpart=1

CVS

RCS (Revision Control System)– By Walter Tichy, Purdue University– software tool for UNIX systems which lets people

work on system control– Reference

http://www.csc.calpoly.edu/~dbutler/tutorials/winter96/rcs/

SharpCVSLib (CVS Client Library)– A Client API for the CVS protocol, written in C#– SCVSLib Homepage

http://sharpcvslib.sourceforge.net/

CVS

CVSNT Running

CVS WinCVS Login

CVS WinCVS: User Gang Import module

CVS WinCVS: User Charlie checkout module

CVS WinCVS: User Charlie Edit a file

CVS WinCVS: User Charlie commits the file

CVS WinCVS: User Gang edits the same file,

commits his version and causes a conflict

CVS WinCVS: User Gang checks version tree

CVS WinCVS: User Gang retrieves the old version

RCS File head 1.3; access; symbols arelease:1.1.1.1 avendor:1.1.1; locks; strict; comment @# @;

1.3 date 2004.10.07.19.40.04;

author Gang; state Exp;

branches; next 1.2; deltatype text; permissions 644; commitid af041659b940c05; kopt kv; filename @Please read me.txt@;

1.2 date 2004.10.07.19.14.13;

author Charlie; state Exp;

branches; next 1.1; deltatype text; permissions 644; commitid d0416595847838; kopt kv; filename @Please read me.txt@;

……

End of Presentation

top related