Version Control with Subversion

Total Page:16

File Type:pdf, Size:1020Kb

Version Control with Subversion Source Code Version Management with SVN Carla Guillen Georg Hager Code Version Management We usually have a team of developers working on a code. Problems: • Central repository is single point of failure. • Working on the repository requires a connection to the server. • All project participants need full read/write access to the server. • All commits affect the complete repository. Famous tools which helps us deal with these problems: • CVS - Very old and deficient. Not so reliable. • Subversion - CVS replacement. • Git – Fast version control system for very large projects. • Others: Mercurial, monotone, bazaar ... SVN: Introduction • SVN stands for Subversion • Link: http://subversion.apache.org/ • Free/open source version control system • Centralized version control system • Operates across networks • Source code is accessible by all developers and stored in a repository • One-time generation of a SVN "project" from original code • One repository can accommodate many projects • Available for Unix/Linux and Windows systems – Special commands for cross usage SVN: Introduction • Options for repository access: – dedicated server, – separate password database directory on arbitrary host, – access via ssh, – local directory on development machine with group access for all developers • Repository contains the full, detailed history of each source file (who has changed what and why) • Limited practicality for binary data • Uses a copy-modify-merge model instead of lock-modify-unlock • What is SVN not? – Data backup system – Generic Distribution system Functionality Single-user functionality: • Change control/mgmt in source code. • Introduction of new files / changes to existing files. • Automatic management of running version numbers on all project files. • Return to any previous revision is always possible. • Tagging of "releases", i.e. current status of a whole project. • Generation of separate branches for independent development Multi-user functionality: • Coordination of complex projects with more than one developer. • Several developers can work with the code simultaneously • No "file locking": several developers can work at the same file simultaneously. • SVN recognizes conflicts and reports them to users • SVN is no substitute for a sensible development strategy! Glossary • Repository: Database, containing the complete source code history of the project. • Revision: Current state ("snapshot") of a file or group of files in the repository. • Sandbox (working copy): Private extract of the project source code from the repository for one developer. • Check out: Request a working copy of a project from the repository. • Commit (check in): Introduce changes on files in a sandbox back into the repository (repository is changed) • Log Message: Developer's comment that is stored together with the changes of a commit. • Update: Synchronize a developer's private sandbox with the current repository (sandbox is changed). • Conflict: Two developers make changes at the same point in the same file. Must be resolved manually. • Trunk or HEAD: the up-to-date version of the SVN. (It’s usefull to call the containing directory “trunk”. Example of development process. 1 2 3 Repository checkout commit commit update commit 1 2 3 3 Sand- 1 box commit update checkout commit commit Sand- 3 1 1 1 box 1 update checkout 3 Sand- 2 box 1 SVN Options and commands • General syntax of svn commands: svn <command> <command parameters> <switches> Example of commands: add, commit, checkout, update, etc... Example of switches: --dry-run, --quiet (-q), --revision (-r). • Switches are dependent on the command. • Switches might have parameters themselves. • Important switch: -m “message” or use --message “message” • Repository administration programs svnadmin and svnlook use the same syntax Create a repository • Create the repository: svnadmin create --fs-type fsfs /path/to/repository/ • This creates a virtual directory structure svn mkdir file:///path/to/repository/trunk -m “trunk” svn ls file:///path/to/repository/ • You can manage your virtual directory using the unix- like standard commands svn mv <from> <to> -m “msg” svn cp <from> <to> -m “msg” svn rm <url path> -m “msg” Configure the repository • After creating the repository, access controls may be altered: – Open conf/svnserver.conf found inside the newly created repository folder • Common values to alter: – anon-access • access control for non authenticated users • better to set it to none (anon-access=none) – auth-access • access control for authenticated users • will need se it to “read” or “write” (auth-access=read) Importing your project • Create your dir: svn mkdir file:///path/to/repository/trunk /myproj -m “dir for my project” • Import the project files: cd /path/to/work/myproj Importing your project NOTE! Before importing a project clean all the files which should not be version-controlled, this usually include compiled code and binaries. svn import file:///path/to/repository/trunk/myproj -m “importing project” This will import your files to your newly created myproj Check what you have imported: svn list –R file:///path/to/repository/trunk/myproj Use common layout • As an advice you should use the following directory tree for your repository – repos/trunk/ – repos/branches/ – repos/tags/ • trunk will hold the main line of development • branches contains branch copies • tags contains tags copies Checkout and existing project Also to work on your files, or someone else’s files, you will need a copy. • Create your working directory mkdir /path/to/work cd /path/to/work/ • Get a working copy with URL: svn checkout https://svn.somelink.de/repository/project • SSH checkout: svn checkout svn+ssh://url/path/to/project/ • Local machine checkout (file as url): svn checkout file:///path/to/project/ • With the previous cases you copy the folder „project“: $> ls /path/to/work project • In general you can also specify a target directory: mkdir /path/to/work/project/ svn checkout <ssh or url>/path/to/project/█ /path/to/work/project/ Update your sandbox You want to get the changes your team has committed (latest revision of the code). Let‘s assume you have no conflicts to resolve (files to update have not been modifyied by you). cd /path/to/work/project/ svn update Files which have been modified in the repository will be copied into your project folder. Incoming files are listed with „U“ (Updated): U main.c Please note: your sandbox version will be overwritten, but still available on svn. You can always obtain a previous version which has been committed by typing: svn update –r 4 Commit • Before a commit, always check the status of your sandbox. It‘s not mandatory but a good practice. svn status M myfile.cpp svn commit –m “updated myfile.cpp” sending myfile.cpp … If there was a conflict svn will display at the end: svn: Out of date: “myfile.cpp” This is Okay. SVN has detected a that the file you want to commit has a change since you last updated it. Managing conflicts • Try updating the file. That means getting the changes. If the conflict does not appear on the same lines you have modified: You are done. svn update G myfile.cpp • If you open your file you will see the changes incorporated. Check if you agree with the merged version and commit again. SVN Your local file Your local file Managing conflicts • You used the svn update command, but the conflicts are on the same lines. • SVN tells you that myfile.cpp has a conflict: svn update C myfile.cpp • SVN asks for input for the user: “put back”, “full own file”, full repository file. If you choose “put back” you will not update the file but you get two additional files. myfile.cpp.r5 and myfile.cpp.r6 • You can compare the files with an editor and decide for the changes that should be committed to the repository. Managing conflicts • What are your options? – Throw your changes and update those from the colleague. – Keep you changes and dump what the colleague did. – Merge both versions into a single one. Managing conflicts • Throwing away your changes und updating your colleagues’ work: svn revert myfile.cpp This is the easiest procedure in terms of svn managing. You don’t need to commit this file. But you loose all your changes. SVN Your local file Your local file Managing conflicts • Keep your changes and throw away what the colleague did. Copy myfile.cpp.mine to myfile.cpp and then tell subversion that you have resolved the conflict. svn resolved myfile.cpp SVN • The resolved command will clean all the special files that were created. Commit your file as you SVN normally would. Your local file Managing conflicts • You have to manually merge both files. Use an editor which allows you to compare them. The merging occurs on your local myfile.cpp • Mark as resolved like in the previous slide and commit. SVN Your Your local file SVN local file Adding, Renaming and deleting a file • To add a file: svn add • Rename the file using the command svn mv. svn mv source.txt destination.txt • To delete a file svn delete • Commit! and you are done • Files in svn are not really deleted, they can be “revived” by reverting to the version they had before deletion. Advanced Topics: Release Tags File A File B File C File C File E 1 1 1 1 1 2 2 2 2 2 3 3 3 3 3 4 4 4 4 5 5 5 6 6 6 7 7 8 9 Advanced Topics: Release Tags • You have arrived to an acceptable version of your code and want to make a release. The trunk of HEAD on svn can be „tagged“ with a release tag to have these version always available. cd /path/to/project/ svn mkdir tags A tags svn copy trunk/ tags/conv-1.0 • Then simply commit this copy. svn commit -m “tagged version conv-1.0” tags/ • Internally the svn’s database doesn’t make a copy but remembers that conv-1.0 refers to the project at a given time.
Recommended publications
  • Efficient Algorithms for Comparing, Storing, and Sharing
    EFFICIENT ALGORITHMS FOR COMPARING, STORING, AND SHARING LARGE COLLECTIONS OF EVOLUTIONARY TREES A Dissertation by SUZANNE JUDE MATTHEWS Submitted to the Office of Graduate Studies of Texas A&M University in partial fulfillment of the requirements for the degree of DOCTOR OF PHILOSOPHY May 2012 Major Subject: Computer Science EFFICIENT ALGORITHMS FOR COMPARING, STORING, AND SHARING LARGE COLLECTIONS OF EVOLUTIONARY TREES A Dissertation by SUZANNE JUDE MATTHEWS Submitted to the Office of Graduate Studies of Texas A&M University in partial fulfillment of the requirements for the degree of DOCTOR OF PHILOSOPHY Approved by: Chair of Committee, Tiffani L. Williams Committee Members, Nancy M. Amato Jennifer L. Welch James B. Woolley Head of Department, Hank W. Walker May 2012 Major Subject: Computer Science iii ABSTRACT Efficient Algorithms for Comparing, Storing, and Sharing Large Collections of Evolutionary Trees. (May 2012) Suzanne Jude Matthews, B.S.; M.S., Rensselaer Polytechnic Institute Chair of Advisory Committee: Dr. Tiffani L. Williams Evolutionary relationships between a group of organisms are commonly summarized in a phylogenetic (or evolutionary) tree. The goal of phylogenetic inference is to infer the best tree structure that represents the relationships between a group of organisms, given a set of observations (e.g. molecular sequences). However, popular heuristics for inferring phylogenies output tens to hundreds of thousands of equally weighted candidate trees. Biologists summarize these trees into a single structure called the consensus tree. The central assumption is that the information discarded has less value than the information retained. But, what if this assumption is not true? In this dissertation, we demonstrate the value of retaining and studying tree collections.
    [Show full text]
  • Analysis of Devops Tools to Predict an Optimized Pipeline by Adding Weightage for Parameters
    International Journal of Computer Applications (0975 – 8887) Volume 181 – No. 33, December 2018 Analysis of DevOps Tools to Predict an Optimized Pipeline by Adding Weightage for Parameters R. Vaasanthi V. Prasanna Kumari, PhD S. Philip Kingston Research Scholar, HOD, MCA Project Manager SCSVMV University Rajalakshmi Engineering Infosys, Mahindra City, Kanchipuram College, Chennai Chennai ABSTRACT cloud. Now-a-days more than ever, DevOps [Development + Operations] has gained a tremendous amount of attention in 2. SCM software industry. Selecting the tools for building the DevOps Source code management (SCM) is a software tool used for pipeline is not a trivial exercise as there are plethora’s of tools development, versioning and enables team working in available in market. It requires thought, planning, and multiple locations to work together more effectively. This preferably enough time to investigate and consult other plays a vital role in increasing team’s productivity. Some of people. Unfortunately, there isn’t enough time in the day to the SCM tools, considered for this study are GIT, SVN, CVS, dig for top-rated DevOps tools and its compatibility with ClearCase, Mercurial, TFS, Monotone, Bitkeeper, Code co- other tools. Each tool has its own pros/cons and compatibility op, Darcs, Endevor, Fossil, Perforce, Rational Synergy, of integrating with other tools. The objective of this paper is Source Safe, and GNU Bazaar. Table1 consists of SCM tools to propose an approach by adding weightage to each with weightage. parameter for the curated list of the DevOps tools. 3. BUILD Keywords Build is a process that enables source code to be automatically DevOps, SCM, dependencies, compatibility and pipeline compiled into binaries including code level unit testing to ensure individual pieces of code behave as expected [4].
    [Show full text]
  • DVCS Or a New Way to Use Version Control Systems for Freebsd
    Brief history of VCS FreeBSD context & gures Is Arch/baz suited for FreeBSD? Mercurial to the rescue New processes & policies needed Conclusions DVCS or a new way to use Version Control Systems for FreeBSD Ollivier ROBERT <[email protected]> BSDCan 2006 Ottawa, Canada May, 12-13th, 2006 Ollivier ROBERT <[email protected]> DVCS or a new way to use Version Control Systems for FreeBSD Brief history of VCS FreeBSD context & gures Is Arch/baz suited for FreeBSD? Mercurial to the rescue New processes & policies needed Conclusions Agenda 1 Brief history of VCS 2 FreeBSD context & gures 3 Is Arch/baz suited for FreeBSD? 4 Mercurial to the rescue 5 New processes & policies needed 6 Conclusions Ollivier ROBERT <[email protected]> DVCS or a new way to use Version Control Systems for FreeBSD Brief history of VCS FreeBSD context & gures Is Arch/baz suited for FreeBSD? Mercurial to the rescue New processes & policies needed Conclusions The ancestors: SCCS, RCS File-oriented Use a subdirectory to store deltas and metadata Use lock-based architecture Support shared developments through NFS (fragile) SCCS is proprietary (System V), RCS is Open Source a SCCS clone exists: CSSC You can have a central repository with symlinks (RCS) Ollivier ROBERT <[email protected]> DVCS or a new way to use Version Control Systems for FreeBSD Brief history of VCS FreeBSD context & gures Is Arch/baz suited for FreeBSD? Mercurial to the rescue New processes & policies needed Conclusions CVS, the de facto VCS for the free world Initially written as shell wrappers over RCS then rewritten in C Centralised server Easy UI Use sandboxes to avoid locking Simple 3-way merges Can be replicated through CVSup or even rsync Extensive documentation (papers, websites, books) Free software and used everywhere (SourceForge for example) Ollivier ROBERT <[email protected]> DVCS or a new way to use Version Control Systems for FreeBSD Brief history of VCS FreeBSD context & gures Is Arch/baz suited for FreeBSD? Mercurial to the rescue New processes & policies needed Conclusions CVS annoyances and aws BUT..
    [Show full text]
  • CSE 391 Lecture 9
    CSE 391 Lecture 9 Version control with Git slides created by Ruth Anderson & Marty Stepp, images from http://git-scm.com/book/en/ http://www.cs.washington.edu/391/ 1 Problems Working Alone • Ever done one of the following? . Had code that worked, made a bunch of changes and saved it, which broke the code, and now you just want the working version back… . Accidentally deleted a critical file, hundreds of lines of code gone… . Somehow messed up the structure/contents of your code base, and want to just “undo” the crazy action you just did . Hard drive crash!!!! Everything’s gone, the day before deadline. • Possible options: . Save as (MyClass-v1.java) • Ugh. Just ugh. And now a single line change results in duplicating the entire file… 2 Problems Working in teams . Whose computer stores the "official" copy of the project? • Can we store the project files in a neutral "official" location? . Will we be able to read/write each other's changes? • Do we have the right file permissions? • Lets just email changed files back and forth! Yay! . What happens if we both try to edit the same file? • Bill just overwrote a file I worked on for 6 hours! . What happens if we make a mistake and corrupt an important file? • Is there a way to keep backups of our project files? . How do I know what code each teammate is working on? 3 Solution: Version Control • version control system: Software that tracks and manages changes to a set of files and resources. • You use version control all the time .
    [Show full text]
  • Software Development a Practical Approach!
    Software Development A Practical Approach! Hans-Petter Halvorsen https://www.halvorsen.blog https://halvorsen.blog Software Development A Practical Approach! Hans-Petter Halvorsen Software Development A Practical Approach! Hans-Petter Halvorsen Copyright © 2020 ISBN: 978-82-691106-0-9 Publisher Identifier: 978-82-691106 https://halvorsen.blog ii Preface The main goal with this document: • To give you an overview of what software engineering is • To take you beyond programming to engineering software What is Software Development? It is a complex process to develop modern and professional software today. This document tries to give a brief overview of Software Development. This document tries to focus on a practical approach regarding Software Development. So why do we need System Engineering? Here are some key factors: • Understand Customer Requirements o What does the customer needs (because they may not know it!) o Transform Customer requirements into working software • Planning o How do we reach our goals? o Will we finish within deadline? o Resources o What can go wrong? • Implementation o What kind of platforms and architecture should be used? o Split your work into manageable pieces iii • Quality and Performance o Make sure the software fulfills the customers’ needs We will learn how to build good (i.e. high quality) software, which includes: • Requirements Specification • Technical Design • Good User Experience (UX) • Improved Code Quality and Implementation • Testing • System Documentation • User Documentation • etc. You will find additional resources on this web page: http://www.halvorsen.blog/documents/programming/software_engineering/ iv Information about the author: Hans-Petter Halvorsen The author currently works at the University of South-Eastern Norway.
    [Show full text]
  • Distributed Versioning for Everyone
    Distributed versioning for everyone Distributed versioning for everyone Nicolas Pouillard [email protected] March 20, 2008 Nicolas Pouillard Distributed versioning for everyoneMarch 20, 2008 1 / 48 Distributed versioning for everyone Introduction Outline 1 Introduction 2 Principles of Distributed Versioning 3 Darcs is one of them 4 Conclusion Nicolas Pouillard Distributed versioning for everyoneMarch 20, 2008 2 / 48 Distributed versioning for everyone Introduction SCM: “Source Code Manager” Keeps track of changes to source code so you can track down bugs and work collaboratively. Most famous example: CVS Numerous acronyms: RCS, SCM, VCS DSCM: Distributed Source Code Manager Nicolas Pouillard Distributed versioning for everyoneMarch 20, 2008 3 / 48 Distributed versioning for everyone Introduction Purpose What’s the purpose of this presentation Show the importance of the distributed feature Enrich your toolbox with a DSCM Exorcize rumors about darcs Show how DSCM are adapted for personal use What’s not the purpose of it A flame against other DSCMs A precise darcs tutorial A real explanation of the Theory of patches Nicolas Pouillard Distributed versioning for everyoneMarch 20, 2008 4 / 48 Distributed versioning for everyone Principles of Distributed Versioning Outline 1 Introduction 2 Principles of Distributed Versioning 3 Darcs is one of them 4 Conclusion Nicolas Pouillard Distributed versioning for everyoneMarch 20, 2008 5 / 48 Distributed versioning for everyone Principles of Distributed Versioning Distributed rather than centralized
    [Show full text]
  • Version Control
    Génie Logiciel Avancé Cours 7 — Version Control Stefano Zacchiroli [email protected] Laboratoire PPS, Université Paris Diderot - Paris 7 5 mai 2011 URL http://upsilon.cc/zack/teaching/1011/gla/ Copyright © 2011 Stefano Zacchiroli License Creative Commons Attribution-ShareAlike 3.0 Unported License http://creativecommons.org/licenses/by-sa/3.0/ Stefano Zacchiroli (Paris 7) Version Control 5 mai 2011 1 / 58 Disclaimer slides in English interactive demos Stefano Zacchiroli (Paris 7) Version Control 5 mai 2011 2 / 58 Sommaire 1 Version control Configuration management diff & patch Version control concepts Brief history of version control systems 2 Revision Control System (RCS) 3 Concurrent Versions System (CVS) 4 Subversion 5 Git 6 References Stefano Zacchiroli (Paris 7) Version Control 5 mai 2011 3 / 58 Sommaire 1 Version control Configuration management diff & patch Version control concepts Brief history of version control systems 2 Revision Control System (RCS) 3 Concurrent Versions System (CVS) 4 Subversion 5 Git 6 References Stefano Zacchiroli (Paris 7) Version Control 5 mai 2011 4 / 58 Sommaire 1 Version control Configuration management diff & patch Version control concepts Brief history of version control systems 2 Revision Control System (RCS) 3 Concurrent Versions System (CVS) 4 Subversion 5 Git 6 References Stefano Zacchiroli (Paris 7) Version Control 5 mai 2011 5 / 58 Change During the life time of a software project, everything changes : bugs are discovered and have to be fixed (code) system requirements change and need to be implemented external dependencies (e.g. new version of hardware and software you depend upon) change competitors might catch up most software systems can be thought of as a set of evolving versions potentially, each of them has to be maintained concurrently with the others Stefano Zacchiroli (Paris 7) Version Control 5 mai 2011 6 / 58 Configuration management Definition (Configuration Management) Configuration Management (CM) is concerned with the policies, processes, and tools for managing changing software systems.
    [Show full text]
  • Analysis of SVN Repositories for Remote Access
    Analysis of SVN Repositories for Remote Access Sadaf Solangi and Safeeullah Soomro Suhni Abbasi Department of Computing and Technology Institute of Information Technology Center Faculty of Engineering & Technology, Indus University Faculty of Social Sciences, Sindh Agricultural Karachi, Pakisstan University Tando Jam, Pakistan e-mail:{sadaf.solangi,ssoomro}@indus.edu.pk [email protected] Abstract— Software Evolution is considered to be essential and collections [10].How digital repositories were well used and challenging characteristic in the field of software engineering. for what, by address of recording [7]. Version control system is an incremental versions tracking system, introduced to avoid unnecessary overwriting of files A. SVN Repository such as programming code, web pages and records. It also helps to decrease the confusion affected by duplicate or A repository is information about the database that is shared outdated data. In this proposed research SVN repository is engineered artifacts created and used by enterprise. A common maintained and analyzed for msitone.wikispaces.com to repository allows instruments to share information, not including minimize the efforts as well as resources for the future users. a common Repository, and it will need a particular protocol We have used two semester data for the analysis purpose that Exchange of information between machines [13].Examples of is observed SVN repository. The result shows that, such sample includes, software, documents etc. Repository implementing the SVN repositories are helpful for has three types of sessions such as trunk, branches and maintenance of the Wikispaces as it also reduce the cost, time and efforts for their evolution. Whereas without implementing tags.
    [Show full text]
  • Darcs: Distributed Version Management in Haskell
    Introduction to darcs What worked and what didn’t Second half of talk... Conclusion Darcs: Distributed Version Management in Haskell David Roundy Cornell University September 30, 2005 David Roundy Darcs: Distributed Version Management in Haskell Introduction to darcs What worked and what didn’t Second half of talk... Conclusion Some incomprehensible equations A classical density functional F [ρ] for the free energy of a fluid is given by Z F [ρ] = d~r [f ideal (ρ(~r)) + f exc (¯ρ(~r)) + ρ(~r)ξ(~r)] (1) where the weighted densityρ ¯ is defined by Z ρ¯(~r) = d~r 0ρ(~r 0)W (~r −~r 0) (2) and the correction term ρ(~r)ξ(~r) is determined by Z 0 0 0 0 ξ(~r) = − d~r ρ(~r )(kB TC(~r −~r ) + W (~r −~r )) (3) where C(∆~r) is the direct correlation function. δ2F = −k T ρ(~r)[δ(~r −~r 0) + C(~r −~r 0)] (4) δρ(~r)δρ(~r 0) B David Roundy Darcs: Distributed Version Management in Haskell Introduction to darcs What worked and what didn’t Second half of talk... Conclusion Outline Introduction to darcs Ideas behind darcs What worked and what didn’t A pure functional language for an SCM? Laziness and unsafeInterleaveIO Object-oriented-like data structures QuickCheck Foreign Function Interface Efficient string handling Handles and zlib and threads Error handling and cleanup Optimization experiences David Roundy Darcs: Distributed Version Management in Haskell Introduction to darcs Ideas behind darcs What worked and what didn’t Distributed rather than centralized Second half of talk..
    [Show full text]
  • Open Source Version Control Thomas Keller HTWK Leipzig
    Open Source Version Control Thomas Keller HTWK Leipzig University Of Applied Sciences Department Computer Science, Mathematics & Natural Sciences Bachelor Thesis in Media Computer Science Open Source Version Control Thomas Keller Tutor: Prof. Dr. Michael Frank Co-tutor: Prof. Dr. Klaus Hering Date of Completion: March 20th, 2006 I affirm that I have created this Bachelor Thesis independently and only with the use of the documented references. Leipzig, in March 2006 ........................................................................... This work is licensed under the terms of the GNU Free Documentation License. See chapter Copyright Notices for details. I would like to thank My beloved girl (soon wife) Marlen, who always supported me during the process of writing this work, My tutor, Mr Prof Dr Michael Frank, who always had a sympathetic ear for my concerns, My good friend Chad Connolly from Delaware/USA, who helped me a great deal to find and fix spelling issues in this work, And finally my cousin Martin Fischer, another guy who has helped me a lot with his positive criticism. Thank you all! Table of Contents Preface.....................................................................................................................................................1 Vorwort...................................................................................................................................................2 Document Conventions...........................................................................................................................3
    [Show full text]
  • A Practical Introduction to Version Control Systems
    Version Control Systems Centralised - SVN Decentralised - Git A Practical Introduction to Version Control Systems A random CAKES(less) talk on a topic I hope others find useful! Andrew Brampton [email protected] 4th February 2009 Andrew Brampton A Practical Introduction to Version Control Systems Version Control Systems Centralised - SVN Decentralised - Git Outline 1 Version Control Systems What is Version Control Basic Principles Versioning Models 2 Centralised - SVN Overview Commands 3 Decentralised - Git Overview Commands Andrew Brampton A Practical Introduction to Version Control Systems Version Control Systems What is Version Control Centralised - SVN Basic Principles Decentralised - Git Versioning Models What can version control do for you? Backup your work Rollback changes The original time machine Collaborate with others Multiple users can share and edit documents Access documents online If your repository is online, you can easily access your files anywhere Andrew Brampton A Practical Introduction to Version Control Systems Version Control Systems What is Version Control Centralised - SVN Basic Principles Decentralised - Git Versioning Models The Repository Description Where all the files and directories are stored Stores the histories of all your files and directories Users read and write files to it Andrew Brampton A Practical Introduction to Version Control Systems Version Control Systems What is Version Control Centralised - SVN Basic Principles Decentralised - Git Versioning Models The Working Copy Description A local copy
    [Show full text]
  • Monotone: a Distributed Version Control System
    Monotone A distributed version control system Graydon Hoare and others This manual is for the \monotone" distributed version control system. This edition docu- ments version 1.1. Copyright c 2003, 2004, 2011 Graydon Hoare Copyright c 2004, 2005, 2006 Nathaniel Smith Copyright c 2005 - 2010 Derek Scherger Copyright c 2005, 2006 Daniel Carosone Copyright c 2006 Jeronimo Pellegrini Copyright c 2006 Alex Queiroz Copyright c 2006, 2007 William Uther Copyright c 2006 - 2010 Thomas Keller Copyright c 2007 - 2012 Stephen Leake This manual is made available under the GNU GPL version 2.0 or greater. See the accom- panying file COPYING for details. i Table of Contents 1 Concepts :::::::::::::::::::::::::::::::::::::::: 1 1.1 Versions of files :::::::::::::::::::::::::::::::::::::::::::::::: 2 1.2 Versions of trees:::::::::::::::::::::::::::::::::::::::::::::::: 4 1.3 Historical records :::::::::::::::::::::::::::::::::::::::::::::: 6 1.4 Certificates::::::::::::::::::::::::::::::::::::::::::::::::::::: 8 1.5 Storage and workflow ::::::::::::::::::::::::::::::::::::::::: 10 1.6 Forks and merges ::::::::::::::::::::::::::::::::::::::::::::: 13 1.7 Branches:::::::::::::::::::::::::::::::::::::::::::::::::::::: 15 1.7.1 Heads and merging ::::::::::::::::::::::::::::::::::::::: 15 1.7.2 Branch Names ::::::::::::::::::::::::::::::::::::::::::: 17 2 Tutorial :::::::::::::::::::::::::::::::::::::::: 19 2.1 Issues ::::::::::::::::::::::::::::::::::::::::::::::::::::::::: 19 2.1.1 Standard Options :::::::::::::::::::::::::::::::::::::::: 19 2.1.2 Revision
    [Show full text]