| <!DOCTYPE html> | 
 | <html xmlns="http://www.w3.org/1999/xhtml" lang="en"> | 
 | <head> | 
 | <meta charset="UTF-8"/> | 
 | <meta http-equiv="X-UA-Compatible" content="IE=edge"/> | 
 | <meta name="viewport" content="width=device-width, initial-scale=1.0"/> | 
 | <meta name="generator" content="Asciidoctor 2.0.23"/> | 
 | <title>gitcore-tutorial(7)</title> | 
 | <link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Open+Sans:300,300italic,400,400italic,600,600italic%7CNoto+Serif:400,400italic,700,700italic%7CDroid+Sans+Mono:400,700"/> | 
 | <style> | 
 | /*! Asciidoctor default stylesheet | MIT License | https://asciidoctor.org */ | 
 | /* Uncomment the following line when using as a custom stylesheet */ | 
 | /* @import "https://fonts.googleapis.com/css?family=Open+Sans:300,300italic,400,400italic,600,600italic%7CNoto+Serif:400,400italic,700,700italic%7CDroid+Sans+Mono:400,700"; */ | 
 | html{font-family:sans-serif;-webkit-text-size-adjust:100%} | 
 | a{background:none} | 
 | a:focus{outline:thin dotted} | 
 | a:active,a:hover{outline:0} | 
 | h1{font-size:2em;margin:.67em 0} | 
 | b,strong{font-weight:bold} | 
 | abbr{font-size:.9em} | 
 | abbr[title]{cursor:help;border-bottom:1px dotted #dddddf;text-decoration:none} | 
 | dfn{font-style:italic} | 
 | hr{height:0} | 
 | mark{background:#ff0;color:#000} | 
 | code,kbd,pre,samp{font-family:monospace;font-size:1em} | 
 | pre{white-space:pre-wrap} | 
 | q{quotes:"\201C" "\201D" "\2018" "\2019"} | 
 | small{font-size:80%} | 
 | sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline} | 
 | sup{top:-.5em} | 
 | sub{bottom:-.25em} | 
 | img{border:0} | 
 | svg:not(:root){overflow:hidden} | 
 | figure{margin:0} | 
 | audio,video{display:inline-block} | 
 | audio:not([controls]){display:none;height:0} | 
 | fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em} | 
 | legend{border:0;padding:0} | 
 | button,input,select,textarea{font-family:inherit;font-size:100%;margin:0} | 
 | button,input{line-height:normal} | 
 | button,select{text-transform:none} | 
 | button,html input[type=button],input[type=reset],input[type=submit]{-webkit-appearance:button;cursor:pointer} | 
 | button[disabled],html input[disabled]{cursor:default} | 
 | input[type=checkbox],input[type=radio]{padding:0} | 
 | button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0} | 
 | textarea{overflow:auto;vertical-align:top} | 
 | table{border-collapse:collapse;border-spacing:0} | 
 | *,::before,::after{box-sizing:border-box} | 
 | html,body{font-size:100%} | 
 | body{background:#fff;color:rgba(0,0,0,.8);padding:0;margin:0;font-family:"Noto Serif","DejaVu Serif",serif;line-height:1;position:relative;cursor:auto;-moz-tab-size:4;-o-tab-size:4;tab-size:4;word-wrap:anywhere;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased} | 
 | a:hover{cursor:pointer} | 
 | img,object,embed{max-width:100%;height:auto} | 
 | object,embed{height:100%} | 
 | img{-ms-interpolation-mode:bicubic} | 
 | .left{float:left!important} | 
 | .right{float:right!important} | 
 | .text-left{text-align:left!important} | 
 | .text-right{text-align:right!important} | 
 | .text-center{text-align:center!important} | 
 | .text-justify{text-align:justify!important} | 
 | .hide{display:none} | 
 | img,object,svg{display:inline-block;vertical-align:middle} | 
 | textarea{height:auto;min-height:50px} | 
 | select{width:100%} | 
 | .subheader,.admonitionblock td.content>.title,.audioblock>.title,.exampleblock>.title,.imageblock>.title,.listingblock>.title,.literalblock>.title,.stemblock>.title,.openblock>.title,.paragraph>.title,.quoteblock>.title,table.tableblock>.title,.verseblock>.title,.videoblock>.title,.dlist>.title,.olist>.title,.ulist>.title,.qlist>.title,.hdlist>.title{line-height:1.45;color:#7a2518;font-weight:400;margin-top:0;margin-bottom:.25em} | 
 | div,dl,dt,dd,ul,ol,li,h1,h2,h3,#toctitle,.sidebarblock>.content>.title,h4,h5,h6,pre,form,p,blockquote,th,td{margin:0;padding:0} | 
 | a{color:#2156a5;text-decoration:underline;line-height:inherit} | 
 | a:hover,a:focus{color:#1d4b8f} | 
 | a img{border:0} | 
 | p{line-height:1.6;margin-bottom:1.25em;text-rendering:optimizeLegibility} | 
 | p aside{font-size:.875em;line-height:1.35;font-style:italic} | 
 | h1,h2,h3,#toctitle,.sidebarblock>.content>.title,h4,h5,h6{font-family:"Open Sans","DejaVu Sans",sans-serif;font-weight:300;font-style:normal;color:#ba3925;text-rendering:optimizeLegibility;margin-top:1em;margin-bottom:.5em;line-height:1.0125em} | 
 | h1 small,h2 small,h3 small,#toctitle small,.sidebarblock>.content>.title small,h4 small,h5 small,h6 small{font-size:60%;color:#e99b8f;line-height:0} | 
 | h1{font-size:2.125em} | 
 | h2{font-size:1.6875em} | 
 | h3,#toctitle,.sidebarblock>.content>.title{font-size:1.375em} | 
 | h4,h5{font-size:1.125em} | 
 | h6{font-size:1em} | 
 | hr{border:solid #dddddf;border-width:1px 0 0;clear:both;margin:1.25em 0 1.1875em} | 
 | em,i{font-style:italic;line-height:inherit} | 
 | strong,b{font-weight:bold;line-height:inherit} | 
 | small{font-size:60%;line-height:inherit} | 
 | code{font-family:"Droid Sans Mono","DejaVu Sans Mono",monospace;font-weight:400;color:rgba(0,0,0,.9)} | 
 | ul,ol,dl{line-height:1.6;margin-bottom:1.25em;list-style-position:outside;font-family:inherit} | 
 | ul,ol{margin-left:1.5em} | 
 | ul li ul,ul li ol{margin-left:1.25em;margin-bottom:0} | 
 | ul.circle{list-style-type:circle} | 
 | ul.disc{list-style-type:disc} | 
 | ul.square{list-style-type:square} | 
 | ul.circle ul:not([class]),ul.disc ul:not([class]),ul.square ul:not([class]){list-style:inherit} | 
 | ol li ul,ol li ol{margin-left:1.25em;margin-bottom:0} | 
 | dl dt{margin-bottom:.3125em;font-weight:bold} | 
 | dl dd{margin-bottom:1.25em} | 
 | blockquote{margin:0 0 1.25em;padding:.5625em 1.25em 0 1.1875em;border-left:1px solid #ddd} | 
 | blockquote,blockquote p{line-height:1.6;color:rgba(0,0,0,.85)} | 
 | @media screen and (min-width:768px){h1,h2,h3,#toctitle,.sidebarblock>.content>.title,h4,h5,h6{line-height:1.2} | 
 | h1{font-size:2.75em} | 
 | h2{font-size:2.3125em} | 
 | h3,#toctitle,.sidebarblock>.content>.title{font-size:1.6875em} | 
 | h4{font-size:1.4375em}} | 
 | table{background:#fff;margin-bottom:1.25em;border:1px solid #dedede;word-wrap:normal} | 
 | table thead,table tfoot{background:#f7f8f7} | 
 | table thead tr th,table thead tr td,table tfoot tr th,table tfoot tr td{padding:.5em .625em .625em;font-size:inherit;color:rgba(0,0,0,.8);text-align:left} | 
 | table tr th,table tr td{padding:.5625em .625em;font-size:inherit;color:rgba(0,0,0,.8)} | 
 | table tr.even,table tr.alt{background:#f8f8f7} | 
 | table thead tr th,table tfoot tr th,table tbody tr td,table tr td,table tfoot tr td{line-height:1.6} | 
 | h1,h2,h3,#toctitle,.sidebarblock>.content>.title,h4,h5,h6{line-height:1.2;word-spacing:-.05em} | 
 | h1 strong,h2 strong,h3 strong,#toctitle strong,.sidebarblock>.content>.title strong,h4 strong,h5 strong,h6 strong{font-weight:400} | 
 | .center{margin-left:auto;margin-right:auto} | 
 | .stretch{width:100%} | 
 | .clearfix::before,.clearfix::after,.float-group::before,.float-group::after{content:" ";display:table} | 
 | .clearfix::after,.float-group::after{clear:both} | 
 | :not(pre).nobreak{word-wrap:normal} | 
 | :not(pre).nowrap{white-space:nowrap} | 
 | :not(pre).pre-wrap{white-space:pre-wrap} | 
 | :not(pre):not([class^=L])>code{font-size:.9375em;font-style:normal!important;letter-spacing:0;padding:.1em .5ex;word-spacing:-.15em;background:#f7f7f8;border-radius:4px;line-height:1.45;text-rendering:optimizeSpeed} | 
 | pre{color:rgba(0,0,0,.9);font-family:"Droid Sans Mono","DejaVu Sans Mono",monospace;line-height:1.45;text-rendering:optimizeSpeed} | 
 | pre code,pre pre{color:inherit;font-size:inherit;line-height:inherit} | 
 | pre>code{display:block} | 
 | pre.nowrap,pre.nowrap pre{white-space:pre;word-wrap:normal} | 
 | em em{font-style:normal} | 
 | strong strong{font-weight:400} | 
 | .keyseq{color:rgba(51,51,51,.8)} | 
 | kbd{font-family:"Droid Sans Mono","DejaVu Sans Mono",monospace;display:inline-block;color:rgba(0,0,0,.8);font-size:.65em;line-height:1.45;background:#f7f7f7;border:1px solid #ccc;border-radius:3px;box-shadow:0 1px 0 rgba(0,0,0,.2),inset 0 0 0 .1em #fff;margin:0 .15em;padding:.2em .5em;vertical-align:middle;position:relative;top:-.1em;white-space:nowrap} | 
 | .keyseq kbd:first-child{margin-left:0} | 
 | .keyseq kbd:last-child{margin-right:0} | 
 | .menuseq,.menuref{color:#000} | 
 | .menuseq b:not(.caret),.menuref{font-weight:inherit} | 
 | .menuseq{word-spacing:-.02em} | 
 | .menuseq b.caret{font-size:1.25em;line-height:.8} | 
 | .menuseq i.caret{font-weight:bold;text-align:center;width:.45em} | 
 | b.button::before,b.button::after{position:relative;top:-1px;font-weight:400} | 
 | b.button::before{content:"[";padding:0 3px 0 2px} | 
 | b.button::after{content:"]";padding:0 2px 0 3px} | 
 | p a>code:hover{color:rgba(0,0,0,.9)} | 
 | #header,#content,#footnotes,#footer{width:100%;margin:0 auto;max-width:62.5em;*zoom:1;position:relative;padding-left:.9375em;padding-right:.9375em} | 
 | #header::before,#header::after,#content::before,#content::after,#footnotes::before,#footnotes::after,#footer::before,#footer::after{content:" ";display:table} | 
 | #header::after,#content::after,#footnotes::after,#footer::after{clear:both} | 
 | #content{margin-top:1.25em} | 
 | #content::before{content:none} | 
 | #header>h1:first-child{color:rgba(0,0,0,.85);margin-top:2.25rem;margin-bottom:0} | 
 | #header>h1:first-child+#toc{margin-top:8px;border-top:1px solid #dddddf} | 
 | #header>h1:only-child{border-bottom:1px solid #dddddf;padding-bottom:8px} | 
 | #header .details{border-bottom:1px solid #dddddf;line-height:1.45;padding-top:.25em;padding-bottom:.25em;padding-left:.25em;color:rgba(0,0,0,.6);display:flex;flex-flow:row wrap} | 
 | #header .details span:first-child{margin-left:-.125em} | 
 | #header .details span.email a{color:rgba(0,0,0,.85)} | 
 | #header .details br{display:none} | 
 | #header .details br+span::before{content:"\00a0\2013\00a0"} | 
 | #header .details br+span.author::before{content:"\00a0\22c5\00a0";color:rgba(0,0,0,.85)} | 
 | #header .details br+span#revremark::before{content:"\00a0|\00a0"} | 
 | #header #revnumber{text-transform:capitalize} | 
 | #header #revnumber::after{content:"\00a0"} | 
 | #content>h1:first-child:not([class]){color:rgba(0,0,0,.85);border-bottom:1px solid #dddddf;padding-bottom:8px;margin-top:0;padding-top:1rem;margin-bottom:1.25rem} | 
 | #toc{border-bottom:1px solid #e7e7e9;padding-bottom:.5em} | 
 | #toc>ul{margin-left:.125em} | 
 | #toc ul.sectlevel0>li>a{font-style:italic} | 
 | #toc ul.sectlevel0 ul.sectlevel1{margin:.5em 0} | 
 | #toc ul{font-family:"Open Sans","DejaVu Sans",sans-serif;list-style-type:none} | 
 | #toc li{line-height:1.3334;margin-top:.3334em} | 
 | #toc a{text-decoration:none} | 
 | #toc a:active{text-decoration:underline} | 
 | #toctitle{color:#7a2518;font-size:1.2em} | 
 | @media screen and (min-width:768px){#toctitle{font-size:1.375em} | 
 | body.toc2{padding-left:15em;padding-right:0} | 
 | body.toc2 #header>h1:nth-last-child(2){border-bottom:1px solid #dddddf;padding-bottom:8px} | 
 | #toc.toc2{margin-top:0!important;background:#f8f8f7;position:fixed;width:15em;left:0;top:0;border-right:1px solid #e7e7e9;border-top-width:0!important;border-bottom-width:0!important;z-index:1000;padding:1.25em 1em;height:100%;overflow:auto} | 
 | #toc.toc2 #toctitle{margin-top:0;margin-bottom:.8rem;font-size:1.2em} | 
 | #toc.toc2>ul{font-size:.9em;margin-bottom:0} | 
 | #toc.toc2 ul ul{margin-left:0;padding-left:1em} | 
 | #toc.toc2 ul.sectlevel0 ul.sectlevel1{padding-left:0;margin-top:.5em;margin-bottom:.5em} | 
 | body.toc2.toc-right{padding-left:0;padding-right:15em} | 
 | body.toc2.toc-right #toc.toc2{border-right-width:0;border-left:1px solid #e7e7e9;left:auto;right:0}} | 
 | @media screen and (min-width:1280px){body.toc2{padding-left:20em;padding-right:0} | 
 | #toc.toc2{width:20em} | 
 | #toc.toc2 #toctitle{font-size:1.375em} | 
 | #toc.toc2>ul{font-size:.95em} | 
 | #toc.toc2 ul ul{padding-left:1.25em} | 
 | body.toc2.toc-right{padding-left:0;padding-right:20em}} | 
 | #content #toc{border:1px solid #e0e0dc;margin-bottom:1.25em;padding:1.25em;background:#f8f8f7;border-radius:4px} | 
 | #content #toc>:first-child{margin-top:0} | 
 | #content #toc>:last-child{margin-bottom:0} | 
 | #footer{max-width:none;background:rgba(0,0,0,.8);padding:1.25em} | 
 | #footer-text{color:hsla(0,0%,100%,.8);line-height:1.44} | 
 | #content{margin-bottom:.625em} | 
 | .sect1{padding-bottom:.625em} | 
 | @media screen and (min-width:768px){#content{margin-bottom:1.25em} | 
 | .sect1{padding-bottom:1.25em}} | 
 | .sect1:last-child{padding-bottom:0} | 
 | .sect1+.sect1{border-top:1px solid #e7e7e9} | 
 | #content h1>a.anchor,h2>a.anchor,h3>a.anchor,#toctitle>a.anchor,.sidebarblock>.content>.title>a.anchor,h4>a.anchor,h5>a.anchor,h6>a.anchor{position:absolute;z-index:1001;width:1.5ex;margin-left:-1.5ex;display:block;text-decoration:none!important;visibility:hidden;text-align:center;font-weight:400} | 
 | #content h1>a.anchor::before,h2>a.anchor::before,h3>a.anchor::before,#toctitle>a.anchor::before,.sidebarblock>.content>.title>a.anchor::before,h4>a.anchor::before,h5>a.anchor::before,h6>a.anchor::before{content:"\00A7";font-size:.85em;display:block;padding-top:.1em} | 
 | #content h1:hover>a.anchor,#content h1>a.anchor:hover,h2:hover>a.anchor,h2>a.anchor:hover,h3:hover>a.anchor,#toctitle:hover>a.anchor,.sidebarblock>.content>.title:hover>a.anchor,h3>a.anchor:hover,#toctitle>a.anchor:hover,.sidebarblock>.content>.title>a.anchor:hover,h4:hover>a.anchor,h4>a.anchor:hover,h5:hover>a.anchor,h5>a.anchor:hover,h6:hover>a.anchor,h6>a.anchor:hover{visibility:visible} | 
 | #content h1>a.link,h2>a.link,h3>a.link,#toctitle>a.link,.sidebarblock>.content>.title>a.link,h4>a.link,h5>a.link,h6>a.link{color:#ba3925;text-decoration:none} | 
 | #content h1>a.link:hover,h2>a.link:hover,h3>a.link:hover,#toctitle>a.link:hover,.sidebarblock>.content>.title>a.link:hover,h4>a.link:hover,h5>a.link:hover,h6>a.link:hover{color:#a53221} | 
 | details,.audioblock,.imageblock,.literalblock,.listingblock,.stemblock,.videoblock{margin-bottom:1.25em} | 
 | details{margin-left:1.25rem} | 
 | details>summary{cursor:pointer;display:block;position:relative;line-height:1.6;margin-bottom:.625rem;outline:none;-webkit-tap-highlight-color:transparent} | 
 | details>summary::-webkit-details-marker{display:none} | 
 | details>summary::before{content:"";border:solid transparent;border-left:solid;border-width:.3em 0 .3em .5em;position:absolute;top:.5em;left:-1.25rem;transform:translateX(15%)} | 
 | details[open]>summary::before{border:solid transparent;border-top:solid;border-width:.5em .3em 0;transform:translateY(15%)} | 
 | details>summary::after{content:"";width:1.25rem;height:1em;position:absolute;top:.3em;left:-1.25rem} | 
 | .admonitionblock td.content>.title,.audioblock>.title,.exampleblock>.title,.imageblock>.title,.listingblock>.title,.literalblock>.title,.stemblock>.title,.openblock>.title,.paragraph>.title,.quoteblock>.title,table.tableblock>.title,.verseblock>.title,.videoblock>.title,.dlist>.title,.olist>.title,.ulist>.title,.qlist>.title,.hdlist>.title{text-rendering:optimizeLegibility;text-align:left;font-family:"Noto Serif","DejaVu Serif",serif;font-size:1rem;font-style:italic} | 
 | table.tableblock.fit-content>caption.title{white-space:nowrap;width:0} | 
 | .paragraph.lead>p,#preamble>.sectionbody>[class=paragraph]:first-of-type p{font-size:1.21875em;line-height:1.6;color:rgba(0,0,0,.85)} | 
 | .admonitionblock>table{border-collapse:separate;border:0;background:none;width:100%} | 
 | .admonitionblock>table td.icon{text-align:center;width:80px} | 
 | .admonitionblock>table td.icon img{max-width:none} | 
 | .admonitionblock>table td.icon .title{font-weight:bold;font-family:"Open Sans","DejaVu Sans",sans-serif;text-transform:uppercase} | 
 | .admonitionblock>table td.content{padding-left:1.125em;padding-right:1.25em;border-left:1px solid #dddddf;color:rgba(0,0,0,.6);word-wrap:anywhere} | 
 | .admonitionblock>table td.content>:last-child>:last-child{margin-bottom:0} | 
 | .exampleblock>.content{border:1px solid #e6e6e6;margin-bottom:1.25em;padding:1.25em;background:#fff;border-radius:4px} | 
 | .sidebarblock{border:1px solid #dbdbd6;margin-bottom:1.25em;padding:1.25em;background:#f3f3f2;border-radius:4px} | 
 | .sidebarblock>.content>.title{color:#7a2518;margin-top:0;text-align:center} | 
 | .exampleblock>.content>:first-child,.sidebarblock>.content>:first-child{margin-top:0} | 
 | .exampleblock>.content>:last-child,.exampleblock>.content>:last-child>:last-child,.exampleblock>.content .olist>ol>li:last-child>:last-child,.exampleblock>.content .ulist>ul>li:last-child>:last-child,.exampleblock>.content .qlist>ol>li:last-child>:last-child,.sidebarblock>.content>:last-child,.sidebarblock>.content>:last-child>:last-child,.sidebarblock>.content .olist>ol>li:last-child>:last-child,.sidebarblock>.content .ulist>ul>li:last-child>:last-child,.sidebarblock>.content .qlist>ol>li:last-child>:last-child{margin-bottom:0} | 
 | .literalblock pre,.listingblock>.content>pre{border-radius:4px;overflow-x:auto;padding:1em;font-size:.8125em} | 
 | @media screen and (min-width:768px){.literalblock pre,.listingblock>.content>pre{font-size:.90625em}} | 
 | @media screen and (min-width:1280px){.literalblock pre,.listingblock>.content>pre{font-size:1em}} | 
 | .literalblock pre,.listingblock>.content>pre:not(.highlight),.listingblock>.content>pre[class=highlight],.listingblock>.content>pre[class^="highlight "]{background:#f7f7f8} | 
 | .literalblock.output pre{color:#f7f7f8;background:rgba(0,0,0,.9)} | 
 | .listingblock>.content{position:relative} | 
 | .listingblock code[data-lang]::before{display:none;content:attr(data-lang);position:absolute;font-size:.75em;top:.425rem;right:.5rem;line-height:1;text-transform:uppercase;color:inherit;opacity:.5} | 
 | .listingblock:hover code[data-lang]::before{display:block} | 
 | .listingblock.terminal pre .command::before{content:attr(data-prompt);padding-right:.5em;color:inherit;opacity:.5} | 
 | .listingblock.terminal pre .command:not([data-prompt])::before{content:"$"} | 
 | .listingblock pre.highlightjs{padding:0} | 
 | .listingblock pre.highlightjs>code{padding:1em;border-radius:4px} | 
 | .listingblock pre.prettyprint{border-width:0} | 
 | .prettyprint{background:#f7f7f8} | 
 | pre.prettyprint .linenums{line-height:1.45;margin-left:2em} | 
 | pre.prettyprint li{background:none;list-style-type:inherit;padding-left:0} | 
 | pre.prettyprint li code[data-lang]::before{opacity:1} | 
 | pre.prettyprint li:not(:first-child) code[data-lang]::before{display:none} | 
 | table.linenotable{border-collapse:separate;border:0;margin-bottom:0;background:none} | 
 | table.linenotable td[class]{color:inherit;vertical-align:top;padding:0;line-height:inherit;white-space:normal} | 
 | table.linenotable td.code{padding-left:.75em} | 
 | table.linenotable td.linenos,pre.pygments .linenos{border-right:1px solid;opacity:.35;padding-right:.5em;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none} | 
 | pre.pygments span.linenos{display:inline-block;margin-right:.75em} | 
 | .quoteblock{margin:0 1em 1.25em 1.5em;display:table} | 
 | .quoteblock:not(.excerpt)>.title{margin-left:-1.5em;margin-bottom:.75em} | 
 | .quoteblock blockquote,.quoteblock p{color:rgba(0,0,0,.85);font-size:1.15rem;line-height:1.75;word-spacing:.1em;letter-spacing:0;font-style:italic;text-align:justify} | 
 | .quoteblock blockquote{margin:0;padding:0;border:0} | 
 | .quoteblock blockquote::before{content:"\201c";float:left;font-size:2.75em;font-weight:bold;line-height:.6em;margin-left:-.6em;color:#7a2518;text-shadow:0 1px 2px rgba(0,0,0,.1)} | 
 | .quoteblock blockquote>.paragraph:last-child p{margin-bottom:0} | 
 | .quoteblock .attribution{margin-top:.75em;margin-right:.5ex;text-align:right} | 
 | .verseblock{margin:0 1em 1.25em} | 
 | .verseblock pre{font-family:"Open Sans","DejaVu Sans",sans-serif;font-size:1.15rem;color:rgba(0,0,0,.85);font-weight:300;text-rendering:optimizeLegibility} | 
 | .verseblock pre strong{font-weight:400} | 
 | .verseblock .attribution{margin-top:1.25rem;margin-left:.5ex} | 
 | .quoteblock .attribution,.verseblock .attribution{font-size:.9375em;line-height:1.45;font-style:italic} | 
 | .quoteblock .attribution br,.verseblock .attribution br{display:none} | 
 | .quoteblock .attribution cite,.verseblock .attribution cite{display:block;letter-spacing:-.025em;color:rgba(0,0,0,.6)} | 
 | .quoteblock.abstract blockquote::before,.quoteblock.excerpt blockquote::before,.quoteblock .quoteblock blockquote::before{display:none} | 
 | .quoteblock.abstract blockquote,.quoteblock.abstract p,.quoteblock.excerpt blockquote,.quoteblock.excerpt p,.quoteblock .quoteblock blockquote,.quoteblock .quoteblock p{line-height:1.6;word-spacing:0} | 
 | .quoteblock.abstract{margin:0 1em 1.25em;display:block} | 
 | .quoteblock.abstract>.title{margin:0 0 .375em;font-size:1.15em;text-align:center} | 
 | .quoteblock.excerpt>blockquote,.quoteblock .quoteblock{padding:0 0 .25em 1em;border-left:.25em solid #dddddf} | 
 | .quoteblock.excerpt,.quoteblock .quoteblock{margin-left:0} | 
 | .quoteblock.excerpt blockquote,.quoteblock.excerpt p,.quoteblock .quoteblock blockquote,.quoteblock .quoteblock p{color:inherit;font-size:1.0625rem} | 
 | .quoteblock.excerpt .attribution,.quoteblock .quoteblock .attribution{color:inherit;font-size:.85rem;text-align:left;margin-right:0} | 
 | p.tableblock:last-child{margin-bottom:0} | 
 | td.tableblock>.content{margin-bottom:1.25em;word-wrap:anywhere} | 
 | td.tableblock>.content>:last-child{margin-bottom:-1.25em} | 
 | table.tableblock,th.tableblock,td.tableblock{border:0 solid #dedede} | 
 | table.grid-all>*>tr>*{border-width:1px} | 
 | table.grid-cols>*>tr>*{border-width:0 1px} | 
 | table.grid-rows>*>tr>*{border-width:1px 0} | 
 | table.frame-all{border-width:1px} | 
 | table.frame-ends{border-width:1px 0} | 
 | table.frame-sides{border-width:0 1px} | 
 | table.frame-none>colgroup+*>:first-child>*,table.frame-sides>colgroup+*>:first-child>*{border-top-width:0} | 
 | table.frame-none>:last-child>:last-child>*,table.frame-sides>:last-child>:last-child>*{border-bottom-width:0} | 
 | table.frame-none>*>tr>:first-child,table.frame-ends>*>tr>:first-child{border-left-width:0} | 
 | table.frame-none>*>tr>:last-child,table.frame-ends>*>tr>:last-child{border-right-width:0} | 
 | table.stripes-all>*>tr,table.stripes-odd>*>tr:nth-of-type(odd),table.stripes-even>*>tr:nth-of-type(even),table.stripes-hover>*>tr:hover{background:#f8f8f7} | 
 | th.halign-left,td.halign-left{text-align:left} | 
 | th.halign-right,td.halign-right{text-align:right} | 
 | th.halign-center,td.halign-center{text-align:center} | 
 | th.valign-top,td.valign-top{vertical-align:top} | 
 | th.valign-bottom,td.valign-bottom{vertical-align:bottom} | 
 | th.valign-middle,td.valign-middle{vertical-align:middle} | 
 | table thead th,table tfoot th{font-weight:bold} | 
 | tbody tr th{background:#f7f8f7} | 
 | tbody tr th,tbody tr th p,tfoot tr th,tfoot tr th p{color:rgba(0,0,0,.8);font-weight:bold} | 
 | p.tableblock>code:only-child{background:none;padding:0} | 
 | p.tableblock{font-size:1em} | 
 | ol{margin-left:1.75em} | 
 | ul li ol{margin-left:1.5em} | 
 | dl dd{margin-left:1.125em} | 
 | dl dd:last-child,dl dd:last-child>:last-child{margin-bottom:0} | 
 | li p,ul dd,ol dd,.olist .olist,.ulist .ulist,.ulist .olist,.olist .ulist{margin-bottom:.625em} | 
 | ul.checklist,ul.none,ol.none,ul.no-bullet,ol.no-bullet,ol.unnumbered,ul.unstyled,ol.unstyled{list-style-type:none} | 
 | ul.no-bullet,ol.no-bullet,ol.unnumbered{margin-left:.625em} | 
 | ul.unstyled,ol.unstyled{margin-left:0} | 
 | li>p:empty:only-child::before{content:"";display:inline-block} | 
 | ul.checklist>li>p:first-child{margin-left:-1em} | 
 | ul.checklist>li>p:first-child>.fa-square-o:first-child,ul.checklist>li>p:first-child>.fa-check-square-o:first-child{width:1.25em;font-size:.8em;position:relative;bottom:.125em} | 
 | ul.checklist>li>p:first-child>input[type=checkbox]:first-child{margin-right:.25em} | 
 | ul.inline{display:flex;flex-flow:row wrap;list-style:none;margin:0 0 .625em -1.25em} | 
 | ul.inline>li{margin-left:1.25em} | 
 | .unstyled dl dt{font-weight:400;font-style:normal} | 
 | ol.arabic{list-style-type:decimal} | 
 | ol.decimal{list-style-type:decimal-leading-zero} | 
 | ol.loweralpha{list-style-type:lower-alpha} | 
 | ol.upperalpha{list-style-type:upper-alpha} | 
 | ol.lowerroman{list-style-type:lower-roman} | 
 | ol.upperroman{list-style-type:upper-roman} | 
 | ol.lowergreek{list-style-type:lower-greek} | 
 | .hdlist>table,.colist>table{border:0;background:none} | 
 | .hdlist>table>tbody>tr,.colist>table>tbody>tr{background:none} | 
 | td.hdlist1,td.hdlist2{vertical-align:top;padding:0 .625em} | 
 | td.hdlist1{font-weight:bold;padding-bottom:1.25em} | 
 | td.hdlist2{word-wrap:anywhere} | 
 | .literalblock+.colist,.listingblock+.colist{margin-top:-.5em} | 
 | .colist td:not([class]):first-child{padding:.4em .75em 0;line-height:1;vertical-align:top} | 
 | .colist td:not([class]):first-child img{max-width:none} | 
 | .colist td:not([class]):last-child{padding:.25em 0} | 
 | .thumb,.th{line-height:0;display:inline-block;border:4px solid #fff;box-shadow:0 0 0 1px #ddd} | 
 | .imageblock.left{margin:.25em .625em 1.25em 0} | 
 | .imageblock.right{margin:.25em 0 1.25em .625em} | 
 | .imageblock>.title{margin-bottom:0} | 
 | .imageblock.thumb,.imageblock.th{border-width:6px} | 
 | .imageblock.thumb>.title,.imageblock.th>.title{padding:0 .125em} | 
 | .image.left,.image.right{margin-top:.25em;margin-bottom:.25em;display:inline-block;line-height:0} | 
 | .image.left{margin-right:.625em} | 
 | .image.right{margin-left:.625em} | 
 | a.image{text-decoration:none;display:inline-block} | 
 | a.image object{pointer-events:none} | 
 | sup.footnote,sup.footnoteref{font-size:.875em;position:static;vertical-align:super} | 
 | sup.footnote a,sup.footnoteref a{text-decoration:none} | 
 | sup.footnote a:active,sup.footnoteref a:active,#footnotes .footnote a:first-of-type:active{text-decoration:underline} | 
 | #footnotes{padding-top:.75em;padding-bottom:.75em;margin-bottom:.625em} | 
 | #footnotes hr{width:20%;min-width:6.25em;margin:-.25em 0 .75em;border-width:1px 0 0} | 
 | #footnotes .footnote{padding:0 .375em 0 .225em;line-height:1.3334;font-size:.875em;margin-left:1.2em;margin-bottom:.2em} | 
 | #footnotes .footnote a:first-of-type{font-weight:bold;text-decoration:none;margin-left:-1.05em} | 
 | #footnotes .footnote:last-of-type{margin-bottom:0} | 
 | #content #footnotes{margin-top:-.625em;margin-bottom:0;padding:.75em 0} | 
 | div.unbreakable{page-break-inside:avoid} | 
 | .big{font-size:larger} | 
 | .small{font-size:smaller} | 
 | .underline{text-decoration:underline} | 
 | .overline{text-decoration:overline} | 
 | .line-through{text-decoration:line-through} | 
 | .aqua{color:#00bfbf} | 
 | .aqua-background{background:#00fafa} | 
 | .black{color:#000} | 
 | .black-background{background:#000} | 
 | .blue{color:#0000bf} | 
 | .blue-background{background:#0000fa} | 
 | .fuchsia{color:#bf00bf} | 
 | .fuchsia-background{background:#fa00fa} | 
 | .gray{color:#606060} | 
 | .gray-background{background:#7d7d7d} | 
 | .green{color:#006000} | 
 | .green-background{background:#007d00} | 
 | .lime{color:#00bf00} | 
 | .lime-background{background:#00fa00} | 
 | .maroon{color:#600000} | 
 | .maroon-background{background:#7d0000} | 
 | .navy{color:#000060} | 
 | .navy-background{background:#00007d} | 
 | .olive{color:#606000} | 
 | .olive-background{background:#7d7d00} | 
 | .purple{color:#600060} | 
 | .purple-background{background:#7d007d} | 
 | .red{color:#bf0000} | 
 | .red-background{background:#fa0000} | 
 | .silver{color:#909090} | 
 | .silver-background{background:#bcbcbc} | 
 | .teal{color:#006060} | 
 | .teal-background{background:#007d7d} | 
 | .white{color:#bfbfbf} | 
 | .white-background{background:#fafafa} | 
 | .yellow{color:#bfbf00} | 
 | .yellow-background{background:#fafa00} | 
 | span.icon>.fa{cursor:default} | 
 | a span.icon>.fa{cursor:inherit} | 
 | .admonitionblock td.icon [class^="fa icon-"]{font-size:2.5em;text-shadow:1px 1px 2px rgba(0,0,0,.5);cursor:default} | 
 | .admonitionblock td.icon .icon-note::before{content:"\f05a";color:#19407c} | 
 | .admonitionblock td.icon .icon-tip::before{content:"\f0eb";text-shadow:1px 1px 2px rgba(155,155,0,.8);color:#111} | 
 | .admonitionblock td.icon .icon-warning::before{content:"\f071";color:#bf6900} | 
 | .admonitionblock td.icon .icon-caution::before{content:"\f06d";color:#bf3400} | 
 | .admonitionblock td.icon .icon-important::before{content:"\f06a";color:#bf0000} | 
 | .conum[data-value]{display:inline-block;color:#fff!important;background:rgba(0,0,0,.8);border-radius:50%;text-align:center;font-size:.75em;width:1.67em;height:1.67em;line-height:1.67em;font-family:"Open Sans","DejaVu Sans",sans-serif;font-style:normal;font-weight:bold} | 
 | .conum[data-value] *{color:#fff!important} | 
 | .conum[data-value]+b{display:none} | 
 | .conum[data-value]::after{content:attr(data-value)} | 
 | pre .conum[data-value]{position:relative;top:-.125em} | 
 | b.conum *{color:inherit!important} | 
 | .conum:not([data-value]):empty{display:none} | 
 | dt,th.tableblock,td.content,div.footnote{text-rendering:optimizeLegibility} | 
 | h1,h2,p,td.content,span.alt,summary{letter-spacing:-.01em} | 
 | p strong,td.content strong,div.footnote strong{letter-spacing:-.005em} | 
 | p,blockquote,dt,td.content,td.hdlist1,span.alt,summary{font-size:1.0625rem} | 
 | p{margin-bottom:1.25rem} | 
 | .sidebarblock p,.sidebarblock dt,.sidebarblock td.content,p.tableblock{font-size:1em} | 
 | .exampleblock>.content{background:#fffef7;border-color:#e0e0dc;box-shadow:0 1px 4px #e0e0dc} | 
 | .print-only{display:none!important} | 
 | @page{margin:1.25cm .75cm} | 
 | @media print{*{box-shadow:none!important;text-shadow:none!important} | 
 | html{font-size:80%} | 
 | a{color:inherit!important;text-decoration:underline!important} | 
 | a.bare,a[href^="#"],a[href^="mailto:"]{text-decoration:none!important} | 
 | a[href^="http:"]:not(.bare)::after,a[href^="https:"]:not(.bare)::after{content:"(" attr(href) ")";display:inline-block;font-size:.875em;padding-left:.25em} | 
 | abbr[title]{border-bottom:1px dotted} | 
 | abbr[title]::after{content:" (" attr(title) ")"} | 
 | pre,blockquote,tr,img,object,svg{page-break-inside:avoid} | 
 | thead{display:table-header-group} | 
 | svg{max-width:100%} | 
 | p,blockquote,dt,td.content{font-size:1em;orphans:3;widows:3} | 
 | h2,h3,#toctitle,.sidebarblock>.content>.title{page-break-after:avoid} | 
 | #header,#content,#footnotes,#footer{max-width:none} | 
 | #toc,.sidebarblock,.exampleblock>.content{background:none!important} | 
 | #toc{border-bottom:1px solid #dddddf!important;padding-bottom:0!important} | 
 | body.book #header{text-align:center} | 
 | body.book #header>h1:first-child{border:0!important;margin:2.5em 0 1em} | 
 | body.book #header .details{border:0!important;display:block;padding:0!important} | 
 | body.book #header .details span:first-child{margin-left:0!important} | 
 | body.book #header .details br{display:block} | 
 | body.book #header .details br+span::before{content:none!important} | 
 | body.book #toc{border:0!important;text-align:left!important;padding:0!important;margin:0!important} | 
 | body.book #toc,body.book #preamble,body.book h1.sect0,body.book .sect1>h2{page-break-before:always} | 
 | .listingblock code[data-lang]::before{display:block} | 
 | #footer{padding:0 .9375em} | 
 | .hide-on-print{display:none!important} | 
 | .print-only{display:block!important} | 
 | .hide-for-print{display:none!important} | 
 | .show-for-print{display:inherit!important}} | 
 | @media amzn-kf8,print{#header>h1:first-child{margin-top:1.25rem} | 
 | .sect1{padding:0!important} | 
 | .sect1+.sect1{border:0} | 
 | #footer{background:none} | 
 | #footer-text{color:rgba(0,0,0,.6);font-size:.9em}} | 
 | @media amzn-kf8{#header,#content,#footnotes,#footer{padding:0}} | 
 | </style> | 
 | <style> | 
 | pre>code { | 
 |    display: inline; | 
 | } | 
 | </style> | 
 | </head> | 
 | <body class="manpage"> | 
 | <div id="header"> | 
 | <h1>gitcore-tutorial(7) Manual Page</h1> | 
 | <h2 id="_name">NAME</h2> | 
 | <div class="sectionbody"> | 
 | <p>gitcore-tutorial - A Git core tutorial for developers</p> | 
 | </div> | 
 | </div> | 
 | <div id="content"> | 
 | <div class="sect1"> | 
 | <h2 id="_synopsis">SYNOPSIS</h2> | 
 | <div class="sectionbody"> | 
 | <div class="paragraph"> | 
 | <p>git *</p> | 
 | </div> | 
 | </div> | 
 | </div> | 
 | <div class="sect1"> | 
 | <h2 id="_description">DESCRIPTION</h2> | 
 | <div class="sectionbody"> | 
 | <div class="paragraph"> | 
 | <p>This tutorial explains how to use the "core" Git commands to set up and | 
 | work with a Git repository.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>If you just need to use Git as a revision control system you may prefer | 
 | to start with "A Tutorial Introduction to Git" (<a href="gittutorial.html">gittutorial(7)</a>) or | 
 | <a href="user-manual.html">the Git User Manual</a>.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>However, an understanding of these low-level tools can be helpful if | 
 | you want to understand Git’s internals.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>The core Git is often called "plumbing", with the prettier user | 
 | interfaces on top of it called "porcelain". You may not want to use the | 
 | plumbing directly very often, but it can be good to know what the | 
 | plumbing does when the porcelain isn’t flushing.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Back when this document was originally written, many porcelain | 
 | commands were shell scripts. For simplicity, it still uses them as | 
 | examples to illustrate how plumbing is fit together to form the | 
 | porcelain commands. The source tree includes some of these scripts in | 
 | contrib/examples/ for reference. Although these are not implemented as | 
 | shell scripts anymore, the description of what the plumbing layer | 
 | commands do is still valid.</p> | 
 | </div> | 
 | <div class="admonitionblock note"> | 
 | <table> | 
 | <tr> | 
 | <td class="icon"> | 
 | <div class="title">Note</div> | 
 | </td> | 
 | <td class="content"> | 
 | Deeper technical details are often marked as Notes, which you can | 
 | skip on your first reading. | 
 | </td> | 
 | </tr> | 
 | </table> | 
 | </div> | 
 | </div> | 
 | </div> | 
 | <div class="sect1"> | 
 | <h2 id="_creating_a_git_repository">Creating a Git repository</h2> | 
 | <div class="sectionbody"> | 
 | <div class="paragraph"> | 
 | <p>Creating a new Git repository couldn’t be easier: all Git repositories start | 
 | out empty, and the only thing you need to do is find yourself a | 
 | subdirectory that you want to use as a working tree - either an empty | 
 | one for a totally new project, or an existing working tree that you want | 
 | to import into Git.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>For our first example, we’re going to start a totally new repository from | 
 | scratch, with no pre-existing files, and we’ll call it <em>git-tutorial</em>. | 
 | To start up, create a subdirectory for it, change into that | 
 | subdirectory, and initialize the Git infrastructure with <em>git init</em>:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ mkdir git-tutorial | 
 | $ cd git-tutorial | 
 | $ git init</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>to which Git will reply</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>Initialized empty Git repository in .git/</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>which is just Git’s way of saying that you haven’t been doing anything | 
 | strange, and that it will have created a local .<code>git</code> directory setup for | 
 | your new project. You will now have a .<code>git</code> directory, and you can | 
 | inspect that with <em>ls</em>. For your new empty project, it should show you | 
 | three entries, among other things:</p> | 
 | </div> | 
 | <div class="ulist"> | 
 | <ul> | 
 | <li> | 
 | <p>a file called <code>HEAD</code>, that has <code>ref:</code> <code>refs/heads/master</code> in it. | 
 | This is similar to a symbolic link and points at | 
 | <code>refs/heads/master</code> relative to the <code>HEAD</code> file.</p> | 
 | <div class="paragraph"> | 
 | <p>Don’t worry about the fact that the file that the <code>HEAD</code> link points to | 
 | doesn’t even exist yet — you haven’t created the commit that will | 
 | start your <code>HEAD</code> development branch yet.</p> | 
 | </div> | 
 | </li> | 
 | <li> | 
 | <p>a subdirectory called <code>objects</code>, which will contain all the | 
 | objects of your project. You should never have any real reason to | 
 | look at the objects directly, but you might want to know that these | 
 | objects are what contains all the real <em>data</em> in your repository.</p> | 
 | </li> | 
 | <li> | 
 | <p>a subdirectory called <code>refs</code>, which contains references to objects.</p> | 
 | </li> | 
 | </ul> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>In particular, the <code>refs</code> subdirectory will contain two other | 
 | subdirectories, named <code>heads</code> and <code>tags</code> respectively. They do | 
 | exactly what their names imply: they contain references to any number | 
 | of different <em>heads</em> of development (aka <em>branches</em>), and to any | 
 | <em>tags</em> that you have created to name specific versions in your | 
 | repository.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>One note: the special <code>master</code> head is the default branch, which is | 
 | why the .<code>git/HEAD</code> file was created points to it even if it | 
 | doesn’t yet exist. Basically, the <code>HEAD</code> link is supposed to always | 
 | point to the branch you are working on right now, and you always | 
 | start out expecting to work on the <code>master</code> branch.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>However, this is only a convention, and you can name your branches | 
 | anything you want, and don’t have to ever even <em>have</em> a <code>master</code> | 
 | branch. A number of the Git tools will assume that .<code>git/HEAD</code> is | 
 | valid, though.</p> | 
 | </div> | 
 | <div class="admonitionblock note"> | 
 | <table> | 
 | <tr> | 
 | <td class="icon"> | 
 | <div class="title">Note</div> | 
 | </td> | 
 | <td class="content"> | 
 | An <em>object</em> is identified by its 160-bit SHA-1 hash, aka <em>object name</em>, | 
 | and a reference to an object is always the 40-byte hex | 
 | representation of that SHA-1 name. The files in the <code>refs</code> | 
 | subdirectory are expected to contain these hex references | 
 | (usually with a final <code>\n</code> at the end), and you should thus | 
 | expect to see a number of 41-byte files containing these | 
 | references in these <code>refs</code> subdirectories when you actually start | 
 | populating your tree. | 
 | </td> | 
 | </tr> | 
 | </table> | 
 | </div> | 
 | <div class="admonitionblock note"> | 
 | <table> | 
 | <tr> | 
 | <td class="icon"> | 
 | <div class="title">Note</div> | 
 | </td> | 
 | <td class="content"> | 
 | An advanced user may want to take a look at <a href="gitrepository-layout.html">gitrepository-layout(5)</a> | 
 | after finishing this tutorial. | 
 | </td> | 
 | </tr> | 
 | </table> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>You have now created your first Git repository. Of course, since it’s | 
 | empty, that’s not very useful, so let’s start populating it with data.</p> | 
 | </div> | 
 | </div> | 
 | </div> | 
 | <div class="sect1"> | 
 | <h2 id="_populating_a_git_repository">Populating a Git repository</h2> | 
 | <div class="sectionbody"> | 
 | <div class="paragraph"> | 
 | <p>We’ll keep this simple and stupid, so we’ll start off with populating a | 
 | few trivial files just to get a feel for it.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Start off with just creating any random files that you want to maintain | 
 | in your Git repository. We’ll start off with a few bad examples, just to | 
 | get a feel for how this works:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ echo "Hello World" >hello | 
 | $ echo "Silly example" >example</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>you have now created two files in your working tree (aka <em>working directory</em>), | 
 | but to actually check in your hard work, you will have to go through two steps:</p> | 
 | </div> | 
 | <div class="ulist"> | 
 | <ul> | 
 | <li> | 
 | <p>fill in the <em>index</em> file (aka <em>cache</em>) with the information about your | 
 | working tree state.</p> | 
 | </li> | 
 | <li> | 
 | <p>commit that index file as an object.</p> | 
 | </li> | 
 | </ul> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>The first step is trivial: when you want to tell Git about any changes | 
 | to your working tree, you use the <em>git update-index</em> program. That | 
 | program normally just takes a list of filenames you want to update, but | 
 | to avoid trivial mistakes, it refuses to add new entries to the index | 
 | (or remove existing ones) unless you explicitly tell it that you’re | 
 | adding a new entry with the <code>--add</code> flag (or removing an entry with the | 
 | <code>--remove</code>) flag.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>So to populate the index with the two files you just created, you can do</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git update-index --add hello example</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>and you have now told Git to track those two files.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>In fact, as you did that, if you now look into your object directory, | 
 | you’ll notice that Git will have added two new objects to the object | 
 | database. If you did exactly the steps above, you should now be able to do</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ ls .git/objects/??/*</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>and see two files:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>.git/objects/55/7db03de997c86a4a028e1ebd3a1ceb225be238 | 
 | .git/objects/f2/4c74a2e500f5ee1332c86b94199f52b1d1d962</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>which correspond with the objects with names of <code>557db..</code>. and | 
 | <code>f24c7..</code>. respectively.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>If you want to, you can use <em>git cat-file</em> to look at those objects, but | 
 | you’ll have to use the object name, not the filename of the object:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git cat-file -t 557db03de997c86a4a028e1ebd3a1ceb225be238</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>where the <code>-t</code> tells <em>git cat-file</em> to tell you what the "type" of the | 
 | object is. Git will tell you that you have a "blob" object (i.e., just a | 
 | regular file), and you can see the contents with</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git cat-file blob 557db03</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>which will print out "Hello World". The object <code>557db03</code> is nothing | 
 | more than the contents of your file <code>hello</code>.</p> | 
 | </div> | 
 | <div class="admonitionblock note"> | 
 | <table> | 
 | <tr> | 
 | <td class="icon"> | 
 | <div class="title">Note</div> | 
 | </td> | 
 | <td class="content"> | 
 | Don’t confuse that object with the file <code>hello</code> itself. The | 
 | object is literally just those specific <strong>contents</strong> of the file, and | 
 | however much you later change the contents in file <code>hello</code>, the object | 
 | we just looked at will never change. Objects are immutable. | 
 | </td> | 
 | </tr> | 
 | </table> | 
 | </div> | 
 | <div class="admonitionblock note"> | 
 | <table> | 
 | <tr> | 
 | <td class="icon"> | 
 | <div class="title">Note</div> | 
 | </td> | 
 | <td class="content"> | 
 | The second example demonstrates that you can | 
 | abbreviate the object name to only the first several | 
 | hexadecimal digits in most places. | 
 | </td> | 
 | </tr> | 
 | </table> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Anyway, as we mentioned previously, you normally never actually take a | 
 | look at the objects themselves, and typing long 40-character hex | 
 | names is not something you’d normally want to do. The above digression | 
 | was just to show that <em>git update-index</em> did something magical, and | 
 | actually saved away the contents of your files into the Git object | 
 | database.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Updating the index did something else too: it created a .<code>git/index</code> | 
 | file. This is the index that describes your current working tree, and | 
 | something you should be very aware of. Again, you normally never worry | 
 | about the index file itself, but you should be aware of the fact that | 
 | you have not actually really "checked in" your files into Git so far, | 
 | you’ve only <strong>told</strong> Git about them.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>However, since Git knows about them, you can now start using some of the | 
 | most basic Git commands to manipulate the files or look at their status.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>In particular, let’s not even check in the two files into Git yet, we’ll | 
 | start off by adding another line to <code>hello</code> first:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ echo "It's a new day for git" >>hello</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>and you can now, since you told Git about the previous state of <code>hello</code>, ask | 
 | Git what has changed in the tree compared to your old index, using the | 
 | <em>git diff-files</em> command:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git diff-files</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Oops. That wasn’t very readable. It just spit out its own internal | 
 | version of a <em>diff</em>, but that internal version really just tells you | 
 | that it has noticed that "hello" has been modified, and that the old object | 
 | contents it had have been replaced with something else.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>To make it readable, we can tell <em>git diff-files</em> to output the | 
 | differences as a patch, using the <code>-p</code> flag:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git diff-files -p | 
 | diff --git a/hello b/hello | 
 | index 557db03..263414f 100644 | 
 | --- a/hello | 
 | +++ b/hello | 
 | @@ -1 +1,2 @@ | 
 |  Hello World | 
 | +It's a new day for git</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>i.e. the diff of the change we caused by adding another line to <code>hello</code>.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>In other words, <em>git diff-files</em> always shows us the difference between | 
 | what is recorded in the index, and what is currently in the working | 
 | tree. That’s very useful.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>A common shorthand for <code>git</code> <code>diff-files</code> <code>-p</code> is to just write <code>git</code> | 
 | <code>diff</code>, which will do the same thing.</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git diff | 
 | diff --git a/hello b/hello | 
 | index 557db03..263414f 100644 | 
 | --- a/hello | 
 | +++ b/hello | 
 | @@ -1 +1,2 @@ | 
 |  Hello World | 
 | +It's a new day for git</pre> | 
 | </div> | 
 | </div> | 
 | </div> | 
 | </div> | 
 | <div class="sect1"> | 
 | <h2 id="_committing_git_state">Committing Git state</h2> | 
 | <div class="sectionbody"> | 
 | <div class="paragraph"> | 
 | <p>Now, we want to go to the next stage in Git, which is to take the files | 
 | that Git knows about in the index, and commit them as a real tree. We do | 
 | that in two phases: creating a <em>tree</em> object, and committing that <em>tree</em> | 
 | object as a <em>commit</em> object together with an explanation of what the | 
 | tree was all about, along with information of how we came to that state.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Creating a tree object is trivial, and is done with <em>git write-tree</em>. | 
 | There are no options or other input: <code>git</code> <code>write-tree</code> will take the | 
 | current index state, and write an object that describes that whole | 
 | index. In other words, we’re now tying together all the different | 
 | filenames with their contents (and their permissions), and we’re | 
 | creating the equivalent of a Git "directory" object:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git write-tree</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>and this will just output the name of the resulting tree, in this case | 
 | (if you have done exactly as I’ve described) it should be</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>8988da15d077d4829fc51d8544c097def6644dbb</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>which is another incomprehensible object name. Again, if you want to, | 
 | you can use <code>git</code> <code>cat-file</code> <code>-t</code> <code>8988d..</code>. to see that this time the object | 
 | is not a "blob" object, but a "tree" object (you can also use | 
 | <code>git</code> <code>cat-file</code> to actually output the raw object contents, but you’ll see | 
 | mainly a binary mess, so that’s less interesting).</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>However — normally you’d never use <em>git write-tree</em> on its own, because | 
 | normally you always commit a tree into a commit object using the | 
 | <em>git commit-tree</em> command. In fact, it’s easier to not actually use | 
 | <em>git write-tree</em> on its own at all, but to just pass its result in as an | 
 | argument to <em>git commit-tree</em>.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p><em>git commit-tree</em> normally takes several arguments — it wants to know | 
 | what the <em>parent</em> of a commit was, but since this is the first commit | 
 | ever in this new repository, and it has no parents, we only need to pass in | 
 | the object name of the tree. However, <em>git commit-tree</em> also wants to get a | 
 | commit message on its standard input, and it will write out the resulting | 
 | object name for the commit to its standard output.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>And this is where we create the .<code>git/refs/heads/master</code> file | 
 | which is pointed at by <code>HEAD</code>. This file is supposed to contain | 
 | the reference to the top-of-tree of the master branch, and since | 
 | that’s exactly what <em>git commit-tree</em> spits out, we can do this | 
 | all with a sequence of simple shell commands:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ tree=$(git write-tree) | 
 | $ commit=$(echo 'Initial commit' | git commit-tree $tree) | 
 | $ git update-ref HEAD $commit</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>In this case this creates a totally new commit that is not related to | 
 | anything else. Normally you do this only <strong>once</strong> for a project ever, and | 
 | all later commits will be parented on top of an earlier commit.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Again, normally you’d never actually do this by hand. There is a | 
 | helpful script called <code>git</code> <code>commit</code> that will do all of this for you. So | 
 | you could have just written <code>git</code> <code>commit</code> | 
 | instead, and it would have done the above magic scripting for you.</p> | 
 | </div> | 
 | </div> | 
 | </div> | 
 | <div class="sect1"> | 
 | <h2 id="_making_a_change">Making a change</h2> | 
 | <div class="sectionbody"> | 
 | <div class="paragraph"> | 
 | <p>Remember how we did the <em>git update-index</em> on file <code>hello</code> and then we | 
 | changed <code>hello</code> afterward, and could compare the new state of <code>hello</code> with the | 
 | state we saved in the index file?</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Further, remember how I said that <em>git write-tree</em> writes the contents | 
 | of the <strong>index</strong> file to the tree, and thus what we just committed was in | 
 | fact the <strong>original</strong> contents of the file <code>hello</code>, not the new ones. We did | 
 | that on purpose, to show the difference between the index state, and the | 
 | state in the working tree, and how they don’t have to match, even | 
 | when we commit things.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>As before, if we do <code>git</code> <code>diff-files</code> <code>-p</code> in our git-tutorial project, | 
 | we’ll still see the same difference we saw last time: the index file | 
 | hasn’t changed by the act of committing anything. However, now that we | 
 | have committed something, we can also learn to use a new command: | 
 | <em>git diff-index</em>.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Unlike <em>git diff-files</em>, which showed the difference between the index | 
 | file and the working tree, <em>git diff-index</em> shows the differences | 
 | between a committed <strong>tree</strong> and either the index file or the working | 
 | tree. In other words, <em>git diff-index</em> wants a tree to be diffed | 
 | against, and before we did the commit, we couldn’t do that, because we | 
 | didn’t have anything to diff against.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>But now we can do</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git diff-index -p HEAD</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>(where <code>-p</code> has the same meaning as it did in <em>git diff-files</em>), and it | 
 | will show us the same difference, but for a totally different reason. | 
 | Now we’re comparing the working tree not against the index file, | 
 | but against the tree we just wrote. It just so happens that those two | 
 | are obviously the same, so we get the same result.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Again, because this is a common operation, you can also just shorthand | 
 | it with</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git diff HEAD</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>which ends up doing the above for you.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>In other words, <em>git diff-index</em> normally compares a tree against the | 
 | working tree, but when given the <code>--cached</code> flag, it is told to | 
 | instead compare against just the index cache contents, and ignore the | 
 | current working tree state entirely. Since we just wrote the index | 
 | file to HEAD, doing <code>git</code> <code>diff-index</code> <code>--cached</code> <code>-p</code> <code>HEAD</code> should thus return | 
 | an empty set of differences, and that’s exactly what it does.</p> | 
 | </div> | 
 | <div class="admonitionblock note"> | 
 | <table> | 
 | <tr> | 
 | <td class="icon"> | 
 | <div class="title">Note</div> | 
 | </td> | 
 | <td class="content"> | 
 | <div class="paragraph"> | 
 | <p><em>git diff-index</em> really always uses the index for its | 
 | comparisons, and saying that it compares a tree against the working | 
 | tree is thus not strictly accurate. In particular, the list of | 
 | files to compare (the "meta-data") <strong>always</strong> comes from the index file, | 
 | regardless of whether the <code>--cached</code> flag is used or not. The <code>--cached</code> | 
 | flag really only determines whether the file <strong>contents</strong> to be compared | 
 | come from the working tree or not.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>This is not hard to understand, as soon as you realize that Git simply | 
 | never knows (or cares) about files that it is not told about | 
 | explicitly. Git will never go <strong>looking</strong> for files to compare, it | 
 | expects you to tell it what the files are, and that’s what the index | 
 | is there for.</p> | 
 | </div> | 
 | </td> | 
 | </tr> | 
 | </table> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>However, our next step is to commit the <strong>change</strong> we did, and again, to | 
 | understand what’s going on, keep in mind the difference between "working | 
 | tree contents", "index file" and "committed tree". We have changes | 
 | in the working tree that we want to commit, and we always have to | 
 | work through the index file, so the first thing we need to do is to | 
 | update the index cache:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git update-index hello</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>(note how we didn’t need the <code>--add</code> flag this time, since Git knew | 
 | about the file already).</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Note what happens to the different <em>git diff-*</em> versions here. | 
 | After we’ve updated <code>hello</code> in the index, <code>git</code> <code>diff-files</code> <code>-p</code> now shows no | 
 | differences, but <code>git</code> <code>diff-index</code> <code>-p</code> <code>HEAD</code> still <strong>does</strong> show that the | 
 | current state is different from the state we committed. In fact, now | 
 | <em>git diff-index</em> shows the same difference whether we use the <code>--cached</code> | 
 | flag or not, since now the index is coherent with the working tree.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Now, since we’ve updated <code>hello</code> in the index, we can commit the new | 
 | version. We could do it by writing the tree by hand again, and | 
 | committing the tree (this time we’d have to use the <code>-p</code> <code>HEAD</code> flag to | 
 | tell commit that the HEAD was the <strong>parent</strong> of the new commit, and that | 
 | this wasn’t an initial commit any more), but you’ve done that once | 
 | already, so let’s just use the helpful script this time:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git commit</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>which starts an editor for you to write the commit message and tells you | 
 | a bit about what you have done.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Write whatever message you want, and all the lines that start with <em>#</em> | 
 | will be pruned out, and the rest will be used as the commit message for | 
 | the change. If you decide you don’t want to commit anything after all at | 
 | this point (you can continue to edit things and update the index), you | 
 | can just leave an empty message. Otherwise <code>git</code> <code>commit</code> will commit | 
 | the change for you.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>You’ve now made your first real Git commit. And if you’re interested in | 
 | looking at what <code>git</code> <code>commit</code> really does, feel free to investigate: | 
 | it’s a few very simple shell scripts to generate the helpful (?) commit | 
 | message headers, and a few one-liners that actually do the | 
 | commit itself (<em>git commit</em>).</p> | 
 | </div> | 
 | </div> | 
 | </div> | 
 | <div class="sect1"> | 
 | <h2 id="_inspecting_changes">Inspecting Changes</h2> | 
 | <div class="sectionbody"> | 
 | <div class="paragraph"> | 
 | <p>While creating changes is useful, it’s even more useful if you can tell | 
 | later what changed. The most useful command for this is another of the | 
 | <em>diff</em> family, namely <em>git diff-tree</em>.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p><em>git diff-tree</em> can be given two arbitrary trees, and it will tell you the | 
 | differences between them. Perhaps even more commonly, though, you can | 
 | give it just a single commit object, and it will figure out the parent | 
 | of that commit itself, and show the difference directly. Thus, to get | 
 | the same diff that we’ve already seen several times, we can now do</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git diff-tree -p HEAD</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>(again, <code>-p</code> means to show the difference as a human-readable patch), | 
 | and it will show what the last commit (in <code>HEAD</code>) actually changed.</p> | 
 | </div> | 
 | <div class="admonitionblock note"> | 
 | <table> | 
 | <tr> | 
 | <td class="icon"> | 
 | <div class="title">Note</div> | 
 | </td> | 
 | <td class="content"> | 
 | <div class="paragraph"> | 
 | <p>Here is an ASCII art by Jon Loeliger that illustrates how | 
 | various <em>diff-*</em> commands compare things.</p> | 
 | </div> | 
 | <div class="literalblock"> | 
 | <div class="content"> | 
 | <pre>            diff-tree | 
 |              +----+ | 
 |              |    | | 
 |              |    | | 
 |              V    V | 
 |           +-----------+ | 
 |           | Object DB | | 
 |           |  Backing  | | 
 |           |   Store   | | 
 |           +-----------+ | 
 |             ^    ^ | 
 |             |    | | 
 |             |    |  diff-index --cached | 
 |             |    | | 
 | diff-index  |    V | 
 |             |  +-----------+ | 
 |             |  |   Index   | | 
 |             |  |  "cache"  | | 
 |             |  +-----------+ | 
 |             |    ^ | 
 |             |    | | 
 |             |    |  diff-files | 
 |             |    | | 
 |             V    V | 
 |           +-----------+ | 
 |           |  Working  | | 
 |           | Directory | | 
 |           +-----------+</pre> | 
 | </div> | 
 | </div> | 
 | </td> | 
 | </tr> | 
 | </table> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>More interestingly, you can also give <em>git diff-tree</em> the <code>--pretty</code> flag, | 
 | which tells it to also show the commit message and author and date of the | 
 | commit, and you can tell it to show a whole series of diffs. | 
 | Alternatively, you can tell it to be "silent", and not show the diffs at | 
 | all, but just show the actual commit message.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>In fact, together with the <em>git rev-list</em> program (which generates a | 
 | list of revisions), <em>git diff-tree</em> ends up being a veritable fount of | 
 | changes.  You can emulate <code>git</code> <code>log</code>, <code>git</code> <code>log</code> <code>-p</code>, etc. with a trivial | 
 | script that pipes the output of <code>git</code> <code>rev-list</code> to <code>git</code> <code>diff-tree</code> <code>--stdin</code>, | 
 | which was exactly how early versions of <code>git</code> <code>log</code> were implemented.</p> | 
 | </div> | 
 | </div> | 
 | </div> | 
 | <div class="sect1"> | 
 | <h2 id="_tagging_a_version">Tagging a version</h2> | 
 | <div class="sectionbody"> | 
 | <div class="paragraph"> | 
 | <p>In Git, there are two kinds of tags, a "light" one, and an "annotated tag".</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>A "light" tag is technically nothing more than a branch, except we put | 
 | it in the .<code>git/refs/tags/</code> subdirectory instead of calling it a <code>head</code>. | 
 | So the simplest form of tag involves nothing more than</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git tag my-first-tag</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>which just writes the current <code>HEAD</code> into the .<code>git/refs/tags/my-first-tag</code> | 
 | file, after which point you can then use this symbolic name for that | 
 | particular state. You can, for example, do</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git diff my-first-tag</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>to diff your current state against that tag which at this point will | 
 | obviously be an empty diff, but if you continue to develop and commit | 
 | stuff, you can use your tag as an "anchor-point" to see what has changed | 
 | since you tagged it.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>An "annotated tag" is actually a real Git object, and contains not only a | 
 | pointer to the state you want to tag, but also a small tag name and | 
 | message, along with optionally a PGP signature that says that yes, | 
 | you really did | 
 | that tag. You create these annotated tags with either the <code>-a</code> or | 
 | <code>-s</code> flag to <em>git tag</em>:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git tag -s <tagname></pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>which will sign the current <code>HEAD</code> (but you can also give it another | 
 | argument that specifies the thing to tag, e.g., you could have tagged the | 
 | current <code>mybranch</code> point by using <code>git</code> <code>tag</code> <em><tagname></em> <code>mybranch</code>).</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>You normally only do signed tags for major releases or things | 
 | like that, while the light-weight tags are useful for any marking you | 
 | want to do — any time you decide that you want to remember a certain | 
 | point, just create a private tag for it, and you have a nice symbolic | 
 | name for the state at that point.</p> | 
 | </div> | 
 | </div> | 
 | </div> | 
 | <div class="sect1"> | 
 | <h2 id="_copying_repositories">Copying repositories</h2> | 
 | <div class="sectionbody"> | 
 | <div class="paragraph"> | 
 | <p>Git repositories are normally totally self-sufficient and relocatable. | 
 | Unlike CVS, for example, there is no separate notion of | 
 | "repository" and "working tree". A Git repository normally <strong>is</strong> the | 
 | working tree, with the local Git information hidden in the .<code>git</code> | 
 | subdirectory. There is nothing else. What you see is what you got.</p> | 
 | </div> | 
 | <div class="admonitionblock note"> | 
 | <table> | 
 | <tr> | 
 | <td class="icon"> | 
 | <div class="title">Note</div> | 
 | </td> | 
 | <td class="content"> | 
 | You can tell Git to split the Git internal information from | 
 | the directory that it tracks, but we’ll ignore that for now: it’s not | 
 | how normal projects work, and it’s really only meant for special uses. | 
 | So the mental model of "the Git information is always tied directly to | 
 | the working tree that it describes" may not be technically 100% | 
 | accurate, but it’s a good model for all normal use. | 
 | </td> | 
 | </tr> | 
 | </table> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>This has two implications:</p> | 
 | </div> | 
 | <div class="ulist"> | 
 | <ul> | 
 | <li> | 
 | <p>if you grow bored with the tutorial repository you created (or you’ve | 
 | made a mistake and want to start all over), you can just do simple</p> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ rm -rf git-tutorial</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>and it will be gone. There’s no external repository, and there’s no | 
 | history outside the project you created.</p> | 
 | </div> | 
 | </li> | 
 | <li> | 
 | <p>if you want to move or duplicate a Git repository, you can do so. There | 
 | is <em>git clone</em> command, but if all you want to do is just to | 
 | create a copy of your repository (with all the full history that | 
 | went along with it), you can do so with a regular | 
 | <code>cp</code> <code>-a</code> <code>git-tutorial</code> <code>new-git-tutorial</code>.</p> | 
 | <div class="paragraph"> | 
 | <p>Note that when you’ve moved or copied a Git repository, your Git index | 
 | file (which caches various information, notably some of the "stat" | 
 | information for the files involved) will likely need to be refreshed. | 
 | So after you do a <code>cp</code> <code>-a</code> to create a new copy, you’ll want to do</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git update-index --refresh</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>in the new repository to make sure that the index file is up to date.</p> | 
 | </div> | 
 | </li> | 
 | </ul> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Note that the second point is true even across machines. You can | 
 | duplicate a remote Git repository with <strong>any</strong> regular copy mechanism, be it | 
 | <em>scp</em>, <em>rsync</em> or <em>wget</em>.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>When copying a remote repository, you’ll want to at a minimum update the | 
 | index cache when you do this, and especially with other peoples' | 
 | repositories you often want to make sure that the index cache is in some | 
 | known state (you don’t know <strong>what</strong> they’ve done and not yet checked in), | 
 | so usually you’ll precede the <em>git update-index</em> with a</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git read-tree --reset HEAD | 
 | $ git update-index --refresh</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>which will force a total index re-build from the tree pointed to by <code>HEAD</code>. | 
 | It resets the index contents to <code>HEAD</code>, and then the <em>git update-index</em> | 
 | makes sure to match up all index entries with the checked-out files. | 
 | If the original repository had uncommitted changes in its | 
 | working tree, <code>git</code> <code>update-index</code> <code>--refresh</code> notices them and | 
 | tells you they need to be updated.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>The above can also be written as simply</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git reset</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>and in fact a lot of the common Git command combinations can be scripted | 
 | with the <code>git</code> <code>xyz</code> interfaces.  You can learn things by just looking | 
 | at what the various git scripts do.  For example, <code>git</code> <code>reset</code> used to be | 
 | the above two lines implemented in <em>git reset</em>, but some things like | 
 | <em>git status</em> and <em>git commit</em> are slightly more complex scripts around | 
 | the basic Git commands.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Many (most?) public remote repositories will not contain any of | 
 | the checked out files or even an index file, and will <strong>only</strong> contain the | 
 | actual core Git files. Such a repository usually doesn’t even have the | 
 | .<code>git</code> subdirectory, but has all the Git files directly in the | 
 | repository.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>To create your own local live copy of such a "raw" Git repository, you’d | 
 | first create your own subdirectory for the project, and then copy the | 
 | raw repository contents into the .<code>git</code> directory. For example, to | 
 | create your own copy of the Git repository, you’d do the following</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ mkdir my-git | 
 | $ cd my-git | 
 | $ rsync -rL rsync://rsync.kernel.org/pub/scm/git/git.git/ .git</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>followed by</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git read-tree HEAD</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>to populate the index. However, now you have populated the index, and | 
 | you have all the Git internal files, but you will notice that you don’t | 
 | actually have any of the working tree files to work on. To get | 
 | those, you’d check them out with</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git checkout-index -u -a</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>where the <code>-u</code> flag means that you want the checkout to keep the index | 
 | up to date (so that you don’t have to refresh it afterward), and the | 
 | <code>-a</code> flag means "check out all files" (if you have a stale copy or an | 
 | older version of a checked out tree you may also need to add the <code>-f</code> | 
 | flag first, to tell <em>git checkout-index</em> to <strong>force</strong> overwriting of any old | 
 | files).</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Again, this can all be simplified with</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git clone git://git.kernel.org/pub/scm/git/git.git/ my-git | 
 | $ cd my-git | 
 | $ git checkout</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>which will end up doing all of the above for you.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>You have now successfully copied somebody else’s (mine) remote | 
 | repository, and checked it out.</p> | 
 | </div> | 
 | </div> | 
 | </div> | 
 | <div class="sect1"> | 
 | <h2 id="_creating_a_new_branch">Creating a new branch</h2> | 
 | <div class="sectionbody"> | 
 | <div class="paragraph"> | 
 | <p>Branches in Git are really nothing more than pointers into the Git | 
 | object database from within the .<code>git/refs/</code> subdirectory, and as we | 
 | already discussed, the <code>HEAD</code> branch is nothing but a symlink to one of | 
 | these object pointers.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>You can at any time create a new branch by just picking an arbitrary | 
 | point in the project history, and just writing the SHA-1 name of that | 
 | object into a file under .<code>git/refs/heads/</code>. You can use any filename you | 
 | want (and indeed, subdirectories), but the convention is that the | 
 | "normal" branch is called <code>master</code>. That’s just a convention, though, | 
 | and nothing enforces it.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>To show that as an example, let’s go back to the git-tutorial repository we | 
 | used earlier, and create a branch in it. You do that by simply just | 
 | saying that you want to check out a new branch:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git switch -c mybranch</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>will create a new branch based at the current <code>HEAD</code> position, and switch | 
 | to it.</p> | 
 | </div> | 
 | <div class="admonitionblock note"> | 
 | <table> | 
 | <tr> | 
 | <td class="icon"> | 
 | <div class="title">Note</div> | 
 | </td> | 
 | <td class="content"> | 
 | <div class="paragraph"> | 
 | <p>If you make the decision to start your new branch at some | 
 | other point in the history than the current <code>HEAD</code>, you can do so by | 
 | just telling <em>git switch</em> what the base of the checkout would be. | 
 | In other words, if you have an earlier tag or branch, you’d just do</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git switch -c mybranch earlier-commit</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>and it would create the new branch <code>mybranch</code> at the earlier commit, | 
 | and check out the state at that time.</p> | 
 | </div> | 
 | </td> | 
 | </tr> | 
 | </table> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>You can always just jump back to your original <code>master</code> branch by doing</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git switch master</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>(or any other branch-name, for that matter) and if you forget which | 
 | branch you happen to be on, a simple</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ cat .git/HEAD</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>will tell you where it’s pointing.  To get the list of branches | 
 | you have, you can say</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git branch</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>which used to be nothing more than a simple script around <code>ls</code> <code>.git/refs/heads</code>. | 
 | There will be an asterisk in front of the branch you are currently on.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Sometimes you may wish to create a new branch <em>without</em> actually | 
 | checking it out and switching to it. If so, just use the command</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git branch <branchname> [startingpoint]</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>which will simply <em>create</em> the branch, but will not do anything further. | 
 | You can then later — once you decide that you want to actually develop | 
 | on that branch — switch to that branch with a regular <em>git switch</em> | 
 | with the branchname as the argument.</p> | 
 | </div> | 
 | </div> | 
 | </div> | 
 | <div class="sect1"> | 
 | <h2 id="_merging_two_branches">Merging two branches</h2> | 
 | <div class="sectionbody"> | 
 | <div class="paragraph"> | 
 | <p>One of the ideas of having a branch is that you do some (possibly | 
 | experimental) work in it, and eventually merge it back to the main | 
 | branch. So assuming you created the above <code>mybranch</code> that started out | 
 | being the same as the original <code>master</code> branch, let’s make sure we’re in | 
 | that branch, and do some work there.</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git switch mybranch | 
 | $ echo "Work, work, work" >>hello | 
 | $ git commit -m "Some work." -i hello</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Here, we just added another line to <code>hello</code>, and we used a shorthand for | 
 | doing both <code>git</code> <code>update-index</code> <code>hello</code> and <code>git</code> <code>commit</code> by just giving the | 
 | filename directly to <code>git</code> <code>commit</code>, with an <code>-i</code> flag (it tells | 
 | Git to <em>include</em> that file in addition to what you have done to | 
 | the index file so far when making the commit).  The <code>-m</code> flag is to give the | 
 | commit log message from the command line.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Now, to make it a bit more interesting, let’s assume that somebody else | 
 | does some work in the original branch, and simulate that by going back | 
 | to the master branch, and editing the same file differently there:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git switch master</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Here, take a moment to look at the contents of <code>hello</code>, and notice how they | 
 | don’t contain the work we just did in <code>mybranch</code> — because that work | 
 | hasn’t happened in the <code>master</code> branch at all. Then do</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ echo "Play, play, play" >>hello | 
 | $ echo "Lots of fun" >>example | 
 | $ git commit -m "Some fun." -i hello example</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>since the master branch is obviously in a much better mood.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Now, you’ve got two branches, and you decide that you want to merge the | 
 | work done. Before we do that, let’s introduce a cool graphical tool that | 
 | helps you view what’s going on:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ gitk --all</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>will show you graphically both of your branches (that’s what the <code>--all</code> | 
 | means: normally it will just show you your current <code>HEAD</code>) and their | 
 | histories. You can also see exactly how they came to be from a common | 
 | source.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Anyway, let’s exit <em>gitk</em> (<code>^Q</code> or the File menu), and decide that we want | 
 | to merge the work we did on the <code>mybranch</code> branch into the <code>master</code> | 
 | branch (which is currently our <code>HEAD</code> too). To do that, there’s a nice | 
 | script called <em>git merge</em>, which wants to know which branches you want | 
 | to resolve and what the merge is all about:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git merge -m "Merge work in mybranch" mybranch</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>where the first argument is going to be used as the commit message if | 
 | the merge can be resolved automatically.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Now, in this case we’ve intentionally created a situation where the | 
 | merge will need to be fixed up by hand, though, so Git will do as much | 
 | of it as it can automatically (which in this case is just merge the <code>example</code> | 
 | file, which had no differences in the <code>mybranch</code> branch), and say:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>        Auto-merging hello | 
 |         CONFLICT (content): Merge conflict in hello | 
 |         Automatic merge failed; fix conflicts and then commit the result.</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>It tells you that it did an "Automatic merge", which | 
 | failed due to conflicts in <code>hello</code>.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Not to worry. It left the (trivial) conflict in <code>hello</code> in the same form you | 
 | should already be well used to if you’ve ever used CVS, so let’s just | 
 | open <code>hello</code> in our editor (whatever that may be), and fix it up somehow. | 
 | I’d suggest just making it so that <code>hello</code> contains all four lines:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>Hello World | 
 | It's a new day for git | 
 | Play, play, play | 
 | Work, work, work</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>and once you’re happy with your manual merge, just do a</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git commit -i hello</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>which will very loudly warn you that you’re now committing a merge | 
 | (which is correct, so never mind), and you can write a small merge | 
 | message about your adventures in <em>git merge</em>-land.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>After you’re done, start up <code>gitk</code> <code>--all</code> to see graphically what the | 
 | history looks like. Notice that <code>mybranch</code> still exists, and you can | 
 | switch to it, and continue to work with it if you want to. The | 
 | <code>mybranch</code> branch will not contain the merge, but next time you merge it | 
 | from the <code>master</code> branch, Git will know how you merged it, so you’ll not | 
 | have to do <em>that</em> merge again.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Another useful tool, especially if you do not always work in X-Window | 
 | environment, is <code>git</code> <code>show-branch</code>.</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git show-branch --topo-order --more=1 master mybranch | 
 | * [master] Merge work in mybranch | 
 |  ! [mybranch] Some work. | 
 | -- | 
 | -  [master] Merge work in mybranch | 
 | *+ [mybranch] Some work. | 
 | *  [master^] Some fun.</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>The first two lines indicate that it is showing the two branches | 
 | with the titles of their top-of-the-tree commits, you are currently on | 
 | <code>master</code> branch (notice the asterisk <code>*</code> character), and the first | 
 | column for the later output lines is used to show commits contained in the | 
 | <code>master</code> branch, and the second column for the <code>mybranch</code> | 
 | branch. Three commits are shown along with their titles. | 
 | All of them have non blank characters in the first column (<code>*</code> | 
 | shows an ordinary commit on the current branch, <code>-</code> is a merge commit), which | 
 | means they are now part of the <code>master</code> branch. Only the "Some | 
 | work" commit has the plus <code>+</code> character in the second column, | 
 | because <code>mybranch</code> has not been merged to incorporate these | 
 | commits from the master branch.  The string inside brackets | 
 | before the commit log message is a short name you can use to | 
 | name the commit.  In the above example, <em>master</em> and <em>mybranch</em> | 
 | are branch heads.  <em>master^</em> is the first parent of <em>master</em> | 
 | branch head.  Please see <a href="gitrevisions.html">gitrevisions(7)</a> if you want to | 
 | see more complex cases.</p> | 
 | </div> | 
 | <div class="admonitionblock note"> | 
 | <table> | 
 | <tr> | 
 | <td class="icon"> | 
 | <div class="title">Note</div> | 
 | </td> | 
 | <td class="content"> | 
 | Without the <em>--more=1</em> option, <em>git show-branch</em> would not output the | 
 | <em>[master^]</em> commit, as <em>[mybranch]</em> commit is a common ancestor of | 
 | both <em>master</em> and <em>mybranch</em> tips.  Please see <a href="git-show-branch.html">git-show-branch(1)</a> | 
 | for details. | 
 | </td> | 
 | </tr> | 
 | </table> | 
 | </div> | 
 | <div class="admonitionblock note"> | 
 | <table> | 
 | <tr> | 
 | <td class="icon"> | 
 | <div class="title">Note</div> | 
 | </td> | 
 | <td class="content"> | 
 | If there were more commits on the <em>master</em> branch after the merge, the | 
 | merge commit itself would not be shown by <em>git show-branch</em> by | 
 | default.  You would need to provide <code>--sparse</code> option to make the | 
 | merge commit visible in this case. | 
 | </td> | 
 | </tr> | 
 | </table> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Now, let’s pretend you are the one who did all the work in | 
 | <code>mybranch</code>, and the fruit of your hard work has finally been merged | 
 | to the <code>master</code> branch. Let’s go back to <code>mybranch</code>, and run | 
 | <em>git merge</em> to get the "upstream changes" back to your branch.</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git switch mybranch | 
 | $ git merge -m "Merge upstream changes." master</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>This outputs something like this (the actual commit object names | 
 | would be different)</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>Updating from ae3a2da... to a80b4aa.... | 
 | Fast-forward (no commit created; -m option ignored) | 
 |  example | 1 + | 
 |  hello   | 1 + | 
 |  2 files changed, 2 insertions(+)</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Because your branch did not contain anything more than what had | 
 | already been merged into the <code>master</code> branch, the merge operation did | 
 | not actually do a merge. Instead, it just updated the top of | 
 | the tree of your branch to that of the <code>master</code> branch. This is | 
 | often called <em>fast-forward</em> merge.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>You can run <code>gitk</code> <code>--all</code> again to see how the commit ancestry | 
 | looks like, or run <em>show-branch</em>, which tells you this.</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git show-branch master mybranch | 
 | ! [master] Merge work in mybranch | 
 |  * [mybranch] Merge work in mybranch | 
 | -- | 
 | -- [master] Merge work in mybranch</pre> | 
 | </div> | 
 | </div> | 
 | </div> | 
 | </div> | 
 | <div class="sect1"> | 
 | <h2 id="_merging_external_work">Merging external work</h2> | 
 | <div class="sectionbody"> | 
 | <div class="paragraph"> | 
 | <p>It’s usually much more common that you merge with somebody else than | 
 | merging with your own branches, so it’s worth pointing out that Git | 
 | makes that very easy too, and in fact, it’s not that different from | 
 | doing a <em>git merge</em>. In fact, a remote merge ends up being nothing | 
 | more than "fetch the work from a remote repository into a temporary tag" | 
 | followed by a <em>git merge</em>.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Fetching from a remote repository is done by, unsurprisingly, | 
 | <em>git fetch</em>:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git fetch <remote-repository></pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>One of the following transports can be used to name the | 
 | repository to download from:</p> | 
 | </div> | 
 | <div class="dlist"> | 
 | <dl> | 
 | <dt class="hdlist1">SSH</dt> | 
 | <dd> | 
 | <p><code>remote.machine:/path/to/repo.git/</code> or</p> | 
 | <div class="paragraph"> | 
 | <p><code>ssh://remote.machine/path/to/repo.git/</code></p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>This transport can be used for both uploading and downloading, | 
 | and requires you to have a log-in privilege over <code>ssh</code> to the | 
 | remote machine.  It finds out the set of objects the other side | 
 | lacks by exchanging the head commits both ends have and | 
 | transfers (close to) minimum set of objects.  It is by far the | 
 | most efficient way to exchange Git objects between repositories.</p> | 
 | </div> | 
 | </dd> | 
 | <dt class="hdlist1">Local directory</dt> | 
 | <dd> | 
 | <p><code>/path/to/repo.git/</code></p> | 
 | <div class="paragraph"> | 
 | <p>This transport is the same as SSH transport but uses <em>sh</em> to run | 
 | both ends on the local machine instead of running other end on | 
 | the remote machine via <em>ssh</em>.</p> | 
 | </div> | 
 | </dd> | 
 | <dt class="hdlist1">Git Native</dt> | 
 | <dd> | 
 | <p><code>git://remote.machine/path/to/repo.git/</code></p> | 
 | <div class="paragraph"> | 
 | <p>This transport was designed for anonymous downloading.  Like SSH | 
 | transport, it finds out the set of objects the downstream side | 
 | lacks and transfers (close to) minimum set of objects.</p> | 
 | </div> | 
 | </dd> | 
 | <dt class="hdlist1">HTTP(S)</dt> | 
 | <dd> | 
 | <p><code>http://remote.machine/path/to/repo.git/</code></p> | 
 | <div class="paragraph"> | 
 | <p>Downloader from http and https URL | 
 | first obtains the topmost commit object name from the remote site | 
 | by looking at the specified refname under <code>repo.git/refs/</code> directory, | 
 | and then tries to obtain the | 
 | commit object by downloading from <code>repo.git/objects/xx/xxx..</code>. | 
 | using the object name of that commit object.  Then it reads the | 
 | commit object to find out its parent commits and the associate | 
 | tree object; it repeats this process until it gets all the | 
 | necessary objects.  Because of this behavior, they are | 
 | sometimes also called <em>commit walkers</em>.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>The <em>commit walkers</em> are sometimes also called <em>dumb | 
 | transports</em>, because they do not require any Git aware smart | 
 | server like Git Native transport does.  Any stock HTTP server | 
 | that does not even support directory index would suffice.  But | 
 | you must prepare your repository with <em>git update-server-info</em> | 
 | to help dumb transport downloaders.</p> | 
 | </div> | 
 | </dd> | 
 | </dl> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Once you fetch from the remote repository, you <code>merge</code> that | 
 | with your current branch.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>However — it’s such a common thing to <code>fetch</code> and then | 
 | immediately <code>merge</code>, that it’s called <code>git</code> <code>pull</code>, and you can | 
 | simply do</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git pull <remote-repository></pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>and optionally give a branch-name for the remote end as a second | 
 | argument.</p> | 
 | </div> | 
 | <div class="admonitionblock note"> | 
 | <table> | 
 | <tr> | 
 | <td class="icon"> | 
 | <div class="title">Note</div> | 
 | </td> | 
 | <td class="content"> | 
 | You could do without using any branches at all, by | 
 | keeping as many local repositories as you would like to have | 
 | branches, and merging between them with <em>git pull</em>, just like | 
 | you merge between branches. The advantage of this approach is | 
 | that it lets you keep a set of files for each <code>branch</code> checked | 
 | out and you may find it easier to switch back and forth if you | 
 | juggle multiple lines of development simultaneously. Of | 
 | course, you will pay the price of more disk usage to hold | 
 | multiple working trees, but disk space is cheap these days. | 
 | </td> | 
 | </tr> | 
 | </table> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>It is likely that you will be pulling from the same remote | 
 | repository from time to time. As a short hand, you can store | 
 | the remote repository URL in the local repository’s config file | 
 | like this:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git config remote.linus.url https://git.kernel.org/pub/scm/git/git.git/</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>and use the "linus" keyword with <em>git pull</em> instead of the full URL.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Examples.</p> | 
 | </div> | 
 | <div class="olist arabic"> | 
 | <ol class="arabic"> | 
 | <li> | 
 | <p><code>git</code> <code>pull</code> <code>linus</code></p> | 
 | </li> | 
 | <li> | 
 | <p><code>git</code> <code>pull</code> <code>linus</code> <code>tag</code> <code>v0.99.1</code></p> | 
 | </li> | 
 | </ol> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>the above are equivalent to:</p> | 
 | </div> | 
 | <div class="olist arabic"> | 
 | <ol class="arabic"> | 
 | <li> | 
 | <p><code>git</code> <code>pull</code> <code>http://www.kernel.org/pub/scm/git/git.git/</code> <code>HEAD</code></p> | 
 | </li> | 
 | <li> | 
 | <p><code>git</code> <code>pull</code> <code>http://www.kernel.org/pub/scm/git/git.git/</code> <code>tag</code> <code>v0.99.1</code></p> | 
 | </li> | 
 | </ol> | 
 | </div> | 
 | </div> | 
 | </div> | 
 | <div class="sect1"> | 
 | <h2 id="_how_does_the_merge_work">How does the merge work?</h2> | 
 | <div class="sectionbody"> | 
 | <div class="paragraph"> | 
 | <p>We said this tutorial shows what plumbing does to help you cope | 
 | with the porcelain that isn’t flushing, but we so far did not | 
 | talk about how the merge really works.  If you are following | 
 | this tutorial the first time, I’d suggest to skip to "Publishing | 
 | your work" section and come back here later.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>OK, still with me?  To give us an example to look at, let’s go | 
 | back to the earlier repository with "hello" and "example" file, | 
 | and bring ourselves back to the pre-merge state:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git show-branch --more=2 master mybranch | 
 | ! [master] Merge work in mybranch | 
 |  * [mybranch] Merge work in mybranch | 
 | -- | 
 | -- [master] Merge work in mybranch | 
 | +* [master^2] Some work. | 
 | +* [master^] Some fun.</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Remember, before running <em>git merge</em>, our <code>master</code> head was at | 
 | "Some fun." commit, while our <code>mybranch</code> head was at "Some | 
 | work." commit.</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git switch -C mybranch master^2 | 
 | $ git switch master | 
 | $ git reset --hard master^</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>After rewinding, the commit structure should look like this:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git show-branch | 
 | * [master] Some fun. | 
 |  ! [mybranch] Some work. | 
 | -- | 
 | *  [master] Some fun. | 
 |  + [mybranch] Some work. | 
 | *+ [master^] Initial commit</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Now we are ready to experiment with the merge by hand.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p><code>git</code> <code>merge</code> command, when merging two branches, uses 3-way merge | 
 | algorithm.  First, it finds the common ancestor between them. | 
 | The command it uses is <em>git merge-base</em>:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ mb=$(git merge-base HEAD mybranch)</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>The command writes the commit object name of the common ancestor | 
 | to the standard output, so we captured its output to a variable, | 
 | because we will be using it in the next step.  By the way, the common | 
 | ancestor commit is the "Initial commit" commit in this case.  You can | 
 | tell it by:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git name-rev --name-only --tags $mb | 
 | my-first-tag</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>After finding out a common ancestor commit, the second step is | 
 | this:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git read-tree -m -u $mb HEAD mybranch</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>This is the same <em>git read-tree</em> command we have already seen, | 
 | but it takes three trees, unlike previous examples.  This reads | 
 | the contents of each tree into different <em>stage</em> in the index | 
 | file (the first tree goes to stage 1, the second to stage 2, | 
 | etc.).  After reading three trees into three stages, the paths | 
 | that are the same in all three stages are <em>collapsed</em> into stage | 
 | 0.  Also paths that are the same in two of three stages are | 
 | collapsed into stage 0, taking the SHA-1 from either stage 2 or | 
 | stage 3, whichever is different from stage 1 (i.e. only one side | 
 | changed from the common ancestor).</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>After <em>collapsing</em> operation, paths that are different in three | 
 | trees are left in non-zero stages.  At this point, you can | 
 | inspect the index file with this command:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git ls-files --stage | 
 | 100644 7f8b141b65fdcee47321e399a2598a235a032422 0       example | 
 | 100644 557db03de997c86a4a028e1ebd3a1ceb225be238 1       hello | 
 | 100644 ba42a2a96e3027f3333e13ede4ccf4498c3ae942 2       hello | 
 | 100644 cc44c73eb783565da5831b4d820c962954019b69 3       hello</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>In our example of only two files, we did not have unchanged | 
 | files so only <em>example</em> resulted in collapsing.  But in real-life | 
 | large projects, when only a small number of files change in one commit, | 
 | this <em>collapsing</em> tends to trivially merge most of the paths | 
 | fairly quickly, leaving only a handful of real changes in non-zero | 
 | stages.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>To look at only non-zero stages, use <code>--unmerged</code> flag:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git ls-files --unmerged | 
 | 100644 557db03de997c86a4a028e1ebd3a1ceb225be238 1       hello | 
 | 100644 ba42a2a96e3027f3333e13ede4ccf4498c3ae942 2       hello | 
 | 100644 cc44c73eb783565da5831b4d820c962954019b69 3       hello</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>The next step of merging is to merge these three versions of the | 
 | file, using 3-way merge.  This is done by giving | 
 | <em>git merge-one-file</em> command as one of the arguments to | 
 | <em>git merge-index</em> command:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git merge-index git-merge-one-file hello | 
 | Auto-merging hello | 
 | ERROR: Merge conflict in hello | 
 | fatal: merge program failed</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p><em>git merge-one-file</em> script is called with parameters to | 
 | describe those three versions, and is responsible to leave the | 
 | merge results in the working tree. | 
 | It is a fairly straightforward shell script, and | 
 | eventually calls <em>merge</em> program from RCS suite to perform a | 
 | file-level 3-way merge.  In this case, <em>merge</em> detects | 
 | conflicts, and the merge result with conflict marks is left in | 
 | the working tree..  This can be seen if you run <code>ls-files</code> | 
 | <code>--stage</code> again at this point:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git ls-files --stage | 
 | 100644 7f8b141b65fdcee47321e399a2598a235a032422 0       example | 
 | 100644 557db03de997c86a4a028e1ebd3a1ceb225be238 1       hello | 
 | 100644 ba42a2a96e3027f3333e13ede4ccf4498c3ae942 2       hello | 
 | 100644 cc44c73eb783565da5831b4d820c962954019b69 3       hello</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>This is the state of the index file and the working file after | 
 | <em>git merge</em> returns control back to you, leaving the conflicting | 
 | merge for you to resolve.  Notice that the path <code>hello</code> is still | 
 | unmerged, and what you see with <em>git diff</em> at this point is | 
 | differences since stage 2 (i.e. your version).</p> | 
 | </div> | 
 | </div> | 
 | </div> | 
 | <div class="sect1"> | 
 | <h2 id="_publishing_your_work">Publishing your work</h2> | 
 | <div class="sectionbody"> | 
 | <div class="paragraph"> | 
 | <p>So, we can use somebody else’s work from a remote repository, but | 
 | how can <strong>you</strong> prepare a repository to let other people pull from | 
 | it?</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>You do your real work in your working tree that has your | 
 | primary repository hanging under it as its .<code>git</code> subdirectory. | 
 | You <strong>could</strong> make that repository accessible remotely and ask | 
 | people to pull from it, but in practice that is not the way | 
 | things are usually done. A recommended way is to have a public | 
 | repository, make it reachable by other people, and when the | 
 | changes you made in your primary working tree are in good shape, | 
 | update the public repository from it. This is often called | 
 | <em>pushing</em>.</p> | 
 | </div> | 
 | <div class="admonitionblock note"> | 
 | <table> | 
 | <tr> | 
 | <td class="icon"> | 
 | <div class="title">Note</div> | 
 | </td> | 
 | <td class="content"> | 
 | This public repository could further be mirrored, and that is | 
 | how Git repositories at <code>kernel.org</code> are managed. | 
 | </td> | 
 | </tr> | 
 | </table> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Publishing the changes from your local (private) repository to | 
 | your remote (public) repository requires a write privilege on | 
 | the remote machine. You need to have an SSH account there to | 
 | run a single command, <em>git-receive-pack</em>.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>First, you need to create an empty repository on the remote | 
 | machine that will house your public repository. This empty | 
 | repository will be populated and be kept up to date by pushing | 
 | into it later. Obviously, this repository creation needs to be | 
 | done only once.</p> | 
 | </div> | 
 | <div class="admonitionblock note"> | 
 | <table> | 
 | <tr> | 
 | <td class="icon"> | 
 | <div class="title">Note</div> | 
 | </td> | 
 | <td class="content"> | 
 | <em>git push</em> uses a pair of commands, | 
 | <em>git send-pack</em> on your local machine, and <em>git-receive-pack</em> | 
 | on the remote machine. The communication between the two over | 
 | the network internally uses an SSH connection. | 
 | </td> | 
 | </tr> | 
 | </table> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Your private repository’s Git directory is usually .<code>git</code>, but | 
 | your public repository is often named after the project name, | 
 | i.e. <em><project></em><code>.git</code>. Let’s create such a public repository for | 
 | project <code>my-git</code>. After logging into the remote machine, create | 
 | an empty directory:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ mkdir my-git.git</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Then, make that directory into a Git repository by running | 
 | <em>git init</em>, but this time, since its name is not the usual | 
 | .<code>git</code>, we do things slightly differently:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ GIT_DIR=my-git.git git init</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Make sure this directory is available for others you want your | 
 | changes to be pulled via the transport of your choice. Also | 
 | you need to make sure that you have the <em>git-receive-pack</em> | 
 | program on the <code>$PATH</code>.</p> | 
 | </div> | 
 | <div class="admonitionblock note"> | 
 | <table> | 
 | <tr> | 
 | <td class="icon"> | 
 | <div class="title">Note</div> | 
 | </td> | 
 | <td class="content"> | 
 | Many installations of sshd do not invoke your shell as the login | 
 | shell when you directly run programs; what this means is that if | 
 | your login shell is <em>bash</em>, only .<code>bashrc</code> is read and not | 
 | .<code>bash_profile</code>. As a workaround, make sure .<code>bashrc</code> sets up | 
 | <code>$PATH</code> so that you can run <em>git-receive-pack</em> program. | 
 | </td> | 
 | </tr> | 
 | </table> | 
 | </div> | 
 | <div class="admonitionblock note"> | 
 | <table> | 
 | <tr> | 
 | <td class="icon"> | 
 | <div class="title">Note</div> | 
 | </td> | 
 | <td class="content"> | 
 | If you plan to publish this repository to be accessed over http, | 
 | you should do <code>mv</code> <code>my-git.git/hooks/post-update.sample</code> | 
 | <code>my-git.git/hooks/post-update</code> at this point. | 
 | This makes sure that every time you push into this | 
 | repository, <code>git</code> <code>update-server-info</code> is run. | 
 | </td> | 
 | </tr> | 
 | </table> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Your "public repository" is now ready to accept your changes. | 
 | Come back to the machine you have your private repository. From | 
 | there, run this command:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git push <public-host>:/path/to/my-git.git master</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>This synchronizes your public repository to match the named | 
 | branch head (i.e. <code>master</code> in this case) and objects reachable | 
 | from them in your current repository.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>As a real example, this is how I update my public Git | 
 | repository. Kernel.org mirror network takes care of the | 
 | propagation to other publicly visible machines:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git push master.kernel.org:/pub/scm/git/git.git/</pre> | 
 | </div> | 
 | </div> | 
 | </div> | 
 | </div> | 
 | <div class="sect1"> | 
 | <h2 id="_packing_your_repository">Packing your repository</h2> | 
 | <div class="sectionbody"> | 
 | <div class="paragraph"> | 
 | <p>Earlier, we saw that one file under .<code>git/objects/</code>??/ directory | 
 | is stored for each Git object you create. This representation | 
 | is efficient to create atomically and safely, but | 
 | not so convenient to transport over the network. Since Git objects are | 
 | immutable once they are created, there is a way to optimize the | 
 | storage by "packing them together". The command</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git repack</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>will do it for you. If you followed the tutorial examples, you | 
 | would have accumulated about 17 objects in .<code>git/objects/</code>??/ | 
 | directories by now. <em>git repack</em> tells you how many objects it | 
 | packed, and stores the packed file in the .<code>git/objects/pack</code> | 
 | directory.</p> | 
 | </div> | 
 | <div class="admonitionblock note"> | 
 | <table> | 
 | <tr> | 
 | <td class="icon"> | 
 | <div class="title">Note</div> | 
 | </td> | 
 | <td class="content"> | 
 | You will see two files, <code>pack-*.pack</code> and <code>pack-*.idx</code>, | 
 | in .<code>git/objects/pack</code> directory. They are closely related to | 
 | each other, and if you ever copy them by hand to a different | 
 | repository for whatever reason, you should make sure you copy | 
 | them together. The former holds all the data from the objects | 
 | in the pack, and the latter holds the index for random | 
 | access. | 
 | </td> | 
 | </tr> | 
 | </table> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>If you are paranoid, running <em>git verify-pack</em> command would | 
 | detect if you have a corrupt pack, but do not worry too much. | 
 | Our programs are always perfect ;-).</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Once you have packed objects, you do not need to leave the | 
 | unpacked objects that are contained in the pack file anymore.</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git prune-packed</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>would remove them for you.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>You can try running <code>find</code> <code>.git/objects</code> <code>-type</code> <code>f</code> before and after | 
 | you run <code>git</code> <code>prune-packed</code> if you are curious.  Also <code>git</code> | 
 | <code>count-objects</code> would tell you how many unpacked objects are in | 
 | your repository and how much space they are consuming.</p> | 
 | </div> | 
 | <div class="admonitionblock note"> | 
 | <table> | 
 | <tr> | 
 | <td class="icon"> | 
 | <div class="title">Note</div> | 
 | </td> | 
 | <td class="content"> | 
 | <code>git</code> <code>pull</code> is slightly cumbersome for HTTP transport, as a | 
 | packed repository may contain relatively few objects in a | 
 | relatively large pack. If you expect many HTTP pulls from your | 
 | public repository you might want to repack & prune often, or | 
 | never. | 
 | </td> | 
 | </tr> | 
 | </table> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>If you run <code>git</code> <code>repack</code> again at this point, it will say | 
 | "Nothing new to pack.". Once you continue your development and | 
 | accumulate the changes, running <code>git</code> <code>repack</code> again will create a | 
 | new pack, that contains objects created since you packed your | 
 | repository the last time. We recommend that you pack your project | 
 | soon after the initial import (unless you are starting your | 
 | project from scratch), and then run <code>git</code> <code>repack</code> every once in a | 
 | while, depending on how active your project is.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>When a repository is synchronized via <code>git</code> <code>push</code> and <code>git</code> <code>pull</code> | 
 | objects packed in the source repository are usually stored | 
 | unpacked in the destination. | 
 | While this allows you to use different packing strategies on | 
 | both ends, it also means you may need to repack both | 
 | repositories every once in a while.</p> | 
 | </div> | 
 | </div> | 
 | </div> | 
 | <div class="sect1"> | 
 | <h2 id="_working_with_others">Working with Others</h2> | 
 | <div class="sectionbody"> | 
 | <div class="paragraph"> | 
 | <p>Although Git is a truly distributed system, it is often | 
 | convenient to organize your project with an informal hierarchy | 
 | of developers. Linux kernel development is run this way. There | 
 | is a nice illustration (page 17, "Merges to Mainline") in | 
 | <a href="https://web.archive.org/web/20120915203609/http://www.xenotime.net/linux/mentor/linux-mentoring-2006.pdf">Randy Dunlap’s presentation</a>.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>It should be stressed that this hierarchy is purely <strong>informal</strong>. | 
 | There is nothing fundamental in Git that enforces the "chain of | 
 | patch flow" this hierarchy implies. You do not have to pull | 
 | from only one remote repository.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>A recommended workflow for a "project lead" goes like this:</p> | 
 | </div> | 
 | <div class="olist arabic"> | 
 | <ol class="arabic"> | 
 | <li> | 
 | <p>Prepare your primary repository on your local machine. Your | 
 | work is done there.</p> | 
 | </li> | 
 | <li> | 
 | <p>Prepare a public repository accessible to others.</p> | 
 | <div class="paragraph"> | 
 | <p>If other people are pulling from your repository over dumb | 
 | transport protocols (HTTP), you need to keep this repository | 
 | <em>dumb transport friendly</em>.  After <code>git</code> <code>init</code>, | 
 | <code>$GIT_DIR/hooks/post-update.sample</code> copied from the standard templates | 
 | would contain a call to <em>git update-server-info</em> | 
 | but you need to manually enable the hook with | 
 | <code>mv</code> <code>post-update.sample</code> <code>post-update</code>.  This makes sure | 
 | <em>git update-server-info</em> keeps the necessary files up to date.</p> | 
 | </div> | 
 | </li> | 
 | <li> | 
 | <p>Push into the public repository from your primary | 
 | repository.</p> | 
 | </li> | 
 | <li> | 
 | <p><em>git repack</em> the public repository. This establishes a big | 
 | pack that contains the initial set of objects as the | 
 | baseline, and possibly <em>git prune</em> if the transport | 
 | used for pulling from your repository supports packed | 
 | repositories.</p> | 
 | </li> | 
 | <li> | 
 | <p>Keep working in your primary repository. Your changes | 
 | include modifications of your own, patches you receive via | 
 | e-mails, and merges resulting from pulling the "public" | 
 | repositories of your "subsystem maintainers".</p> | 
 | <div class="paragraph"> | 
 | <p>You can repack this private repository whenever you feel like.</p> | 
 | </div> | 
 | </li> | 
 | <li> | 
 | <p>Push your changes to the public repository, and announce it | 
 | to the public.</p> | 
 | </li> | 
 | <li> | 
 | <p>Every once in a while, <em>git repack</em> the public repository. | 
 | Go back to step 5. and continue working.</p> | 
 | </li> | 
 | </ol> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>A recommended work cycle for a "subsystem maintainer" who works | 
 | on that project and has an own "public repository" goes like this:</p> | 
 | </div> | 
 | <div class="olist arabic"> | 
 | <ol class="arabic"> | 
 | <li> | 
 | <p>Prepare your work repository, by running <em>git clone</em> on the public | 
 | repository of the "project lead". The URL used for the | 
 | initial cloning is stored in the remote.origin.url | 
 | configuration variable.</p> | 
 | </li> | 
 | <li> | 
 | <p>Prepare a public repository accessible to others, just like | 
 | the "project lead" person does.</p> | 
 | </li> | 
 | <li> | 
 | <p>Copy over the packed files from "project lead" public | 
 | repository to your public repository, unless the "project | 
 | lead" repository lives on the same machine as yours.  In the | 
 | latter case, you can use <code>objects/info/alternates</code> file to | 
 | point at the repository you are borrowing from.</p> | 
 | </li> | 
 | <li> | 
 | <p>Push into the public repository from your primary | 
 | repository. Run <em>git repack</em>, and possibly <em>git prune</em> if the | 
 | transport used for pulling from your repository supports | 
 | packed repositories.</p> | 
 | </li> | 
 | <li> | 
 | <p>Keep working in your primary repository. Your changes | 
 | include modifications of your own, patches you receive via | 
 | e-mails, and merges resulting from pulling the "public" | 
 | repositories of your "project lead" and possibly your | 
 | "sub-subsystem maintainers".</p> | 
 | <div class="paragraph"> | 
 | <p>You can repack this private repository whenever you feel | 
 | like.</p> | 
 | </div> | 
 | </li> | 
 | <li> | 
 | <p>Push your changes to your public repository, and ask your | 
 | "project lead" and possibly your "sub-subsystem | 
 | maintainers" to pull from it.</p> | 
 | </li> | 
 | <li> | 
 | <p>Every once in a while, <em>git repack</em> the public repository. | 
 | Go back to step 5. and continue working.</p> | 
 | </li> | 
 | </ol> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>A recommended work cycle for an "individual developer" who does | 
 | not have a "public" repository is somewhat different. It goes | 
 | like this:</p> | 
 | </div> | 
 | <div class="olist arabic"> | 
 | <ol class="arabic"> | 
 | <li> | 
 | <p>Prepare your work repository, by <em>git clone</em> the public | 
 | repository of the "project lead" (or a "subsystem | 
 | maintainer", if you work on a subsystem). The URL used for | 
 | the initial cloning is stored in the remote.origin.url | 
 | configuration variable.</p> | 
 | </li> | 
 | <li> | 
 | <p>Do your work in your repository on <em>master</em> branch.</p> | 
 | </li> | 
 | <li> | 
 | <p>Run <code>git</code> <code>fetch</code> <code>origin</code> from the public repository of your | 
 | upstream every once in a while. This does only the first | 
 | half of <code>git</code> <code>pull</code> but does not merge. The head of the | 
 | public repository is stored in .<code>git/refs/remotes/origin/master</code>.</p> | 
 | </li> | 
 | <li> | 
 | <p>Use <code>git</code> <code>cherry</code> <code>origin</code> to see which ones of your patches | 
 | were accepted, and/or use <code>git</code> <code>rebase</code> <code>origin</code> to port your | 
 | unmerged changes forward to the updated upstream.</p> | 
 | </li> | 
 | <li> | 
 | <p>Use <code>git</code> <code>format-patch</code> <code>origin</code> to prepare patches for e-mail | 
 | submission to your upstream and send it out. Go back to | 
 | step 2. and continue.</p> | 
 | </li> | 
 | </ol> | 
 | </div> | 
 | </div> | 
 | </div> | 
 | <div class="sect1"> | 
 | <h2 id="_working_with_others_shared_repository_style">Working with Others, Shared Repository Style</h2> | 
 | <div class="sectionbody"> | 
 | <div class="paragraph"> | 
 | <p>If you are coming from a CVS background, the style of cooperation | 
 | suggested in the previous section may be new to you. You do not | 
 | have to worry. Git supports the "shared public repository" style of | 
 | cooperation you are probably more familiar with as well.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>See <a href="gitcvs-migration.html">gitcvs-migration(7)</a> for the details.</p> | 
 | </div> | 
 | </div> | 
 | </div> | 
 | <div class="sect1"> | 
 | <h2 id="_bundling_your_work_together">Bundling your work together</h2> | 
 | <div class="sectionbody"> | 
 | <div class="paragraph"> | 
 | <p>It is likely that you will be working on more than one thing at | 
 | a time.  It is easy to manage those more-or-less independent tasks | 
 | using branches with Git.</p> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>We have already seen how branches work previously, | 
 | with "fun and work" example using two branches.  The idea is the | 
 | same if there are more than two branches.  Let’s say you started | 
 | out from "master" head, and have some new code in the "master" | 
 | branch, and two independent fixes in the "commit-fix" and | 
 | "diff-fix" branches:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git show-branch | 
 | ! [commit-fix] Fix commit message normalization. | 
 |  ! [diff-fix] Fix rename detection. | 
 |   * [master] Release candidate #1 | 
 | --- | 
 |  +  [diff-fix] Fix rename detection. | 
 |  +  [diff-fix~1] Better common substring algorithm. | 
 | +   [commit-fix] Fix commit message normalization. | 
 |   * [master] Release candidate #1 | 
 | ++* [diff-fix~2] Pretty-print messages.</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Both fixes are tested well, and at this point, you want to merge | 
 | in both of them.  You could merge in <em>diff-fix</em> first and then | 
 | <em>commit-fix</em> next, like this:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git merge -m "Merge fix in diff-fix" diff-fix | 
 | $ git merge -m "Merge fix in commit-fix" commit-fix</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Which would result in:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git show-branch | 
 | ! [commit-fix] Fix commit message normalization. | 
 |  ! [diff-fix] Fix rename detection. | 
 |   * [master] Merge fix in commit-fix | 
 | --- | 
 |   - [master] Merge fix in commit-fix | 
 | + * [commit-fix] Fix commit message normalization. | 
 |   - [master~1] Merge fix in diff-fix | 
 |  +* [diff-fix] Fix rename detection. | 
 |  +* [diff-fix~1] Better common substring algorithm. | 
 |   * [master~2] Release candidate #1 | 
 | ++* [master~3] Pretty-print messages.</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>However, there is no particular reason to merge in one branch | 
 | first and the other next, when what you have are a set of truly | 
 | independent changes (if the order mattered, then they are not | 
 | independent by definition).  You could instead merge those two | 
 | branches into the current branch at once.  First let’s undo what | 
 | we just did and start over.  We would want to get the master | 
 | branch before these two merges by resetting it to <em>master~2</em>:</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git reset --hard master~2</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>You can make sure <code>git</code> <code>show-branch</code> matches the state before | 
 | those two <em>git merge</em> you just did.  Then, instead of running | 
 | two <em>git merge</em> commands in a row, you would merge these two | 
 | branch heads (this is known as <em>making an Octopus</em>):</p> | 
 | </div> | 
 | <div class="listingblock"> | 
 | <div class="content"> | 
 | <pre>$ git merge commit-fix diff-fix | 
 | $ git show-branch | 
 | ! [commit-fix] Fix commit message normalization. | 
 |  ! [diff-fix] Fix rename detection. | 
 |   * [master] Octopus merge of branches 'diff-fix' and 'commit-fix' | 
 | --- | 
 |   - [master] Octopus merge of branches 'diff-fix' and 'commit-fix' | 
 | + * [commit-fix] Fix commit message normalization. | 
 |  +* [diff-fix] Fix rename detection. | 
 |  +* [diff-fix~1] Better common substring algorithm. | 
 |   * [master~1] Release candidate #1 | 
 | ++* [master~2] Pretty-print messages.</pre> | 
 | </div> | 
 | </div> | 
 | <div class="paragraph"> | 
 | <p>Note that you should not do Octopus just because you can.  An octopus | 
 | is a valid thing to do and often makes it easier to view the | 
 | commit history if you are merging more than two independent | 
 | changes at the same time.  However, if you have merge conflicts | 
 | with any of the branches you are merging in and need to hand | 
 | resolve, that is an indication that the development happened in | 
 | those branches were not independent after all, and you should | 
 | merge two at a time, documenting how you resolved the conflicts, | 
 | and the reason why you preferred changes made in one side over | 
 | the other.  Otherwise it would make the project history harder | 
 | to follow, not easier.</p> | 
 | </div> | 
 | </div> | 
 | </div> | 
 | <div class="sect1"> | 
 | <h2 id="_see_also">SEE ALSO</h2> | 
 | <div class="sectionbody"> | 
 | <div class="paragraph"> | 
 | <p><a href="gittutorial.html">gittutorial(7)</a>, | 
 | <a href="gittutorial-2.html">gittutorial-2(7)</a>, | 
 | <a href="gitcvs-migration.html">gitcvs-migration(7)</a>, | 
 | <a href="git-help.html">git-help(1)</a>, | 
 | <a href="giteveryday.html">giteveryday(7)</a>, | 
 | <a href="user-manual.html">The Git User’s Manual</a></p> | 
 | </div> | 
 | </div> | 
 | </div> | 
 | <div class="sect1"> | 
 | <h2 id="_git">GIT</h2> | 
 | <div class="sectionbody"> | 
 | <div class="paragraph"> | 
 | <p>Part of the <a href="git.html">git(1)</a> suite</p> | 
 | </div> | 
 | </div> | 
 | </div> | 
 | </div> | 
 | <div id="footer"> | 
 | <div id="footer-text"> | 
 | Last updated 2025-06-20 18:10:42 -0700 | 
 | </div> | 
 | </div> | 
 | </body> | 
 | </html> |