This is an old revision of the document!




“Darcs is a revision control system, along the lines of CVS or ARCH. That means that it keeps track of various revisions and branches of your project, allows for changes to propagate from one branch to another. Darcs is intended to be an 'advanced' revision control system. Darcs has two particularly distinctive features which differ from other revision control systems: 1) each copy of the source is a fully functional branch, and 2) underlying darcs is a consistent and powerful theory of patches.”

  • VersionControl
  • Every source tree a branch
  • A simple advanced tool
  • Keeping track of changes rather than versions
  • Record changes locally
  • Interactive records
  • Unrecord local changes
  • Interactive everything else
  • Test suites
  • Any old server
  • You decide write permissions
  • Symmetric repositories
  • CGI script
  • File and directory moves
  • Token replace
  • Configurable defaults

the FoAM repositories can be accessed using the interwiki tag 'FoamDarcs:' for example FoamDarcs:ceed

ie. http://fo.am/cgi-bin/darcsweb.cgi?r=ceed

instructions and tools for converting cvs repositries to darcs are available at http://www.scannedinavian.org/DarcsWiki/ConvertingFromCvs

using darcs and trac together > http://www.darcs.net/DarcsWiki/TracOnDarcs

based on entries in the manual with the caveat that “Because of the different models used by cvs (or arch) and darcs, it is difficult to provide a complete equivalence between cvs (or arch) and darcs. A rough correspondence for the everyday commands follows”

<table cellspacing=“1” cellpadding=“1” border=“0”><tr><th bgcolor=“#dadada” “> font color=”#000000“>darcs</font></a> </th><th bgcolor=”#dadada“><font color=”#000000“>cvs</font></a> </th><th bgcolor=”#dadada“><font color=”#000000“>arch</font></a> </th></tr> <tr><td bgcolor=”#ffffff“ ”> darcs initialize </td><td bgcolor=“#ffffff”> &nbsp; </td><td bgcolor=“#ffffff”> tla init-tree </td></tr> <tr><td bgcolor=“#eaeaea” “> darcs get </td><td bgcolor=”#eaeaea“> cvs checkout </td><td bgcolor=”#eaeaea“> tla get </td></tr> <tr><td bgcolor=”#ffffff“ ”> darcs pull </td><td bgcolor=“#ffffff”> cvs update </td><td bgcolor=“#ffffff”> tla update </td></tr> <tr><td bgcolor=“#eaeaea” “> darcs pull –dry-run </td><td bgcolor=”#eaeaea“> cvs -n update (summarize remote changes) </td><td bgcolor=”#eaeaea“> &nbsp; </td></tr> <tr><td bgcolor=”#ffffff“ ”> darcs revert </td><td bgcolor=“#ffffff”> &nbsp; </td><td bgcolor=“#ffffff”> tla file-diffs f “pipe” patch -R </td></tr> <tr><td bgcolor=“#eaeaea” “> darcs whatsnew </td><td bgcolor=”#eaeaea“> cvs diff (if checking local changes) </td><td bgcolor=”#eaeaea“> tla changes -diffs </td></tr> <tr><td bgcolor=”#ffffff“ ”> darcs whatsnew –summary </td><td bgcolor=“#ffffff”> cvs -n update </td><td bgcolor=“#ffffff”> &nbsp; </td></tr> <tr><td bgcolor=“#eaeaea” “> darcs whatsnew -ls “pipe” grep ^a </td><td bgcolor=”#eaeaea“> cvs -n update “pipe” grep '?' (list potential files to add) </td><td bgcolor=”#eaeaea“> &nbsp; </td></tr> <tr><td bgcolor=”#ffffff“ ”> darcs changes </td><td bgcolor=“#ffffff”> &nbsp; </td><td bgcolor=“#ffffff”> tla logs </td></tr> <tr><td bgcolor=“#eaeaea” “> darcs diff </td><td bgcolor=”#eaeaea“> cvs diff (if checking recorded changes) </td><td bgcolor=”#eaeaea“> &nbsp; </td></tr> <tr><td bgcolor=”#ffffff“ ”> darcs diff -u </td><td bgcolor=“#ffffff”> &nbsp; </td><td bgcolor=“#ffffff”> tla file-diffs </td></tr> <tr><td bgcolor=“#eaeaea” “> darcs add </td><td bgcolor=”#eaeaea“> cvs add </td><td bgcolor=”#eaeaea“> tla add </td></tr> <tr><td bgcolor=”#ffffff“ ”> darcs mv </td><td bgcolor=“#ffffff”> - </td><td bgcolor=“#ffffff”> tla mv (not tla move) </td></tr> <tr><td bgcolor=“#eaeaea” “> darcs record </td><td bgcolor=”#eaeaea“> cvs commit (if committing locally) </td><td bgcolor=”#eaeaea“> tla commit (if committing locally) </td></tr> <tr><td bgcolor=”#ffffff“ ”> darcs tag </td><td bgcolor=“#ffffff”> cvs commit </td><td bgcolor=“#ffffff”> tla commit (if marking a version for later use) </td></tr> <tr><td bgcolor=“#eaeaea” “> darcs push or darcs send </td><td bgcolor=”#eaeaea“> cvs commit (if committing remotely) </td><td bgcolor=”#eaeaea“> tla commit (if committing remotely) </td></tr> <tr><td bgcolor=”#ffffff“ ”> darcs pull or darcs push </td><td bgcolor=“#ffffff”> &nbsp; </td><td bgcolor=“#ffffff”> tla archive-mirror </td></tr> <tr><td bgcolor=“#eaeaea” “> darcs get </td><td bgcolor=”#eaeaea“> cvs tag -b </td><td bgcolor=”#eaeaea“> tla tag (if creating a branch) </td></tr> <tr><td bgcolor=”#ffffff“ ”> darcs tag </td><td bgcolor=“#ffffff”> cvs tag </td><td bgcolor=“#ffffff”> tla tag (if creating a tag). </td></tr> </table>

  • using_darcs.1184175731.txt.gz
  • Last modified: 2007-07-11 17:42
  • by nik