about summary refs log tree commit diff stats
path: root/dev/git.html
diff options
context:
space:
mode:
Diffstat (limited to 'dev/git.html')
-rw-r--r--dev/git.html204
1 files changed, 124 insertions, 80 deletions
diff --git a/dev/git.html b/dev/git.html
index fdae528..3e5f4c1 100644
--- a/dev/git.html
+++ b/dev/git.html
@@ -6,7 +6,7 @@
 </head>
 <body>
 
-    <a href="index.html">Dev Index</a>
+    <a href="index.html">Development Index</a>
     <h1>Git</h1>
 
     <p>First configure your global identity, configuration
@@ -34,45 +34,48 @@
         </li>
     </ul>
 
-    <h2 id="teamwork">Team WorkFlow</h2>
+    <pre>
+       $ git clone devbox:atom
+       $ git remote -v
+    </pre>
+
+    <h2 id="teamwork">1. Team WorkFlow</h2>
 
     <p>This work flow is based on
-    <a href="http://nvie.com/posts/a-successful-git-branching-model/">Vicent Driessen</a>,
+    <a href="http://nvie.com/posts/a-successful-git-branching-model/">Vicent Driessen</a>
     development model, it defines rules how branches are forked,
     merged and tagged. By having well defined set of branches,
     the project structure is used as a communication tool,
     allowing to work simultaneously on different stages
     of the development.</p>
 
-    <pre>
-       $ git clone devbox:atom
-       $ git remote -v
-    </pre>
-
-
-    <h3>Main Branches;</h3>
+    <p>Main Branches;</p>
 
     <dl>
         <dt>master</dt>
         <dd>Current official stable release history.</dd>
-        <dt>release</dt>
-        <dd>Next release, new features not allowed.</dd>
         <dt>develop</dt>
         <dd>Integration branch for features.</dd>
     </dl>
 
-    <h3>Add-on Branches;</h3>
+    <p>Add-on Branches;</p>
 
     <dl>
-        <dt>feature</dt>
+        <dt>feature (f-)</dt>
         <dd>New features, improvement proposal, tests, etc...</dd>
-        <dt>hotfix</dt>
-        <dd>Hotfix is branched of master and should only contain isolated bugfixes.</dd>
+        <dd>Only fork and merge from/to develop.
+        <dt>release (r-)</dt>
+        <dd>Next release, new features not allowed.</dd>
+        <dd>Fork from develop, merges to master and develop.</dd>
+        <dt>hotfix (h-)</dt>
+        <dd>Hotfix only contain isolated bugfixes.</dd>
+        <dd>Only fork from master, merges back to master and develop.</dd>
     </dl>
 
-    <h2 id="feature">Feature</h2>
+    <p>
+    <h3 id="feature">1.1. Feature</h3>
 
-    <p>Create a branch and checkout;</p>
+    <p>Create a branch featurex from develop and checkout;</p>
 
     <pre>
     $ git checkout -b featurex develop
@@ -84,52 +87,69 @@
     $ git push -u origin featurex
     </pre>
 
-    <p>Rename a branch;</p>
+    <p>Rename a branch, if all feature branches start by "f-" is easy
+    and quick to type and easy to spot;</p>
 
     <pre>
-        $ git branch -m featurex feature-x
+    $ git branch -m featurex f-xpto
     </pre>
 
     <p>Rename remote branch;</p>
 
     <pre>
-        $ git push origin :featurex feature-x
-        $ git push origin -u feature-x
+    $ git push origin :featurex f-xpto
+    $ git push origin -u f-xpto
     </pre>
 
     <p>Merge branch feature into develop;</p>
 
     <pre>
-       $ git checkout develop
-       Switched to branch 'develop'
-       $ git merge --no-ff feature-x
-       Updating ea1b82a..05e9557
-       (Summary of changes)
-       $ git push origin develop
+    $ git checkout develop
+    Switched to branch 'develop'
+    $ git merge --no-ff f-xpto
+    Updating ea1b82a..05e9557
+    (Summary of changes)
+    $ git push origin develop
     </pre>
 
     <p>Delete Local;</p>
 
     <pre>
-       $ git branch -D feature-x
+    $ git branch -D f-xpto
     </pre>
 
     <p>Delete Remote</p>
 
     <pre>
-       $ git push origin :feature-x
+    $ git push origin :f-xpto
     </pre>
 
-    <h2 id="release">Release</h2>
+    <h3 id="release">1.2. Release</h3>
+
+    <p>Software release numbers follow <a href="http://semver.org/">Tom Preston-Werner</a>
+    description;</p>
 
     <pre>
-       $ git checkout -b release-1.2 develop
-       Switched to a new branch "release-1.2"
-       $ ./bump-version.sh 1.2
-       Files modified successfully, version bumped to 1.2.
-       $ git commit -a -m "Bumped version number to 1.2"
-       [release-1.2 74d9424] Bumped version number to 1.2
-       1 files changed, 1 insertions(+), 1 deletions(-)
+    software-name-X.Y.Z.tar.xz
+    </pre>
+
+    <dl>
+        <dt>X</dt>
+        <dd>Major version, backwards incompatible API changes.</dd>
+        <dt>Y</dt>
+        <dd>Minor version, backwards-compatible changes.</dd>
+        <dt>Z</dt>
+        <dd>Patch version, backwards-compatible bug fixes.</dd>
+    </dl>
+
+    <pre>
+    $ git checkout -b r-1.2.1 develop
+    Switched to a new branch "release-1.2.1"
+    $ ./bump-version.sh 1.2.1
+    Files modified successfully, version bumped to 1.2.1.
+    $ git commit -a -m "Bumped version number to 1.2.1"
+    [release-1.2 74d9424] Bumped version number to 1.2.1
+    1 files changed, 1 insertions(+), 1 deletions(-)
     </pre>
 
     <p>Only documentation or bugfixes are allowed in this
@@ -137,75 +157,99 @@
     and push to master;</p>
 
     <pre>
-       $ git checkout master
-       Switched to branch 'master'
-       $ git merge --no-ff release-1.2
-       Merge made by recursive.
-       (Summary of changes)
-       $ git tag -a 1.2
+    $ git checkout master
+    Switched to branch 'master'
+    $ git merge --no-ff r-1.2.1
+    Merge made by recursive.
+    </pre>
+
+    <p>Tag new release with software-name-version, this
+    allows meaningful ports
+    <a href="../core/ports.html">distfiles</a> when
+    downloading releases from git archives;</p>
+
+    <pre>
+    $ git tag -a software-name-1.2.1
+    $ git push --follow-tags
     </pre>
 
     <p>Update branch develop with bugfixes from last release,
     conflict will happen in next step</p>
 
     <pre>
-       $ git checkout develop
-       Switched to branch 'develop'
-       $ git merge --no-ff release-1.2
-       Merge made by recursive.
-       (Summary of changes)
+    $ git checkout develop
+    Switched to branch 'develop'
+    $ git merge --no-ff r-1.2.1
+    Merge made by recursive.
+    (Summary of changes)
+    $ git push
     </pre>
 
-    <h2 id="hotfix">Hotfix</h2>
+    <h3 id="tags">1.3. Tags</h3>
 
-    <p>This branch should never exist, ;)</p>
+    <p>There are two main types of tags, lightweight and
+    annotated. Lightweight tag is a pointer to a specific commit,
+    much like cheap branches. Annotated tags are stored as full objects
+    and allow to sign with <a href="gnupg.html">gnupg</a>, making it ideal
+    for distributing releases.</p>
+
+    <p>Delete local and remote last end of life version;</p>
 
     <pre>
-       $ git checkout -b hotfix-1.2.1 master
-       $ ./bump-version.sh 1.2.1
-       Files modified successfully, version bumped to 1.2.1
-       $ git commit -a -m "Bumped version number to 1.2"
+    $ git tag -d software-name-0.0.12
+    $ git push origin :refs/tags/software-name-0.8
     </pre>
 
+    <p>Checkout master commit you want to start long term support and then;</p>
+
     <pre>
-       $ git commit -m "Commit severe fixes"
+    $ git tag -m "this commit is tagged" -a "software-name-1.1.8"
+    $ git push --follow-tags
     </pre>
 
+    <h3 id="hotfix">1.4. Hotfix</h3>
+
+    <p>This branch should never exist, ;)</p>
+
     <pre>
-       $ git checkout master
-       Switched to branch 'master'
-       $ git merge --no-ff release-1.2.1
-       Merge made by recursive.
-       (Summary of changes)
-       $ git tag -a 1.2.1
+    $ git checkout -b h-1.2.2 master
+    $ ./bump-version.sh 1.2.2
+    Files modified successfully, version bumped to 1.2.2
+    $ git commit -a -m "Bumped version number to 1.2.2"
     </pre>
 
-    <p>Conflict will happen in next step</p>
-
     <pre>
-       $ git checkout develop
-       Switched to branch 'develop'
-       $ git merge --no-ff release-1.2.1
-       Merge made by recursive.
-       (Summary of changes)
+    $ git merge --no-ff b-error-xpto
+    ...
+    $ git merge --no-ff b-error-xpto
+    ...
+    $ git commit -m "Commit severe fix"
+    ...
+    $ git commit -m "Commit severe fix"
+    ...
     </pre>
 
     <pre>
-       $ git -D hotfix-1.2.1
+    $ git checkout master
+    Switched to branch 'master'
+    $ git merge --no-ff h-1.2.2
+    Merge made by recursive.
+    (Summary of changes)
+    $ git tag -a software-name-1.2.2
     </pre>
 
-    <h2 id="tags">Tags</h2>
+    <p>Conflict will happen in next step</p>
 
     <pre>
-    $ git tag -m "this commit is tagged" -a "v1.8"
-    $ git push --follow-tags
+    $ git checkout develop
+    Switched to branch 'develop'
+    $ git merge --no-ff h-1.2.2
+    Merge made by recursive.
+    (Summary of changes)
     </pre>
 
-    <p>Delete local and remote tag;</p>
-
     <pre>
-    $ git tag -d v1.8
-    $ git push origin :refs/tags/v1.8
+    $ git -D h-1.2.2
     </pre>
 
     <h2 id="local">Local Workflow</h2>
@@ -230,10 +274,10 @@
     $ git checkout f000^ -- path/to/file
     </pre>
 
-    <a href="index.html">Dev Index</a>
-    <p>This is part of the SysDoc Manual.
+    <a href="index.html">Development Index</a>
+    <p>This is part of the c9-doc Manual.
     Copyright (C) 2016
-    Silvino Silva.
+    c9 Team.
     See the file <a href="../fdl-1.3-standalone.html">Gnu Free Documentation License</a>
     for copying conditions.</p>