Concurrent Versions System

aesthetics  →
being  →
complexity  →
database  →
enterprise  →
ethics  →
fiction  →
history  →
internet  →
knowledge  →
language  →
licensing  →
linux  →
logic  →
method  →
news  →
perception  →
philosophy  →
policy  →
purpose  →
religion  →
science  →
sociology  →
software  →
truth  →
unix  →
wiki  →
essay  →
feed  →
help  →
system  →
wiki  →
critical  →
discussion  →
forked  →
imported  →
original  →
Concurrent Versions System
[ temporary import ]
please note:
- the content below is remote from Wikipedia
- it has been imported raw for GetWiki

}}{{lead rewrite|date=September 2018}}The Concurrent Versions System (CVS), also known as the Concurrent Versioning System, is a free client-server revision control system in the field of software development. A version control system keeps track of all work and all changes in a set of files, and allows several developers (potentially widely separated in space and time) to collaborate. Dick Grune developed CVS as a series of shell scripts in July 1986.WEB,weblink CVS--Concurrent Versions System v1.12.12.1: Overview, - Per Cederqvist, 9 December 2011,weblink" title="">weblink 15 April 2012, yes, dmy-all, In addition to proprietary software developers, CVS became popular with the open-source software world and was released under the GNU General Public License. While there was regular development to add features and fix bugs in the past,WEB,weblink CVS Change Log, February 22, 2011, including regular builds and test results,WEB,weblink CVS Test Results, February 22, 2011, there have been no new releases since 2008.


CVS uses a client–server architecture: a server stores the current version(s) of a project and its history, and clients connect to the server in order to "check out" a complete copy of the project, work on this copy and then later "check in" their changes. Typically, the client and server connect over a LAN or over the Internet, but client and server may both run on the same machine if CVS has the task of keeping track of the version history of a project with only local developers. The server software normally runs on Unix (although at least the CVSNT server also supports various flavours of Microsoft Windows), while CVS clients may run on any major operating-system platform.Several developers may work on the same project concurrently, each one editing files within their own "working copy" of the project, and sending (or checking in) their modifications to the server. To avoid conflicts, the server only accepts changes made to the most recent version of a file. Developers are therefore expected to keep their working copy up-to-date by incorporating other people's changes on a regular basis. This task is mostly handled automatically by the CVS client, requiring manual intervention only when an edit conflict arises between a checked-in modification and the yet-unchecked local version of a file.If the check in operation succeeds, then the version numbers of all files involved automatically increment, and the CVS-server writes a user-supplied description line, the date and the author's name to its log files. CVS can also run external, user-specified log processing scripts following each commit. These scripts are installed by an entry in CVS's loginfo file, which can trigger email notification or convert the log data into a Web-based format.Clients can also compare versions, request a complete history of changes, or check out a historical snapshot of the project as of a given date (but not by revision number as there is no project-wide revision number).CVS servers can allow "anonymous read access",WEB, Charles D. Cranor, Theo de Raadt, Opening The Source Repository With Anonymous CVS, USENIX 1999,weblink 1999, wherein clients may check out and compare versions with either a blank or simple published password (e.g., "anoncvs"); only the check-in of changes requires a personal account and password in these scenarios.Clients can also use the "update" command to bring their local copies up-to-date with the newest version on the server. This eliminates the need for repeated downloading of the whole project.CVS can also maintain different "branches" of a project. For instance, a released version of the software project may form one branch, used for bug fixes, while a version under current development, with major changes and new features, can form a separate branch.CVS uses delta compression for efficient storage of different versions of the same file. This works well with large text files with few changes from one version to the next. This is usually the case for source code files. On the other hand, when CVS is told to store a file as binary, it will keep each individual version on the server. Storing files as binary is important in order to avoid corruption of binary files.{{Quotation|In the world of open source software, the Concurrent Version System (CVS) has long been the tool of choice for version control. And rightly so. CVS itself is free software, and its non-restrictive modus operandi and support for networked operation – which allow dozens of geographically dispersed programmers to share their work – fits the collaborative nature of the open-source world very well. CVS and its semi-chaotic development model have become cornerstones of open-source.|Collins-Sussman|Version Control with Subversion For Subversion 1.1, 2005}}


CVS labels a single project (set of related files) that it manages as a module. A CVS server stores the modules it manages in its repository. Programmers acquire copies of modules by checking out. The checked-out files serve as a working copy, sandbox or workspace. Changes to the working copy are reflected in the repository by committing them. To update is to acquire or merge the changes in the repository with the working copy.


CVS was designed:
  • To exclude symbolic links because when they are stored in a version control system they can pose a security risk. For instance, a symbolic link to a sensitive file can be stored in the repository, making the sensitive file accessible even when it is not checked in. In place of symbolic links, scripts that require certain privileges and conscious intervention to execute may be checked into CVS.{{Citation needed|reason=cleanup of text|date=July 2017}}
  • Use the native ASCII character set in filenames, precluding the use of multi-lingual filenames. Now many Unix systems run in UTF-8,WEB, Kuhn, Markus, UTF-8 and Unicode FAQ, 2010-07-07, 2009-05-11,weblink
, and CVS on such systems handles UTF-8 multi-lingual filenames natively.
  • Create revisions per file, not an identifier for all revisions created during a commit ( this is sometimes referred to as atomic but not in the transactional database sense, where a commit automatically rolls back if it fails for any reason, but in the sense that each commit can be uniquely identified). This design choice was made even when servers could easily have had insufficient resilience to complete a commit without crashing. The lack of atomicity is mitigated by the fact that in many code management processes, development work is performed on branches and then merged into the trunk after code review. That final merge is atomic, and performed in the data center by QA{{Citation needed|reason=cleanup of text|date=July 2017}}. Tracking each commit can be accomplished by modifying the correct trigger.
  • To assume that the majority of work takes place on the trunk, and that branches should generally be short-lived or historical. When used as designed, branches are easily managed and branch operations are efficient and fast.WEB, Collins-Sussman, Ben, Greg Ward, Subversion Users: Re: Performance (Subversion vs. CVS), subversion-users, 2010-07-07, September 2004,weblink
, West
, Adrian
, cvs branchtag performance fix
, 2010-07-07
, July 2004
,weblink" title="">weblink
, 2009-08-03
, yes
  • That text files are expected to be the primary file type stored in the CVS repository{{Citation needed|reason=cleanup of text|date=July 2017}}. However, binary files are also supported, and files with a particular file extension can automatically be recognized as being binary.
  • That changes would be frequently committed to the centrally checked-in copies of files in order to aid merging and foster rapid distribution of changes to all users{{Citation needed|reason=cleanup of text|date=July 2017}}, so there is no support for distributed revision control or unpublished changes.

History and status

Dick Grune developed CVS as a front end for the Revision Control System (RCS), an older version control system that manages individual files but not whole projects.{{Quotation|I created CVS to be able to cooperate with my students, Erik Baalbergen and Maarten Waage, on the ACK (Amsterdam Compiler Kit) C compiler. The three of us had vastly different schedules (one student was a steady 9-5 worker, the other was irregular, and I could work on the project only in the evenings). Their project ran from July 1984 to August 1985. CVS was initially called cmt, for the obvious reason that it allowed us to commit versions independently.|source=}}Grune publicly released the code on June 23, 1986.NEWSGROUP, CVS, an RCS front-end (cvs), Dick Grune, July 3, 1986, mod.sources, 122@mirror.UUCP,weblink September 14, 2016, The code that eventually evolved into the current version of CVS started with Brian Berliner in April 1989, with later input from Jeff Polk and many other contributors. Brian Berliner wrote a paper introducing his improvements to the CVS program—which describes how the tool was extended and used internally by Prisma, a third-party developer working on the SunOS kernel, and was released for the benefit of the community under the GPL. On November 19, 1990, CVS version 1.0 was submitted to the Free Software Foundation for development and distribution.initial release of version 1.0; CVS NEWS fileCVS supports distributed, multi-site and offline operations due to the unreliability of the few computer networks that existed at the time CVS evolved.

Development status

{{original research|section|date=April 2016}}There have been no official recent announcements indicating the project status.
  • The latest version was released {{date|2008-05-08}} ({{Age in years, months and days|2008|05|08}} ago).WEB,weblink Concurrent Versions System - News

, April 19, 2016, {{date, 2008-05-08, mdy, |publisher=Free Software Foundation, Inc.}}
  • Since 2008 there have been some maintenance bugfixes in the CVS project's own CVS repository.WEB,weblink CVS ChangeLog, May 25, 2009,
  • There are no bugs or enhancements reportedWEB,weblink Open requests for fixes/features, January 17, 2013, since the last code change that are complete (fulfill the requirement for a fix). There are a total of 9 reports, most of which are questions. Questions are typically answered quickly if asked on the mailing list.
  • The info-cvs mailing list actively answer questions.WEB,weblink CVS Mailing List, January 17, 2013,
  • Links on the official CVS page that point to the external web site, such as 'Current Events,' are dead,WEB,weblink Current Events, January 15, 2013, as is the CVS wiki.WEB,weblink CVS Wiki, January 15, 2013, Companies offering commercial support for CVS are listed in the CVS Wiki.,weblink" title="">weblink November 30, 2010, yes, mdy-all, Archived information is available using weblink" title="">new links
  • The last message in the Cvs-Announce mailing list was posted on {{date|2008-05-08}} ({{Age in years, months and days|2008|05|08}} ago).WEB,weblink Stable CVS Version 1.11.23 Released!, GNU, Cvs-Announce mailing list, January 15, 2013, Stable CVS 1.11.23 has been released. Stable releases contain only bug fixes from previous versions of CVS.,
  • The last code checkin to the CVS code repository occurred on {{date|2011-03-30}} ({{Age in years, months and days|2011|03|30}} ago).WEB,weblink Savannah CVS Surfing - Index of /cvs/ccvs/src, January 15, 2013, gpg.c (parse_signature_subpacket): Correct spout->raw memory allocation. (Reported by David Taylor .),
Development of the Microsoft Windows, Linux, Solaris, HPUX, I5os and Mac OS X port of CVS has split off into a separate project named CVSNT, which is under current, active development.WEB,weblink About the CVSNT Project, March Hare Software, History, January 15, 2013, CVS Suite 2009R2 was released in July 2011 with improved support for versioning PL/SQL triggers/procedures etc, and CVS Suite 2010 is currently being prepared for release. A major upgrade: CVS Suite 2012 is in final planning stages and is expected to be released in early 2012.,

Relationship with GNU

The relationship between CVS and the GNU project has long been somewhat ambiguous: the GNU web site distributed the program, labelling it "GNU package" on one page and "other GPL-licensed project" on another. In 2008, when development of CVS was transferred from the old website ( to the GNU Savannah hosting platform, it was placed in the "non-GNU" section.Note: all pages in the non-gnu section automatically contain the notice "This project is not part of the GNU Project", so this is just an automatic consequence of being in the non-gnu section, not a comment specifically made by GNU about CVS. WEB,weblink Concurrent Versions System - Summary, January 15, 2013, This project is not part of the GNU Project., Further, on GNU's FTP download server, CVS is distributed in the "non-gnu" directory.


Over time, developers have created new version control systems based on CVS in order to add features, alter the operational model, and improve developers' productivity. CVS replacement projects include CVSNT (first released 1998), SubversionWEB,weblink Subversion FAQ: Why does this project exist?, Subversion (software), Subversion, September 21, 2009, WEB,weblink Dispelling Subversion FUD, Ben Collins-Sussman, June 30, 2010, yes,weblink" title="">weblink July 18, 2011, (initially released in 2004Subversion released 26th February 2004: and the CHANGELOG proof can be found here) and EVS (first released 2008).

See also

  • StatCVS, a program that generates graphical reports about CVS repositories.
  • TortoiseCVS, a shell-integrated CVSNT client for Microsoft Windows (commonly used with CVS servers)WEB, Barrett, Arthur, Anonymous or Developer checkout with TortoiseCVS, 2010-07-10, 2010-06-25,weblink
, WEB, Barrett, Arthur, TortoiseCVS instructions – sourceforge, 2010-07-10,weblink
  • Bonsai CVS code management system, a tool to report on files, directories, and branches under CVS management.
  • Cervisia, a KDE GUI frontend for CVS
  • ViewVC, a browser interface for CVS repositories
  • OpenGrok, a browser interface for CVS repositories
  • CVSup, a utility and protocol to check out and mirror CVS repositories efficiently

IDEs with support for CVS

{{col-begin}}{{col-3}} {{col-3}} {{col-3}} {{col-end}}




  • BOOK

, David Thomas
, Andrew Hunt, Andy Hunt (author)
, Pragmatic Version Control Using CVS
, The Pragmatic Programmers
, 2003
, 0-9745140-0-4
, Dave Thomas (programmer)
  • BOOK

, Jennifer Vesperman
, Essential CVS
, 2e
, O'Reilly
, 2006
, 0-596-52703-9
  • BOOK

, Per Cederqvist
, Version Management with CVS
, 0-9541617-1-8
,weblink etal,
  • BOOK

, Karl Franz Fogel
, Moshe Bar, Moshe Bar (investor)
, Open Source Development with CVS
, 1-932111-81-6

External links

{{Version control software}}

- content above as imported from Wikipedia
- "Concurrent Versions System" does not exist on GetWiki (yet)
- time: 8:20pm EST - Sat, Feb 23 2019
[ this remote article is provided by Wikipedia ]
LATEST EDITS [ see all ]
M.R.M. Parrott