Knowledge (XXG)

Concurrent Versions System

Source đź“ť

1150: 499: 188: 388:) 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 36: 445:) 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. 311:
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
404:
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 assumes that the majority of work
452:
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
392:
arises between a checked-in modification and the yet-unchecked local version of a file. Clients can also use the "update" command to bring their local copies up-to-date with the newest version on the server. Clients can also compare versions, request a complete history of changes, or check out a
319:
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
383:
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. CVS servers can allow "anonymous read access", wherein clients may check out and compare versions with either a blank or simple
384:
published password (e.g., "anoncvs"); only the check-in of changes requires a personal account and password in these scenarios. Several developers may work on the same project concurrently, each one editing files within their own "working copy" of the project, and sending (or
393:
historical snapshot of the project (e.g.: based on a given date). If the check-in operation succeeds, then the version numbers of all files involved automatically increment, and the server writes a user-supplied description line, the date and the author's name to its
473:
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.
300:(RCS), an older version control system that manages individual files but not whole projects. It expands upon RCS by adding support for repository-level change tracking, and a client-server model. Files are tracked using the same history format as in RCS, with a 478:
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
453:
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
469:
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
1628: 405:
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.
1244: 1046: 1277: 57: 44: 1623: 397:
files. CVS can also run external, user-specified log processing scripts following each commit. These scripts are installed by an entry in CVS's
1618: 1613: 1574: 1380: 1114: 1039: 512: 312:
server. This is typically used for non-text files such as executable images where it is difficult to create compact deltas between versions.
504: 1603: 1482: 1283: 692: 1032: 987: 951: 930: 911: 593: 1581: 1567: 1149: 860: 1313: 941: 772: 649: 1081: 1548: 165: 1533: 1492: 1487: 1336: 1320: 139: 117: 1095: 241: 49: 790: 736: 1504: 891: 454: 368: 358: 201: 88: 1538: 1445: 1225: 1089: 297: 1608: 977: 442: 336: 293: 277: 1454: 1307: 839: 484: 441:
I created CVS to be able to cooperate with my students, Erik Baalbergen and Maarten Waage, on the ACK (
1106: 973: 579: 330: 1439: 1419: 1229: 1219: 1215: 748: 224: 1521: 1237: 895: 376: 620: 1387: 1359: 1189: 983: 947: 926: 907: 422: 308: 217: 1301: 809:"Concurrent Versions System - News: Stable CVS Version 1.11.23 Released! [Savannah]" 740: 426: 401:
file, which can trigger email notification or convert the log data into a Web-based format.
301: 236: 229: 208: 808: 1528: 1258: 1055: 696: 17: 187: 1516: 1271: 752: 597: 1064:
Years, where available, indicate the date of first stable release. Systems with names
667: 1597: 1265: 1251: 900: 389: 316: 864: 1553: 1509: 1295: 394: 957: 744: 642: 776: 1461: 1206: 532: 1407: 1366: 494: 281: 83: 835: 825:
Ben Collins-Sussman, Version Control with Subversion For Subversion 1.1, 2005
1499: 1413: 1352: 567: 556: 213: 1024: 717: 174: 35: 1017: 320:
privileges and conscious intervention to execute may be checked into CVS.
1543: 1400: 1289: 1120: 522: 517: 304:
containing a corresponding history file for each file in the repository.
328:
CVS labels a single project (set of related files) that it manages as a
773:"CVS II: Parallelizing Software Development - Berliner (ResearchIndex)" 527: 380: 537: 1373: 1177: 480: 418: 356:. Changes to the working copy are reflected in the repository by 1183: 1133: 1126: 414: 1028: 993: 643:"Opening The Source Repository With Anonymous CVS, USENIX 1999" 1393: 29: 1068:
are no longer maintained or have planned end-of-life dates.
379:
architecture: a server stores the current version(s) of a
621:"The Evolution of Version Control System (VCS) Internals" 568:
CVS Feature Version 1.12.13 Released! * Security Update *
668:"Subversion Users: Re: Performance (Subversion vs. CVS)" 252: 594:"CVS--Concurrent Versions System v1.12.12.1: Overview" 372:
the changes in the repository with the working copy.
334:. A CVS server stores the modules it manages in its 1475: 1429: 1344: 1335: 1199: 1164: 1157: 1105: 1080: 1073: 449:Grune publicly released the code on June 23, 1986. 247: 235: 223: 207: 197: 164: 138: 116: 94: 82: 899: 666:Collins-Sussman, Ben; Greg Ward (September 2004). 1629:Unix archivers and compression-related utilities 467: 460:The latest version was released on 8 May 2008. 439: 836:"Subversion FAQ: Why does this project exist?" 1040: 27:Historical centralized version control system 8: 77: 340:. Programmers acquire copies of modules by 1341: 1161: 1077: 1047: 1033: 1025: 425:), while CVS clients may run on any major 186: 76: 641:Charles D. Cranor; Theo de Raadt (1999). 421:server also supports various flavors of 60:of all important aspects of the article. 549: 791:"[cvs] Contents of /ccvs/NEWS" 513:Comparison of version-control software 56:Please consider expanding the lead to 863:. Ben Collins-Sussman. Archived from 413:The server software normally runs on 7: 940:Per Cederqvist; et al. (2002). 557:Stable CVS Version 1.11.23 Released! 505:Free and open-source software portal 145:1.12.13 / September 28, 2005 902:Pragmatic Version Control Using CVS 619:Stopak, Jacob (November 30, 2019). 344:. The checked-out files serve as a 457:for development and distribution. 25: 1148: 979:Open Source Development with CVS 718:"Concurrent Versions System CVS" 655:from the original on 2022-10-09. 497: 34: 693:"cvs branchtag performance fix" 48:may be too short to adequately 1624:Software using the GPL license 58:provide an accessible overview 1: 1619:Free version control software 1614:Free software programmed in C 906:. The Pragmatic Programmers. 737:"CVS, an RCS front-end (cvs)" 123:1.11.23 / May 8, 2008 274:Concurrent Versioning System 943:Version Management with CVS 921:Jennifer Vesperman (2006). 861:"Dispelling Subversion FUD" 735:Dick Grune (July 3, 1986). 1645: 1604:Concurrent Versions System 691:West, Adrian (July 2004). 580:"Contents of /ccvs/README" 266:Concurrent Versions System 78:Concurrent Versions System 1562: 1146: 1062: 925:(2e ed.). O'Reilly. 160: 112: 18:Concurrent Version System 1056:Version control software 455:Free Software Foundation 280:originally developed by 1284:Software Change Manager 464:Adoption and successors 417:(although at least the 298:Revision Control System 476: 447: 443:Amsterdam Compiler Kit 278:version control system 147:; 18 years ago 125:; 16 years ago 100:; 33 years ago 98:November 19, 1990 779:on September 9, 2004. 795:cvs.savannah.gnu.org 982:. Paraglyph Press. 813:savannah.nongnu.org 79: 972:Karl Franz Fogel; 946:. Network Theory. 292:CVS operates as a 1591: 1590: 1517:Delta compression 1471: 1470: 1331: 1330: 1321:Visual SourceSafe 1174:(1986, 1990 in C) 1144: 1143: 423:Microsoft Windows 366:is to acquire or 309:delta compression 263: 262: 75: 74: 16:(Redirected from 1636: 1448:(via Git) (2014) 1442:(via Git) (2013) 1345:Free/open-source 1342: 1165:Free/open-source 1162: 1152: 1082:Free/open-source 1078: 1049: 1042: 1035: 1026: 1021: 1020: 1018:Official website 1004: 1002: 1001: 992:. Archived from 968: 966: 965: 956:. Archived from 936: 917: 905: 877: 876: 874: 872: 867:on July 18, 2011 857: 851: 850: 848: 846: 832: 826: 823: 817: 816: 805: 799: 798: 787: 781: 780: 775:. Archived from 769: 763: 762: 760: 758: 732: 726: 725: 714: 708: 707: 705: 704: 695:. Archived from 688: 682: 681: 679: 678: 672:subversion-users 663: 657: 656: 654: 647: 638: 632: 631: 629: 627: 616: 610: 609: 607: 605: 600:on 15 April 2012 596:. Archived from 590: 584: 583: 576: 570: 565: 559: 554: 507: 502: 501: 500: 437:Grune recalled: 427:operating system 400: 302:hidden directory 259: 256: 254: 242:GPL-1.0-or-later 230:Revision control 209:Operating system 190: 185: 182: 180: 178: 176: 155: 153: 148: 133: 131: 126: 108: 106: 101: 80: 70: 67: 61: 38: 30: 21: 1644: 1643: 1639: 1638: 1637: 1635: 1634: 1633: 1594: 1593: 1592: 1587: 1558: 1529:File comparison 1467: 1425: 1327: 1195: 1184:QVCS Enterprise 1153: 1140: 1101: 1069: 1058: 1053: 1016: 1015: 1012: 1007: 999: 997: 990: 971: 963: 961: 954: 939: 933: 920: 914: 890: 886: 881: 880: 870: 868: 859: 858: 854: 844: 842: 834: 833: 829: 824: 820: 807: 806: 802: 789: 788: 784: 771: 770: 766: 756: 754: 734: 733: 729: 716: 715: 711: 702: 700: 690: 689: 685: 676: 674: 665: 664: 660: 652: 645: 640: 639: 635: 625: 623: 618: 617: 613: 603: 601: 592: 591: 587: 578: 577: 573: 566: 562: 555: 551: 546: 503: 498: 496: 493: 466: 435: 411: 398: 326: 290: 251: 193: 173: 156: 151: 149: 146: 140:Preview release 134: 129: 127: 124: 104: 102: 99: 95:Initial release 71: 65: 62: 55: 43:This article's 39: 28: 23: 22: 15: 12: 11: 5: 1642: 1640: 1632: 1631: 1626: 1621: 1616: 1611: 1606: 1596: 1595: 1589: 1588: 1586: 1585: 1578: 1571: 1563: 1560: 1559: 1557: 1556: 1551: 1546: 1541: 1536: 1531: 1526: 1525: 1524: 1514: 1513: 1512: 1502: 1497: 1496: 1495: 1485: 1479: 1477: 1473: 1472: 1469: 1468: 1466: 1465: 1459: 1451: 1450: 1449: 1443: 1433: 1431: 1427: 1426: 1424: 1423: 1417: 1411: 1405: 1397: 1391: 1385: 1377: 1371: 1363: 1357: 1348: 1346: 1339: 1333: 1332: 1329: 1328: 1326: 1325: 1317: 1311: 1305: 1299: 1293: 1287: 1281: 1275: 1272:Perforce Helix 1269: 1263: 1255: 1249: 1241: 1235: 1234: 1233: 1223: 1210: 1203: 1201: 1197: 1196: 1194: 1193: 1187: 1181: 1175: 1168: 1166: 1159: 1155: 1154: 1147: 1145: 1142: 1141: 1139: 1138: 1130: 1124: 1118: 1111: 1109: 1103: 1102: 1100: 1099: 1093: 1086: 1084: 1075: 1071: 1070: 1063: 1060: 1059: 1054: 1052: 1051: 1044: 1037: 1029: 1023: 1022: 1011: 1010:External links 1008: 1006: 1005: 988: 969: 952: 937: 931: 918: 912: 887: 885: 882: 879: 878: 852: 827: 818: 800: 782: 764: 727: 709: 683: 658: 633: 611: 585: 571: 560: 548: 547: 545: 542: 541: 540: 535: 530: 525: 520: 515: 509: 508: 492: 489: 471:modus operandi 465: 462: 434: 431: 410: 407: 325: 322: 317:symbolic links 289: 286: 284:in July 1986. 261: 260: 249: 245: 244: 239: 233: 232: 227: 221: 220: 211: 205: 204: 199: 195: 194: 192: 191: 170: 168: 162: 161: 158: 157: 144: 142: 136: 135: 122: 120: 118:Stable release 114: 113: 110: 109: 96: 92: 91: 86: 73: 72: 66:September 2018 52:the key points 42: 40: 33: 26: 24: 14: 13: 10: 9: 6: 4: 3: 2: 1641: 1630: 1627: 1625: 1622: 1620: 1617: 1615: 1612: 1610: 1609:1990 software 1607: 1605: 1602: 1601: 1599: 1584: 1583: 1579: 1577: 1576: 1572: 1570: 1569: 1565: 1564: 1561: 1555: 1552: 1550: 1547: 1545: 1542: 1540: 1537: 1535: 1532: 1530: 1527: 1523: 1520: 1519: 1518: 1515: 1511: 1508: 1507: 1506: 1503: 1501: 1498: 1494: 1491: 1490: 1489: 1486: 1484: 1481: 1480: 1478: 1474: 1463: 1460: 1457: 1456: 1452: 1447: 1444: 1441: 1438: 1437: 1436:Azure DevOps 1435: 1434: 1432: 1428: 1421: 1418: 1415: 1412: 1409: 1406: 1403: 1402: 1398: 1395: 1392: 1389: 1386: 1383: 1382: 1378: 1375: 1372: 1369: 1368: 1364: 1361: 1358: 1355: 1354: 1350: 1349: 1347: 1343: 1340: 1338: 1334: 1323: 1322: 1318: 1315: 1312: 1309: 1306: 1303: 1300: 1297: 1294: 1291: 1288: 1285: 1282: 1279: 1276: 1273: 1270: 1267: 1264: 1261: 1260: 1256: 1253: 1252:Dimensions CM 1250: 1247: 1246: 1242: 1239: 1236: 1231: 1227: 1224: 1221: 1217: 1214: 1213: 1212:Azure DevOps 1211: 1208: 1205: 1204: 1202: 1198: 1191: 1188: 1185: 1182: 1179: 1176: 1173: 1170: 1169: 1167: 1163: 1160: 1158:Client–server 1156: 1151: 1136: 1135: 1131: 1128: 1125: 1122: 1119: 1116: 1115:The Librarian 1113: 1112: 1110: 1108: 1104: 1097: 1094: 1091: 1088: 1087: 1085: 1083: 1079: 1076: 1072: 1067: 1061: 1057: 1050: 1045: 1043: 1038: 1036: 1031: 1030: 1027: 1019: 1014: 1013: 1009: 996:on 2014-07-16 995: 991: 989:1-932111-81-6 985: 981: 980: 975: 970: 960:on 2014-08-05 959: 955: 953:0-9541617-1-8 949: 945: 944: 938: 934: 932:0-596-52703-9 928: 924: 923:Essential CVS 919: 915: 913:0-9745140-0-4 909: 904: 903: 897: 893: 889: 888: 883: 866: 862: 856: 853: 845:September 21, 841: 837: 831: 828: 822: 819: 814: 810: 804: 801: 796: 792: 786: 783: 778: 774: 768: 765: 757:September 14, 753: 750: 746: 742: 738: 731: 728: 723: 722:dickgrune.com 719: 713: 710: 699:on 2009-08-03 698: 694: 687: 684: 673: 669: 662: 659: 651: 644: 637: 634: 622: 615: 612: 599: 595: 589: 586: 581: 575: 572: 569: 564: 561: 558: 553: 550: 543: 539: 536: 534: 531: 529: 526: 524: 521: 519: 516: 514: 511: 510: 506: 495: 490: 488: 486: 482: 475: 472: 463: 461: 458: 456: 450: 446: 444: 438: 432: 430: 428: 424: 420: 416: 408: 406: 402: 396: 391: 390:edit conflict 387: 382: 378: 377:client–server 373: 371: 370: 365: 361: 360: 355: 351: 347: 343: 339: 338: 333: 332: 323: 321: 318: 315:CVS excludes 313: 310: 305: 303: 299: 295: 287: 285: 283: 279: 275: 271: 267: 258: 250: 246: 243: 240: 238: 234: 231: 228: 226: 222: 219: 215: 212: 210: 206: 203: 200: 196: 189: 184: 172: 171: 169: 167: 163: 159: 143: 141: 137: 121: 119: 115: 111: 97: 93: 90: 87: 85: 81: 69: 59: 53: 51: 46: 41: 37: 32: 31: 19: 1580: 1573: 1566: 1453: 1399: 1379: 1365: 1351: 1319: 1308:Team Concert 1296:Surround SCM 1257: 1243: 1171: 1132: 1065: 998:. Retrieved 994:the original 978: 962:. Retrieved 958:the original 942: 922: 901: 892:David Thomas 869:. Retrieved 865:the original 855: 843:. Retrieved 830: 821: 812: 803: 794: 785: 777:the original 767: 755:. Retrieved 730: 721: 712: 701:. Retrieved 697:the original 686: 675:. Retrieved 671: 661: 636: 626:22 September 624:. Retrieved 614: 602:. Retrieved 598:the original 588: 574: 563: 552: 477: 470: 468: 459: 451: 448: 440: 436: 412: 403: 385: 374: 367: 363: 357: 353: 349: 346:working copy 345: 342:checking out 341: 335: 329: 327: 314: 306: 291: 273: 269: 265: 264: 89:The CVS Team 84:Developer(s) 63: 47: 45:lead section 1522:Interleaved 1462:Plastic SCM 1430:Proprietary 1337:Distributed 1207:AccuRev SCM 1200:Proprietary 1107:Proprietary 896:Andrew Hunt 745:mod.sources 533:TortoiseCVS 409:Portability 386:checking in 375:CVS uses a 1598:Categories 1575:Comparison 1549:Repository 1408:GNU Bazaar 1367:Code Co-op 1190:Subversion 1074:Local only 1066:in italics 1000:2002-02-05 964:2009-11-25 884:References 840:Subversion 703:2010-07-07 677:2010-07-07 604:9 December 485:Subversion 429:platform. 359:committing 337:repository 282:Dick Grune 198:Written in 166:Repository 152:2005-09-28 130:2008-05-08 105:1990-11-19 1500:Changeset 1414:Mercurial 1353:BitKeeper 1266:Integrity 1238:ClearCase 974:Moshe Bar 741:Newsgroup 362:them. To 354:workspace 324:Operation 307:CVS uses 294:front end 214:Unix-like 181:/projects 50:summarize 1568:Category 1544:Monorepo 1483:Baseline 1476:Concepts 1455:TeamWare 1446:Services 1420:Monotone 1401:GNU arch 1290:StarTeam 1280:(1980s?) 1232:) (2014) 1226:Services 1222:) (2005) 1121:Panvalet 976:(2003). 898:(2003). 871:June 30, 650:Archived 523:OpenGrok 518:Cervisia 491:See also 175:savannah 1302:Synergy 1286:(1970s) 1254:(1980s) 1123:(1970s) 749:Usenet: 743::  528:StatCVS 433:History 399:loginfo 381:project 350:sandbox 276:) is a 255:.nongnu 248:Website 237:License 218:Windows 177:.nongnu 150: ( 128: ( 103: ( 1505:Commit 1488:Branch 1464:(2006) 1458:(1992) 1440:Server 1422:(2003) 1416:(2005) 1410:(2005) 1404:(2001) 1396:(2005) 1390:(2007) 1388:Fossil 1384:(2002) 1376:(2002) 1370:(1997) 1362:(2017) 1360:Breezy 1356:(2000) 1324:(1994) 1316:(2003) 1310:(2008) 1304:(1990) 1298:(2002) 1292:(1995) 1274:(1995) 1268:(2001) 1262:(1984) 1248:(1994) 1240:(1992) 1216:Server 1209:(2002) 1192:(2000) 1186:(1998) 1180:(1998) 1137:(1991) 1129:(1985) 1117:(1969) 1098:(1973) 1092:(1982) 986:  950:  929:  910:  751:  538:ViewVC 364:update 331:module 288:Design 1539:Merge 1510:Gated 1493:Trunk 1374:Darcs 1314:Vault 1228:(via 1218:(via 1178:CVSNT 653:(PDF) 646:(PDF) 544:Notes 481:CVSNT 419:CVSNT 369:merge 272:, or 1582:List 1534:Fork 1381:DCVS 1278:SCLM 1259:DSEE 1245:CMVC 1230:TFVC 1220:TFVC 1134:QVCS 1127:PVCS 1096:SCCS 984:ISBN 948:ISBN 927:ISBN 908:ISBN 873:2010 847:2009 759:2016 628:2020 606:2011 483:and 415:Unix 257:.org 225:Type 183:/cvs 179:.org 1554:Tag 1394:Git 1172:CVS 1090:RCS 395:log 352:or 296:to 270:CVS 253:cvs 1600:: 894:; 838:. 811:. 793:. 747:. 739:. 720:. 670:. 648:. 487:. 348:, 216:, 1048:e 1041:t 1034:v 1003:. 967:. 935:. 916:. 875:. 849:. 815:. 797:. 761:. 724:. 706:. 680:. 630:. 608:. 582:. 268:( 202:C 154:) 132:) 107:) 68:) 64:( 54:. 20:)

Index

Concurrent Version System

lead section
summarize
provide an accessible overview
Developer(s)
The CVS Team
Stable release
Preview release
Repository
savannah.nongnu.org/projects/cvs
Edit this at Wikidata
C
Operating system
Unix-like
Windows
Type
Revision control
License
GPL-1.0-or-later
cvs.nongnu.org
version control system
Dick Grune
front end
Revision Control System
hidden directory
delta compression
symbolic links
module
repository

Text is available under the Creative Commons Attribution-ShareAlike License. Additional terms may apply.

↑