August 22, New Views on your History with git replace. Christian Couder
|
|
- Chad Walton
- 6 years ago
- Views:
Transcription
1 August 22, 2014 New Views on your History with git replace Christian Couder
2 About Git A Distributed Version Control System (DVCS): created by Linus Torvalds maintained by Junio Hamano since 2005 preferred VCS among free and open source developers
3 About myself started developing Git in 2006 worked on git bisect developed git replace in 2009 $dayjob at SoftAtHome
4 Git Design Git is made of these things: Objects Refs config, indexes, logs, hooks, grafts, packs,... Only Objects and Refs are transferred from one repository to another.
5 Git Objects Blob: content of a file Tree: content of a directory Commit: state of the whole source code Tag: stamp on an object
6 Git Objects Storage Git Objects are stored in a content addressable database. The key to retrieve each Object is the SHA-1 of the Object s content. A SHA-1 is a 160-bit / 40-hex / 20-byte hash value which is considered unique.
7 Blob SHA1: e blob <size> blob = content of a file /* content of this blob, it can be anything like an image, a video,... but most of the time it is source code like:*/ #include <stdio.h> int main(void) { printf("hello world!\n"); return 0; }
8 Example of storing and retrieving a blob $ echo "Whatever..." git hash-object -w --stdin aa eea6d8e0bc68f3663de51767a9f5b1 $ git cat-file -p aa Whatever...
9 Tree SHA1: 0de24... tree = content of a directory tree <size> blob hello.c e It can point to blobs and other tree lib 10af9... trees.
10 Example of storing and retrieving a tree $ BLOB=aa eea6d8e0bc68f3663de51767a9f5b1 $ (printf " whatever.txt\0"; echo $BLOB xxd -r -p) git hash-object -t tree -w --stdin 0625da548ef0a7038c44b480f10d5550b2f2f962 $ git cat-file -p 0625da548e blob aa whatever.txt
11 Commit SHA1: 98ca9... tree commit 0de24... <size> commit = information about some changes parents author committer () Christian <timestamp> Christian <timestamp> It points to one tree and 0 or more parents. My commit message
12 Example of storing and retrieving a commit (1) $ TREE=0625da548ef0a7038c44b480f10d5550b2f2f962 $ ME= Christian Couder <chriscool@tuxfamily.org> $ DATE=$(date "+%s %z") $ (echo -e "tree $TREE\nauthor $ME $DATE"; echo -e "committer $ME $DATE\n\nfirst commit") git hash-object -t commit -w --stdin 37449e a0a888ee100cfd0a7ba7927b3
13 Example of storing and retrieving a commit (2) $ git cat-file -p 37449e9554 tree 0625da548ef0a7038c44b480f10d5550b2f2f962 author Christian Couder <chriscool@tuxfamily.org> committer Christian Couder <chriscool@tuxfamily.org> first commit
14 Git Objects Relations SHA1: e84c7... commit <size> tree 29c43... parents () author Christian <ts> committer Christian <ts> Initial commit SHA1: 29c43... tree <size> blob hello.c tree doc 0de ca9... SHA1: 0de24... blob <size> int main() {... } SHA1: 98ca9... tree <size> blob readme 677f4... SHA1: 98ca9... blob install 23ae9... commit <size> tree 5c11f... parents (e84c7...) author Arnaud <ts> committer Arnaud <ts> Change hello.c SHA1: 5c11f... tree <size> blob hello.c bc tree doc 98ca9... SHA1: bc blob <size> int main(void) {... }
15 Git Refs Head: branch.git/refs/heads/ Tag: lightweight tag.git/refs/tags/ Remote: distant repository.git/refs/remotes/ Note: note attached to an object.git/refs/notes/ Replace: replacement of an object.git/refs/replace/
16 Example of storing and retrieving a branch $ git update-ref refs/heads/master 37449e9554 $ git rev-parse master 37449e a0a888ee100cfd0a7ba7927b3 $ git reset --hard master HEAD is now at 37449e9 first commit $ cat whatever.txt Whatever...
17 Result from previous examples master commit 37449e9554 tree 0625da548e blob aa
18 Commits in Git form a DAG (Directed Acyclic Graph) history direction is from left to right new commits point to their parents
19 git bisect B B introduces a bad behavior called "bug" or "regression" red commits are called "bad" blue commits are called "good"
20 Problem when bisecting Sometimes the commit that introduced a bug will be in an untestable area of the graph. For example: W X X1 X2 X3 Y Z Commit X introduced a breakage, later fixed by commit Y.
21 Possible solutions Possible solutions to bisect anyway: apply a patch before testing and remove it afterwards (can be done using "git cherry-pick"), or create a fixed up branch (can be done with "git rebase -i"), for example: X + Y X1' X2' X3' Z' W X X1 X2 X3 Y Z Z1
22 A good solution The idea is that we will replace Z with Z' so that we bisect from the beginning using the fixed up branch. X + Y X1' X2' X3' Z' Z1 W X X1 X2 X3 Y Z $ git replace Z Z'
23 Grafts Created mostly for projects like linux kernel with old repositories..git/info/grafts file each line describe parents of a commit <commit> <parent> [<parent>]* this overrides the content in the commit
24 Problem with Grafts They are neither objects nor refs, so they cannot be easily transferred. We need something that is either: an object, or a ref.
25 Solution, part 1: replace ref It is a ref in.git/refs/replace/ Its name is the SHA-1 of the object that should be replaced. It contains, so it points to, the SHA-1 of the replacement object.
26 Solution, part 2: git replace git replace [ -f ] <object> <replacement> to create a replace ref git replace -d <object> to delete a replace ref git replace [--format=<format>] [ -l [ pattern ] ] to list some replace refs
27 Replace ref transfer as with heads, tags, notes, remotes except that there are no shortcuts and you must be explicit refspec: refs/replace/*:refs/replace/* refspec can be configured (in.git/config), or used on the command line (after git push/fetch <remote>)
28 Creating replacement objects When it is needed the following commands can help: git rebase [ -i ] git cherry-pick git hash-object git filter-branch (or maybe tools like BFG Repo-Cleaner)
29 What can it be used for? Create new views of your history. Right now only 2 views are possible: the view with all the replace refs enabled, or the view with all the replace refs disabled, using --no-replace-objects or the GIT_NO_REPLACE_OBJECTS environment variable
30 Why new views? split old and new history or merge them fix bugs to bisect on a clean history fix mistakes in author, committer, timestamps remove big files to have something lighter to use, when you don t need them prepare a repo cleanup mask/unmask some steps (see git imerge)...
31 Limitations everything is still in the repo so the repo is still big there are probably bugs insecure? complex? confusing?
32 Current and future work git replace --edit git replace --graft fix bugs allow subdirectories in.git/refs/replace/ maybe allow views as set of active subdirectories...
33 Conclusion best of both world: immutability and configurability of history no true view history is important for freedom
34 Many thanks to: Junio Hamano (comments, help, discussions, reviews, improvements), Ingo Molnar, Linus Torvalds, many other great people in the Git and Linux communities, especially: Andreas Ericsson, Johannes Schindelin, H. Peter Anvin, Daniel Barkalow, Bill Lear, John Hawley,... LinuxTag organizers and attendants, SoftAtHome, the company I am working for.
35 Questions?
36
Git. A Distributed Version Control System. Carlos García Campos
Git A Distributed Version Control System Carlos García Campos carlosgc@gnome.org Carlos García Campos carlosgc@gnome.org - Git 1 A couple of Quotes For the first 10 years of kernel maintenance, we literally
More informationVersioning with git. Moritz August Git/Bash/Python-Course for MPE. Moritz August Versioning with Git
Versioning with git Moritz August 13.03.2017 Git/Bash/Python-Course for MPE 1 Agenda What s git and why is it good? The general concept of git It s a graph! What is a commit? The different levels Remote
More informationUnderstanding. Steve
Understanding Steve Smith It's easy, it's just a directed acyclic graph! If I hear that one more time I may have to punch something! Emma Jane Hogbin Westby, Git-Merge 2015 internals Carlsberg Blobs,
More informationGit. all meaningful operations can be expressed in terms of the rebase command. -Linus Torvalds, 2015
Git all meaningful operations can be expressed in terms of the rebase command -Linus Torvalds, 2015 a talk by alum Ross Schlaikjer for the GNU/Linux Users Group Sound familiar? add commit diff init clone
More informationWhy? Clean Model Branches Local reflog Flows Doc Ex. Advanced use of Git. Matthieu Moy
Advanced use of Git Matthieu Moy Matthieu.Moy@imag.fr https://matthieu-moy.fr/cours/formation-git/advanced-git-slides.pdf 2018 Matthieu Moy (Matthieu.Moy@imag.fr) Advanced Git 2018 < 1 / 75 > Goals of
More informationDistributed Version Control (with Git)
Distributed Version Control (with Git) Introduction and Tutorial fhlug 24. 03. 2011 Why Distributed? No single point of failure Automatic backups Fast local operations (log, diff, checkout, ) Authenticity
More informationAdvanced Git. Luc Sarzyniec. Xilopix, February / 88
Advanced Git Luc Sarzyniec Xilopix, February 2015 1 / 88 About This slides are using resources from the Pro Git book [isbn:1430218339] which is licensed under the Creative Commons v3.0 (by-nc-sa) license.
More informationUsing Git For Development. Shantanu Pavgi, UAB IT Research Computing
Using Git For Development Shantanu Pavgi, pavgi@uab.edu UAB IT Research Computing Outline Version control system Git Branching and Merging Workflows Advantages Version Control System (VCS) Recording changes
More informationGit Workflows. Sylvain Bouveret, Grégory Mounié, Matthieu Moy
s Sylvain Bouveret, Grégory Mounié, Matthieu Moy 2017 [first].[last]@imag.fr http://recherche.noiraudes.net/resources/git/git-workflow-slides.pdf 1 / 16 Goals of the presentation Global history: multiple
More informationa handful of Git workflows for the agilist steven harman twitter: stevenharman
a handful of Git workflows for the agilist steven harman twitter: stevenharman http://stevenharman.net stop worrying and start loving The Git. git is awesome - if you re using it, you know. if not, don
More informationVersion Control with Git
Version Control with Git Jon Loeliger O'REILLY Beijing Cambridge Farnham Köln Sebastopol Tokyo Table of Contents Preface... xi 1. Introduction... 1 Background 1 The Birth of Git 2 Precedents 4 Time Line
More informationWhy? Clean Model Branches Local reflog Flows Doc Ex. Advanced use of Git. Matthieu Moy
Advanced use of Git Matthieu Moy Matthieu.Moy@imag.fr https://matthieu-moy.fr/cours/formation-git/advanced-git-slides.pdf 2017 Matthieu Moy (Matthieu.Moy@imag.fr) Advanced Git 2017 < 1 / 74 > Goals of
More informationBest Practices. Joaquim Rocha IT-DSS-TD
Best Practices joaquim.rocha@cern.ch IT-DSS-TD January 24, 2014 About yours truly Contributor to/author of many Open Source projects Member of the GNOME Foundation Former member of Igalia and Red Hat Currently
More informationSource Code Management wih git
Source Code Management wih git Matthieu Herrb December 22 http://homepages.laas.fr/matthieu/cours/git.pdf Licence This work is licensed under a Creative Commons Attribution-ShareAlike 3. Unported License.
More informationGit. Ľubomír Prda. IT4Innovations.
Git Ľubomír Prda IT4Innovations lubomir.prda@vsb.cz support@it4i.cz VCS Version Control System Versioning - creation and management of multiple releases of a product, all of which have the same general
More informationRevision control Advanced git
Revision control Advanced git Waterford Institute of Technology April 30, 2016 John Fitzgerald Waterford Institute of Technology, Revision controladvanced git 1/35 Presentation outline Estimated duration
More informationIntroduction to GIT. The distributed SCM
Introduction to GIT The distributed SCM Bart Trojanowski
More informationGUIDE TO MAKE A REAL CONTRIBUTION TO AN OPEN SOURCE PROJECT 1. 1
GUIDE TO MAKE A REAL CONTRIBUTION TO AN OPEN SOURCE PROJECT 1. 1 WHO AM I? @tushar_rishav GSoC'16 student contributing to coala - a static code analysis tool, under Python So ware Foundation. A senior
More informationBasics of Git GitHub
Basics of Hub Why this Webinar? You registered for Microsoft codefundo++ Deadline to submit your idea is Oct 12th, 23:59 IST Getting you started with & Hub Agenda What is Version Control? What is the difference
More informationAgenda. Several projects are using GIT Developer(s) Junio Hamano, Linus Torvalds. Qt Stable release (January 31, 2011)
Basic Agenda 1 Project information Who is ussing 2 14 Oct 2011 3 Basic Data Transport Work ow 4 Con gure 5 Basic Project information Who is ussing Project information Who is ussing Project information
More informationIntroduction to GIT. Jordi Blasco 14 Oct 2011
Jordi Blasco (jblasco@xrqtc.com) 14 Oct 2011 Agenda 1 Project information Who is ussing GIT 2 Branch Tag Data Transport Workow 3 Congure 4 Working with remotes 5 Project information Who is ussing GIT Project
More informationCommon Git Commands. Git Crash Course. Teon Banek April 7, Teon Banek (TakeLab) Common Git Commands TakeLab 1 / 18
Common Git Commands Git Crash Course Teon Banek theongugl@gmail.com April 7, 2016 Teon Banek (TakeLab) Common Git Commands TakeLab 1 / 18 Outline 1 Introduction About Git Setup 2 Basic Usage Trees Branches
More informationGIT for companies Mark Struberg, INSO TU Vienna
GIT for companies Mark Struberg, INSO TU Vienna What is an SCM SCM stands for Source Code Management Checkin: organized common access to sources History: who did commit which code at what time. This creates
More informationIntroduction to Supercomputing
Introduction to Supercomputing TMA4280 Introduction to development tools 0.1 Development tools During this course, only the make tool, compilers, and the GIT tool will be used for the sake of simplicity:
More informationSubmitting your Work using GIT
Submitting your Work using GIT You will be using the git distributed source control system in order to manage and submit your assignments. Why? allows you to take snapshots of your project at safe points
More informationIndex. Alias syntax, 31 Author and commit attributes, 334
Index A Alias syntax, 31 Author and commit attributes, 334 B Bare repository, 19 Binary conflict creating conflicting changes, 218 during merging, 219 during rebasing, 221 Branches backup, 140 clone-with-branches
More informationGit Immersion Rails Conf 2010 Tutorial
Git Immersion Rails Conf 2010 Tutorial Jim Weirich Chief Scientist / EdgeCase jim@edgecase.com @jimweirich 1 Setup git config --global user.name "Jim Weirich" git config --global user.email "jim.weirich@gmail.com"
More informationTopics covered. Introduction to Git Git workflows Git key concepts Hands on session Branching models. Git 2
Git Git 1 Topics covered Introduction to Git Git workflows Git key concepts Hands on session Branching models Git 2 Introduction to Git Git 3 Version control systems The source files of a project changes
More informationWorking in Teams CS 520 Theory and Practice of Software Engineering Fall 2018
Working in Teams CS 520 Theory and Practice of Software Engineering Fall 2018 Version Control September 18, 2018 Thursday (September 20) First in-class exercise On using git (today is a prelude with useful
More informationOverview. 1. Install git and create a Github account 2. What is git? 3. How does git work? 4. What is GitHub? 5. Quick example using git and GitHub
Git 101: Overview 1. Install git and create a Github account 2. What is git? 3. How does git work? 4. What is GitHub? 5. Quick example using git and GitHub Github icon 1 Install git and a create GitHub
More informationGit for Newbies. ComMouse Dongyue Studio
Git for Newbies ComMouse Dongyue Studio 2018.4.25 Contents What is Git? Git Quick Start Git Branch Git Workflow Git in Practice What is Git? What is Git? A Version Control System (VCS) An Open-sourced
More informationAlgorithm Engineering
Algorithm Engineering Jens K. Mueller jkm@informatik.uni-jena.de Department of Mathematics and Computer Science Friedrich Schiller University Jena Tuesday 21 st October, 2014 Version Control with Git Version
More informationGit for (not-so) dummies
Git for (not-so) dummies Michaël Hauspie Université Lille 1 - IUT A - LIFL May 25, 2012 M. Hauspie (LIFL-IUT) Git May 25, 2012 1 / 115 Outline What is git? Local repository Using
More informationVersion Control: Gitting Started
ting Started Cai Li October 2014 What is Version Control? Version control is a system that records changes to a file or set of files over time so that you can recall specific versions later. Local Version
More informationWhat is git? Distributed Version Control System (VCS); Created by Linus Torvalds, to help with Linux development;
What is git? Distributed Version Control System (VCS); Created by Linus Torvalds, to help with Linux development; Why should I use a VCS? Repositories Types of repositories: Private - only you and the
More informationMaintaining an Out-of-Tree Driver and an Upstream Driver Simultaneously (with minimal pain)
Maintaining an Out-of-Tree Driver and an Upstream Driver Simultaneously (with minimal pain) Catherine Sullivan Intel LinuxCon 2015 Me Intel ND Linux Ethernet drivers 40G product line A little 10G Network
More informationWhat is version control? (discuss) Who has used version control? Favorite VCS? Uses of version control (read)
1 For the remainder of the class today, I want to introduce you to a topic we will spend one or two more classes discussing and that is source code control or version control. What is version control?
More informationgit the SCM system Jan-Simon Möller training.linuxfoundation.org
git the SCM system Jan-Simon Möller training.linuxfoundation.org Topics What is git (what is a SCM) How to install git How to personalize git How to use git for development What is git? What is a SCM System?
More informationGit. (Why not CVS?... because Git.) Karel Zak Florian Festi Bart Trojanowski December 20, 2007
Git (Why not CVS?... because Git.) Karel Zak Florian Festi Bart Trojanowski December 20, 2007 Copyright 2007 Karel Zak Copyright 2007 Tomas Janousek (beamer template) Copyright 2007 Florian Festi Copyright
More informationDVCS - Under the Bonnet
DVCS - Under the Bonnet What s going on in there? Jim Hague LAIC AG ACCU Conference 2011 Jim Hague (LAIC AG) DVCS - Under the Bonnet ACCU2011 1 / 75 Aims of the Session Look at the workings of two popular
More informationJohn DeDourek Professor Emeritus Faculty of Computer Science University of New Brunswick GIT
John DeDourek Professor Emeritus Faculty of Computer Science University of New Brunswick GIT What is Git? A source code control system Implies program code A version control system Implies any sort of
More informationGit - A brief overview
breno.leitao@gmail.com Linux Technology Center May 16, 2008 Agenda Introduction Concepts Commands (Tutorial) Front Ends History Started in 2005 to replace BitKeeper. Designed to support the kernel development.
More informationVersion Control with Git
Version Control with Git Xiaoxu Guan High Performance Computing, LSU November 11, 2015 (https://www.atlassian.com/git/tutorials) LSU HPC Training Series, Fall 2015 p. 1/52 Overview Why should we use a
More informationDecentralized Version Control Systems
Decentralized Version Control Systems Matthieu Moy Verimag 2007 Matthieu Moy (Verimag) DVC 2007 < 1 / 43 > Outline 1 Motivations, Prehistory 2 History and Categories of Version Control Systems 3 Version
More informationGit for Version Control
Git for Version Control These slides are heavily based on slides created by Ruth Anderson for CSE 390a. Thanks, Ruth! images taken from http://git-scm.com/book/en/ http://www.cs.washington.edu/403/ About
More informationVersion Control with GIT
Version Control with GIT Benjamin Roth CIS LMU München Benjamin Roth (CIS LMU München) Version Control with GIT 1 / 30 Version Control Version control [...] is the management of changes to documents, computer
More informationRe-implementing git. (a small part at least) Thibault Allançon November 2018
Re-implementing git (a small part at least) Thibault Allançon November 2018 1 Motivation Learning git inner workings «What I cannot create, I do not understand» Richard Feynman 2 Motivation Learning git
More informationCESSDA Expert Seminar 13 & 14 September 2016 Prague, Czech Republic
CESSDA Expert Seminar 13 & 14 September 2016 Prague, Czech Republic - basics Matthäus Zloch GESIS Outline for this session Git introduction and some theory Git command basics (plus some little advanced)
More informationDESCRIPTION Git dpm is a tool to handle a debian source package in a git repository.
NAME git dpm debian packages in git manager SYNOPSIS git dpm help git dpm [ options ] command [ per command options and arguments ] DESCRIPTION Git dpm is a tool to handle a debian source package in a
More informationIntroduction, Instructions and Conventions
Encodo Systems AG Garnmarkt 1 8400 Winterthur Telephone +41 52 511 80 80 www.encodo.com Encodo GIT handbook Introduction, Instructions and Conventions Abstract This document is an introduction to using
More informationAbout SJTUG. SJTU *nix User Group SJTU Joyful Techie User Group
About SJTUG SJTU *nix User Group SJTU Joyful Techie User Group Homepage - https://sjtug.org/ SJTUG Mirrors - https://mirrors.sjtug.sjtu.edu.cn/ GitHub - https://github.com/sjtug Git Basic Tutorial Zhou
More informationGitting things done. Hands-on introduction to git niceties. Jan Urbański Ducksboard
Gitting things done Hands-on introduction to git niceties Jan Urbański jan@ducksboard.com Ducksboard Atlassian Git Party, Madrid, September 25, 2012 Jan Urbański (Ducksboard) Gitting things done Atlassian
More informationGit and Gerrit Workflows. Enforcing Manual & Automated Review
Git and Gerrit Workflows Enforcing Manual & Automated Review Agenda Branching and Workflow Review A Look at Gerrit The Gerrit Workflow Other Workflows Customizing Gerrit Workflow Branching and Workflow
More informationAn introduction to git
An introduction to git Olivier Berger olivier.berger@telecom-sudparis.eu 2012-12-06 Adapted from "git concepts simplified" by Sitaram Chamarty, sitaramc@gmail.com http://sitaramc.github.com/gcs/ 1 / 52
More informationKernel maintainership: an oral tradition
Embedded Linux Conference Europe 2015 Kernel maintainership: an oral tradition Gregory CLEMENT Bootlin gregory.clement@bootlin.com (Image credit: Andrew Cheal under license CC BY-ND 2.0) - Kernel, drivers
More informationGit Introduction CS 400. February 11, 2018
Git Introduction CS 400 February 11, 2018 1 Introduction Git is one of the most popular version control system. It is a mature, actively maintained open source project originally developed in 2005 by Linus
More informationGit Workbook. Self-Study Guide to Git. Lorna Mitchell. This book is for sale at
Git Workbook Self-Study Guide to Git Lorna Mitchell This book is for sale at http://leanpub.com/gitworkbook This version was published on 2018-01-15 This is a Leanpub book. Leanpub empowers authors and
More informationGETTING STARTED WITH. Michael Lessard Senior Solutions Architect June 2017
GETTING STARTED WITH Michael Lessard Senior Solutions Architect June 2017 Agenda What is Git? Installation of Git Git basis Github First steps with Git 2 WHAT IS GIT? What is Git? Started in 2005 Created
More informationA Plumber s Guide to Git Alex
A Plumber s Guide to Git Alex Chan @alexwlchan Image: Model of the Optimus water closet. Science Museum, Wellcome Images. #1 The Git object database 1. Create a new folder, and initialise Git. 2. Look
More informationLecture 6 Remotes. Sign in on the attendance sheet!
Lecture 6 Remotes Sign in on the attendance sheet! Midterm Review Everyone did great! What We ve Learned So Far Creating and cloning repositories git init, git clone Linear commit histories and diffs git
More informationE, F. deleteall command, 352 directory structure, 350 export_data method, 353 inline_data method, 353 print_export method, 351 target directory, 351
Index A Access control list (ACL), 299 Ancestry references, 184 Attributes, 288 binary files, 289 export-ignore, 294 export-subst, 294 keyword expansion, 291 merge strategies, 294 Authorized_keys file,
More informationI m an egotistical bastard, and I name all my projects after myself. First Linux, now git. Linus Torvalds, creator of Linux and Git
I m an egotistical bastard, and I name all my projects after myself. First Linux, now git. Linus Torvalds, creator of Linux and Git Git Benedict R. Gaster University of West of England November 23, 2015
More information2 Initialize a git repository on your machine, add a README file, commit and push
BioHPC Git Training Demo Script First, ensure that git is installed on your machine, and you have configured an ssh key. See the main slides for instructions. To follow this demo script open a terminal
More informationGit Like You Mean it. Alan Ott SCaLE 16x March 8-11, 2018
Git Like You Mean it Alan Ott SCaLE 16x March 8-11, 2018 About the Presenter Platform Software at SoftIron Data center appliances (storage, transcoding) Ceph-based storage appliances OverDrive 3000/1000
More informationF17 Modern Version Control with Git. Aaron Perley https://www.andrew.cmu.edu/course/98-174/
98-174 F17 Modern Version Control with Git Aaron Perley (aperley@andrew.cmu.edu) https://www.andrew.cmu.edu/course/98-174/ Why should you take this course? Version control software is an essential part
More informationIntroduction to distributed version control with git
Institut für theoretische Physik TU Clausthal 04.03.2013 Inhalt 1 Basics Differences to Subversion Translation of commands 2 Config Create and clone States and workflow Remote repos Branching and merging
More informationGit and GitHub. Dan Wysocki. February 12, Dan Wysocki Git and GitHub February 12, / 48
Git and GitHub Dan Wysocki February 12, 2015 Dan Wysocki Git and GitHub February 12, 2015 1 / 48 1 Version Control 2 Git 3 GitHub 4 Walkthrough Dan Wysocki Git and GitHub February 12, 2015 2 / 48 Version
More informationVersion control with Git.
1 Version control with Git http://git-scm.com/book/en/ Basic Intro to Git We will: Discuss how Git differs from Subversion Discuss the basic Git model Pull/clone files from a repository on github Edit
More informationLaboratorio di Programmazione. Prof. Marco Bertini
Laboratorio di Programmazione Prof. Marco Bertini marco.bertini@unifi.it http://www.micc.unifi.it/bertini/ Code versioning: techniques and tools Software versions All software has multiple versions: Each
More informationGit. Presenter: Haotao (Eric) Lai Contact:
Git Presenter: Haotao (Eric) Lai Contact: haotao.lai@gmail.com 1 Acknowledge images with white background is from the following link: http://marklodato.github.io/visual-git-guide/index-en.html images with
More informationGit: (Distributed) Version Control
Git: (Distributed) Version Control Computer Science and Engineering College of Engineering The Ohio State University Lecture 6 The Need for Version Control Track evolution of a software artifact Development
More informationEECS 470 Lab 4. Version Control System. Friday, 31 st January, 2014
EECS 470 Lab 4 Version Control System Department of Electrical Engineering and Computer Science College of Engineering University of Michigan Friday, 31 st January, 2014 (University of Michigan) Lab 4:
More informationCS 520: VCS and Git. Intermediate Topics Ben Kushigian
CS 520: VCS and Git Intermediate Topics Ben Kushigian https://people.cs.umass.edu/~rjust/courses/2017fall/cs520/2017_09_19.zip Our Goal Our Goal (Overture) Overview the basics of Git w/ an eye towards
More informationVersion Control System - Git. zswu
Version Control System - Git zswu Overview Why VCS? Why Git? Using Git Personally Using Git with Others Etiquette Rules of Using Git Tools & Services Tips 2 Why VCS (1/3) How do you manage your homework?
More informationGit, The Developers Perspec ve
Git, The Developers Perspec ve What is Git? A command line tool wri en by Linus Torvalds for Linux Kernel collabora on to replace a proprietary Distributed Version Control System called Bit Keeper Originally
More informationIngegneria del Software Corso di Laurea in Informatica per il Management (D)VCS. Davide Rossi Dipartimento di Informatica Università di Bologna
Ingegneria del Software Corso di Laurea in Informatica per il Management (D)VCS Davide Rossi Dipartimento di Informatica Università di Bologna Rationale for version control Control the revisions of artifacts
More informationGit: (Distributed) Version Control
Git: (Distributed) Version Control Computer Science and Engineering College of Engineering The Ohio State University Lecture 2 The Need for Version Control Track evolution of a software artifact Development
More informationConfiguring Git. Matthieu Moy. configuring-git-slides.
Configuring Git Matthieu Moy Matthieu.Moy@imag.fr http://www-verimag.imag.fr/~moy/cours/formation-git/ configuring-git-slides.pdf 2015 Matthieu Moy (Matthieu.Moy@imag.fr) Configuring Git 2015 < 1 / 14
More informationA L A TEX-oriented intro to Git
A L A TEX-oriented intro to Git the tex part is in the interactive demo not in the slides Danielle Amethyst Brake 22 October - 26 November, 2018 ICERM Semester on Nonlinear Algebra Inter-week collaboration
More informationGit: Distributed Version Control
Git: Distributed Version Control Computer Science and Engineering College of Engineering The Ohio State University Lecture 3 Demo Prep: Empty (but initialized) repo Linear development: Create, edit, rename,
More informationIntroduction to Version Control
Research Institute for Symbolic Computation Johannes Kepler University Linz, Austria 21-Nov-2013 Outline General Remarks about Version Control 1 General Remarks about Version Control 2 Outline General
More informationPush up your code next generation version control with (E)Git
Push up your code next generation version control with (E)Git Dominik Schadow Senior Consultant Application Development dominik.schadow@trivadis.com Java Forum Stuttgart, 07.07.2011 Basel Bern Lausanne
More informationContribute To Linux Mainline
Contribute To Linux Mainline Wu Zhangjin / Falcon wuzhangjin@gmail.com Tiny Lab 泰晓实验室 http://tinylab.org June 3, 2013 Outline 1 About Linux Kernel Development 2 Upstream your source code 3 Reference 4
More informationUsing Git to Manage Source RTL
Using Git to Manage Source RTL CS250 Tutorial 1 (Version 082311) August 24, 2011 Brian Zimmer How to use this tutorial This class will be using Git for all of the labs and projects. This will allow the
More informationKTH Royal Institute of Technology SEMINAR 2-29 March Simone Stefani -
KTH Royal Institute of Technology SEMINAR 2-29 March 2017 Simone Stefani - sstefani@kth.se WHAT IS THIS SEMINAR ABOUT Branching Merging and rebasing Git team workflows Pull requests and forks WHAT IS THIS
More informationgit-flow Documentation
git-flow Documentation Release 1.0 Johan Cwiklinski Jul 14, 2017 Contents 1 Presentation 3 1.1 Conventions............................................... 4 1.2 Pre-requisites...............................................
More informationAdvanced Operating Systems Control Versioning with GIT. Giuseppe Massari
Control Versioning with GIT Giuseppe Massari giuseppe.massari@polimi.it Outline 2/54 Why using version control tools? Why Git? First steps Getting help and configuration Basic concepts Local repository
More informationGit version control with Eclipse (EGit) Tutorial
Git version control with Eclipse (EGit) Tutorial 출처 : Lars Vogel http://www.vogella.com/tutorials/eclipsegit/article.html Lars Vogel Version 3.6 Copyright 2009, 2010, 2011, 2012, 2013, 2014 Lars Vogel
More informationGitHub for Developers Training Manual. -v1.0
GitHub for Developers Training Manual -v1.0 Table of Contents Welcome to GitHub for Developers................................. 1 License...................................................... 1 Getting
More informationLicense. Introduction to Version Control with Git. Local Version Control Systems. Why Use Version Control?
License Introduction to Version Control with Git Andreas Skielboe 1 Adapted by Dr. Andrew Vardy 2 All images adapted from Pro Git by Scott Chacon and released under license Creative Commons BY-NC-SA 3.0.
More informationGit Resolve Conflict Using Mine Command Line
Git Resolve Conflict Using Mine Command Line We'll explore what approaches there are to resolve the conflict, and then we'll Please, fix them up in the work tree, and then use 'git add/rm ' as appropriate
More informationCS 390 Software Engineering Lecture 5 More Git
CS 390 Software Engineering Lecture 5 More Git Reference: Scott Chacon and Ben Straub, Pro Git, published by Apress, available at https://git-scm.com/book/en/v2. Outline Finish local repository Remote
More informationVersion Control for the 2- Pizza Team: Merge Conflicts (ELLS 9.5) Armando Fox
Version Control for the 2- Pizza Team: Merge Conflicts (ELLS 9.5) Armando Fox 2012 Armando Fox & David Patterson Licensed under Creative Commons Attribution- NonCommercial-ShareAlike 3.0 Unported License
More informationSoftware Development I
6.148 Software Development I Two things How to write code for web apps. How to collaborate and keep track of your work. A text editor A text editor A text editor Anything that you re used to using Even
More informationINET
INET Framework@GitHub Proposal: How to Collaborate on Model Development Andras Varga, Rudolf Hornig INET: Current Stand Several branches in private repositories i Several extensions various web sites Patches,
More informationIntro Technical details Using vcsh Outlook Outro. vcsh. manage config files in $HOME via fake bare git repositories
Intro Technical details Using Outlook Outro manage config files in $HOME via fake bare git repositories Richard Hartmann, RichiH@{freenode,OFTC,IRCnet}, richih.mailinglist@gmail.com 2012-02-04 Intro Technical
More informationGit: Distributed Version Control
Git: Distributed Version Control Computer Science and Engineering College of Engineering The Ohio State University Lecture 3 What Does "D" Stand For? Distributed version control Multiple people, distributed
More informationPractical C Programming
Practical C Programming Advanced Preprocessor # - quotes a string ## - concatenates things #pragma h3p://gcc.gnu.org/onlinedocs/cpp/pragmas.html #warn #error Defined Constants Macro FILE LINE DATE TIME
More informationCS 390 Software Engineering Lecture 4 - Git
CS 390 Software Engineering Lecture 4 - Git Reference: Scott Chacon and Ben Straub, Pro Git, published by Apress, available at https://git-scm.com/book/en/v2. Outline Git terminology Git configuration
More informationCreating a Patch. Created by Carl Heymann on 2010 Sep 14 1
Created by on 2010 Sep 14 1 1. Starting a Patch To create a patch, and get it through the review process and into a main branch of a project, you can follow the following steps: Clone the project if you
More information