Brief git Cheat Sheet

Brief git Cheat Sheet

quick start with Git

Tutorials

2020.04.02

0 #git #scss #sass

                        <h2 id="install-git">Install Git</h2>

<p>Git distributions for all platforms are available on the official Git SCM (Software Configuration Management) web site - <a href="https://git-scm.com">https://git-scm.com</a>.</p>

<h2 id="configure-tooling">Configure tooling</h2>

<p>Configure user information for all local repositories.</p>

<div class="language-sh highlighter-rouge"><div class="highlight"><pre class="highlight"><code>git config <span class="nt">--global</span> user.name <span class="s2">"[name]"</span>
<span class="c"># sets the name you want attached to your commit transactions</span>
</code></pre></div></div>

<div class="language-sh highlighter-rouge"><div class="highlight"><pre class="highlight"><code>git config <span class="nt">--global</span> user.email <span class="s2">"[email address]"</span>
<span class="c"># sets the email you want attached to your commit transactions</span>
</code></pre></div></div>

<div class="language-sh highlighter-rouge"><div class="highlight"><pre class="highlight"><code>git config <span class="nt">--global</span> color.ui auto
<span class="c"># enables helpful colorization of command line output</span>
</code></pre></div></div>

<h2 id="create-repositories">Create repositories</h2>

<p>When starting out with a new repository, you only need to do it once; either locally, then push to Git host sites, or by cloning an existing repository.</p>

<div class="language-sh highlighter-rouge"><div class="highlight"><pre class="highlight"><code>git init
<span class="c"># turn an existing directory into a git repository</span>
</code></pre></div></div>

<div class="language-sh highlighter-rouge"><div class="highlight"><pre class="highlight"><code>git clone <span class="o">[</span>url]
<span class="c"># clone (download) a repository that already exists on Git host sites,</span>
<span class="c"># including all of the files, branches, and commits</span>
</code></pre></div></div>

<h2 id="branches">Branches</h2>

<p>Branches are an important part of working with Git. Any commits you make will be made on the branch you’re currently “checked out” to. Use <code class="language-plaintext highlighter-rouge">git status</code> to see which branch that is.</p>

<div class="language-sh highlighter-rouge"><div class="highlight"><pre class="highlight"><code>git branch <span class="o">[</span>branch-name]
<span class="c"># creates a new branch</span>
</code></pre></div></div>

<div class="language-sh highlighter-rouge"><div class="highlight"><pre class="highlight"><code>git checkout <span class="o">[</span>branch-name]
<span class="c"># switches to the specified branch and updates the working directory</span>
</code></pre></div></div>

<div class="language-sh highlighter-rouge"><div class="highlight"><pre class="highlight"><code>git merge <span class="o">[</span>branch]
<span class="c"># combines the specified branch's history into the current branch</span>
<span class="c"># this is usually done in pull requests, but is an important Git operation</span>
</code></pre></div></div>

<div class="language-sh highlighter-rouge"><div class="highlight"><pre class="highlight"><code>git branch <span class="nt">-d</span> <span class="o">[</span>branch-name]
<span class="c"># deletes the specified branch</span>
</code></pre></div></div>

<h2 id="the-gitignore-file">The .gitignore file</h2>

<p>Sometimes it may be a good idea to exclude files from being tracked with Git. This is typically done in a special file named <code class="language-plaintext highlighter-rouge">.gitignore</code>. You can find help templates for <code class="language-plaintext highlighter-rouge">.gitignore</code> files at <a href="https://github.com/github/gitignore">https://github.com/github/gitignore</a> for different projects.</p>

<h2 id="synchronize-changes">Synchronize changes</h2>

<p>Synchronize your local repository with the remote repository on Git host sites.</p>

<div class="language-sh highlighter-rouge"><div class="highlight"><pre class="highlight"><code>git fetch
<span class="c"># downloads all history from the remote tracking branches</span>
</code></pre></div></div>

<div class="language-sh highlighter-rouge"><div class="highlight"><pre class="highlight"><code>git merge
<span class="c"># combines remote tracking branch into current local branch</span>
</code></pre></div></div>

<div class="language-sh highlighter-rouge"><div class="highlight"><pre class="highlight"><code>git push
<span class="c"># uploads all local branch commits to Git host sites</span>
</code></pre></div></div>

<div class="language-sh highlighter-rouge"><div class="highlight"><pre class="highlight"><code>git pull
<span class="c"># updates your current local working branch</span>
<span class="c"># with all new commits from the corresponding remote branch</span>
<span class="c"># 'git pull' is a combination of 'git fetch' &amp; 'git merge'</span>
</code></pre></div></div>

<h2 id="make-changes">Make changes</h2>

<p>Browse and inspect the evolution of project files.</p>

<div class="language-sh highlighter-rouge"><div class="highlight"><pre class="highlight"><code>git log
<span class="c"># lists version history of the current branch</span>
</code></pre></div></div>

<div class="language-sh highlighter-rouge"><div class="highlight"><pre class="highlight"><code>git log <span class="nt">--follow</span> <span class="o">[</span>file]
<span class="c"># lists version history for a file, including renames</span>
</code></pre></div></div>

<div class="language-sh highlighter-rouge"><div class="highlight"><pre class="highlight"><code>git diff <span class="o">[</span>first-branch]...[second-branch]
<span class="c"># shows content differences between two branches</span>
</code></pre></div></div>

<div class="language-sh highlighter-rouge"><div class="highlight"><pre class="highlight"><code>git show <span class="o">[</span>commit]
<span class="c"># outputs metadata and content changes of the specified commit</span>
</code></pre></div></div>

<div class="language-sh highlighter-rouge"><div class="highlight"><pre class="highlight"><code>git add <span class="o">[</span>file]
<span class="c"># snapshots the file in preparation for versioning</span>
</code></pre></div></div>

<div class="language-sh highlighter-rouge"><div class="highlight"><pre class="highlight"><code>git commit <span class="nt">-m</span> <span class="s2">"[descriptive message]"</span>
<span class="c"># records file snapshots permanently in version history</span>
</code></pre></div></div>

<h2 id="redo-commits">Redo commits</h2>

<p>Erase mistakes and craft replacement history.</p>

<div class="language-sh highlighter-rouge"><div class="highlight"><pre class="highlight"><code>git reset <span class="o">[</span>commit]
<span class="c"># undoes all commits after [commit], preserving changes locally</span>
</code></pre></div></div>

<div class="language-sh highlighter-rouge"><div class="highlight"><pre class="highlight"><code>git reset <span class="nt">--hard</span> <span class="o">[</span>commit]
<span class="c"># discards all hostory and changes back to the specified commit</span>
</code></pre></div></div>

<p>CAUTION! Changing history can have nasty side effects. If you need to change commits that exist on remote Git host sites, proceed with caution.</p>

<p><img src="https://res.cloudinary.com/flinhong/image/upload/v1585795449/static/journal/git-flow.png" alt="Git Flow" /></p>

<h2 id="glossary">Glossary</h2>

<ul>
  <li><strong><em>git</em></strong>: an open source, distibuted version-control system</li>
  <li><strong><em>commit</em></strong>: a Git object, a snapshot of your entire repository compressed into a SHA</li>
  <li><strong><em>branch</em></strong>: a lightweight movable pointer to a commit</li>
  <li><strong><em>clone</em></strong>: a local version of a repository, including all commits and branches</li>
  <li><strong><em>remote</em></strong>: a common repository on Git host sites that all team member use to exchange their changes</li>
  <li><strong><em>fork</em></strong>: a copy of a repository on Git host sites that owned by a different user</li>
  <li><strong><em>pull request</em></strong>: a place to compare and discuss the differences introduced on a branch with reviews, comments, integrated tests, and more</li>
  <li><strong><em>HEAD</em></strong>: representing your current working directory, the HEAD pointer can be moved to different branches, tags, or commits when using <code class="language-plaintext highlighter-rouge">git checkout</code></li>
</ul>

                        
Ads by Google

林宏

Frank Lin

Hey, there! This is Frank Lin (@flinhong), one of the 1.4 billion 🇨🇳. This 'inDev. Journal' site holds the exploration of my quirky thoughts and random adventures through life. Hope you enjoy reading and perusing my posts.

YOU MAY ALSO LIKE

Setup an IKEv2 server with StrongSwan

Tutorials

2020.01.09

Setup an IKEv2 server with StrongSwan

IKEv2, or Internet Key Exchange v2, is a protocol that allows for direct IPSec tunneling between the server and client. In IKEv2 implementations, IPSec provides encryption for the network traffic. IKEv2 is natively supported on some platforms (OS X 10.11+, iOS 9.1+, and Windows 10) with no additional applications necessary, and it handles client hiccups quite smoothly.

Using Liquid in Jekyll - Live with Demos

Web Notes

2016.08.20

Using Liquid in Jekyll - Live with Demos

Liquid is a simple templating language that Jekyll uses to process pages on your site. With Liquid you can output an modify variables, have logic statements inside your pages and loop over content.

First taste of Heroku, h5ai for a file indexer

Tutorials

2017.04.20

First taste of Heroku, h5ai for a file indexer

I've known Heroku for a long time, but never have a try to build with it. This time, I found a beautiful file indexer, h5ai, that requires PHP 5.5+, and Heroku is a perfect platform to build and host it.