Jump to content

History of software configuration management

From Wikipedia, the free encyclopedia
(Redirected from SCM History)

The history of software configuration management (SCM) can be traced back as early as the 1950s, when CM (configuration management), originally for hardware development and production control, was being applied to software development. Early software had a physical footprint, such as cards, tapes, and other media. The first software configuration management was a manual operation. With the advances in language and complexity, software engineering, involving configuration management and other methods, became a major concern due to issues like schedule, budget, and quality. Practical lessons, over the years, had led to the definition, and establishment, of procedures and tools. Eventually, the tools became systems to manage software changes.[1] Industry-wide practices were offered as solutions, either in an open or proprietary manner (such as Revision Control System). With the growing use of computers, systems emerged that handled a broader scope, including requirements management, design alternatives, quality control, and more; later tools followed the guidelines of organizations, such as the Capability Maturity Model of the Software Engineering Institute.

Timeline

[edit]
  • Early 1960s or even late 1950s: CDC UPDATE and IBM IEB_UPDATE.[2]
  • Late 1960s into 1970s: The Librarian is released by Applied Data Research and provides an alternative to keeping programs on punched card decks for the IBM mainframe market.[3]
  • Late 1960s, early 1970s: Professor Leon Pressor at the University of California, Santa Barbara produced a thesis on change and configuration control. This concept was a response to a contract he was working on with a defense contractor who made aircraft engines for the US Navy.
  • Early 1970s: Unix make.
  • By 1970 CDC update was an advanced product.
  • Circa 1972: Bell Labs paper describing the original diff algorithm.
  • 1972, with an IEEE paper in 1975: source code control system, SCCS, Marc Rochkind Bell Labs. Originally programmed in SNOBOL for OS/360; subsequently rewritten in C for Unix (used diff for comparing files).
  • 1970s: Lisle, Illinois-based Pansophic Systems offered PANVALET, which was an early source code control system for the mainframe market.[4]
  • 1975: Professor Pressor's work eventually grew into a commercially available product called Change and Configuration Control (CCC) which was sold by the SoftTool corporation.
  • Revision Control System (RCS, Walter Tichy).
  • Early 1980s: patch (around 1985, Larry Wall).
  • 1984: Aide-de-Camp
  • 1986: Concurrent Version System (CVS).
  • 2000: Subversion initiated by CollabNet.
  • Early 2000s (decade): distributed revision control systems like BitKeeper and GNU arch become viable.

Background

[edit]

Until the 1980s, SCM could only be understood as CM applied to software development.[5] Some basic concepts such as identification and baseline (well-defined point in the evolution of a project) were already clear, but what was at stake was a set of techniques oriented towards the control of the activity, and using formal processes, documents, request forms, control boards etc.

It is only after this date that the use of software tools applying directly to software artefacts representing the actual resources, has allowed SCM to grow as an autonomous entity (from traditional CM).

The use of different tools has actually led to very distinct emphases.

Evolution

[edit]

First generation

[edit]

SCCS (first released in 1973) and DSEE (considered a predecessor of Atria ClearCase), described in 1984,[6] are two other notable VCS software tools. These tools, along with Revision Control System (RCS), are generally considered the first generation of VCS as automated software tools.[7]

Second generation

[edit]

After the first generation VCS, tools such as CVS and Subversion, which feature a locally centralized repository, could be considered as the second generation VCS. Specifically, CVS (Concurrent Versions System) was developed on top of RCS structure, improving scalability of the tool for larger groups, and later PRCS,[8] a simpler CVS-like tool which also uses RCS-like files, but improves upon the delta compression by using Xdelta instead.

By 2006 or so, Subversion was considered to be the most popular and widely in use VCS tool from this generation and filled important weaknesses of CVS.[according to whom?] Later SVK developed with the goal of remote contribution feature, but still the foundation of its design were similar to its predecessors.[7]

Third generation

[edit]

As Internet connectivity improved and geographically distributed software development became more common, tools emerged that did not rely on a shared central project repository. These allow users to maintain independent repositories (or forks) of a project and communicate revisions via changesets. BitKeeper, Git, Monotone, darcs, Mercurial, and bzr are some examples of third generation version control systems.[7]

See also

[edit]
  • Revision control – Activity of managing versions of files

References

[edit]
  1. ^ "1988 "A Guide to Understanding Configuration Management in Trusted Systems" National Computer Security System (via Google)
  2. ^ "Obsolete: Configuration Management Frequently Asked Questions".
  3. ^ Goetz, Martin (3 May 2002). "An Interview with Martin Goetz" (Interview). Interviewed by Jeffrey R. Yost. Washington, D.C.: Charles Babbage Institute, University of Minnesota. pp. 5–7. Retrieved 26 May 2023.
  4. ^ Oral history interview with Joseph Piscopo, Charles Babbage Institute, University of Minnesota. Piscopo founded Pansophic Systems in 1969 and led it until his retirement in 1987. Interview discusses the development of Panvalet and the acquisition of Easytrieve.
  5. ^ J.K. Buckle (1982). Software Configuration Management. ISBN 0-333-30719-4.
  6. ^ Leblang, David B.; Chase, Robert P. (May 1984). "Computer-Aided Software Engineering in a distributed workstation environment". ACM SIGPLAN Notices. 19 (5): 104–112. doi:10.1145/390011.808255.
  7. ^ a b c Raymond, Eric. "Understanding Version-Control Systems (DRAFT)". www.catb.org. Retrieved 13 February 2017.
  8. ^ MacDonald, Joshua P (9 May 2004). "PRCS, the Project Revision Control System". Retrieved 29 October 2021.