Pages

Tuesday, December 11, 2012

GIT Commands

Setting up the environment :

Configuration files exist in three places :

(Windows)

System (all users of the same machine) wide, typically located in
  • C:\Program Files\git\etc\gitconfig
  • Configuration command: git config --system
User specific (Global), typically located in :
  • C:\users\*user*\.gitconfig
  • Configuration command:  git config --global
Project specific, located in :
  • Working project directory ie: C:\development\.git\config
  • Configuration command: git config
Modifying specific configuration files via the command line :

As a brief run through, we'll focus on manipulating a user specific configuration file (global configuration) to outline some of the rudimentary configuration steps.

git-bash> git config --global user.name "W Wright"
git-bash> git config --global user.email ""wemail@dne.com"" (single quotes)
git-bash> git config --global core.editor "notepad.exe" (Google for neat configurations for this)
git-bash> git config --global color.ui true
git-bash> git config --list
git-bash> git init
git-bash> git add .
git-bash> git add <filename>
git-bash> git status
git-bash> git rm <filename>  *permanent, unix like rm*
git-bash> git mv <filename> <filename>
git-bash> git diff
git-bash> git diff <filename>
git-bash> git checkout <branch name>
git-bash> git checkout -- <filename/folder>
git-bash> git commit --ammend -m "message" * ammends changes to HEAD pointer commit*
git-bash> git log
git-bash> git checkout <10-30 numbers from SHA-1> -- <filename> *checkout from a revision puts it into staging tree*
git-bash> git diff --staged
git-bash> git reset HEAD <filename> *removes an item from the staging tree*
git-bash> git revert <10-30 characters from SHA-1> * complete mirror reversal of commit, done using the last HEAD pointer commit value*

Undoing multiple commits *dangerous*


git-bash> git reset --soft <SHA-1 to reset to>
  • resets the version in the repository, does not affect the updated versions contained in either the staging index or the working directory. diff will show all the differences between the files in repo versus working/staging dir.
 git-bash> git reset --mixed (default) <SHA-1 to reset to>
  • moves head pointer to specified commit, also changes staging index, but does not affect the working directory.  
 git-bash> git reset --hard <SHA-1 to reset to>
  • moves pointer of repository but also makes staging and working directory match the affects of the reset.  (All updated files in the staging & working) will be changed.
--------------------
git-bash> git clean -n (test run for removing untracked files contained in working directory)
git-bash> git clean -f (removes untracked files contained in working directory)

.gitgnore file - to avoid git from complaining about untracked specific file types, etc.

git-bash> git config --global core.excludesfile ~/.gitignore (Global ignore file - specify location)

git-bash>  git rm --cached <filename>  to remove a file from the staging index after ignoring it.  (a method to ignore already tracked files)






GIT - DVCS (Distributed Version Control System)


For example:


Developer A logs into the server and "check's out" an updated copy of the project file. Simultaneously, Developer B also logs into the server and "check's out" a copy of the project file also. Developer A is quick to make a few changes to the files and "commits" or "checks in" the changes to the server to update the server copy. Shortly after, Developer B has finalized changes to his/her local copy and attempts to "commit / check-in" his completed work.


However ! The server will only accept changes to the most updated files. Hence, beca

The Goal :


To establish and maintain a GIT environment for the purpose of project collaboration, primarily in C.


What is GIT ?


GIT is a DRCS (Distributed Revision Control System) also commonly known as Distributed Version Control and or DVCS (Decentralized Version Control System).


GIT vs. Traditional CVS (Concurrent Versions System)



CVS:


First let's start off by exploring the traditional CVS setup:

CVS uses a client - server architecture, where-in current versions of the "project" and it's associated history of changes are stored on a server. Client(s)/developers then connect to the server in order to "check out" a complete copy of the project. Once checked out, the developer is able to modify this copy of the project, and once completed "check-in" their changes.

Multiple developers are able to collaborate/work on the same project concurrently (occuring simultaneously or side by side). However, there are limitations.
use Developer A has already submitted changes and updated the server side files, the copy that has been modified by Developer B is no longer associated with the most "updated" version of the files. This is where manual intervention is required to accommodate the conflict in the CVS repository.

"Clients can also compare versions, request a complete history of changes, or check out a historical snapshot of the project as of a given date or as of a revision number."


GIT:

Git adopts a peer - to - peer style of version control as opposed to the client - server (centralized) approach. Therefore, each local copy stored on the machines of contributors to the "project" are all considered official respositories. Syncronization of the core files (Project) occur through a process of patch updates (change-sets) amongst developers/peers.

Must Read: http://git-scm.com/book/en/Getting-Started-About-Version-Control

Introduction to Linear Algebra

"Algebraic Method" of solving linear equations using Matrices.

Consider the following system:

3x1 + 2x2 - x3 + x4-1
2x1          - x3 + 2x4 = 0
3x1 + x2 - 2x3 + 5x4 = -1
Augmented Matrix :

[ 3 2 -1 1 | -1 ]
[ 2 0 -1 2 |   0 ]
[ 3 1   2 5 |   2 ]

Coefficient Matrix :

[ 3 2 -1 1 ]
[ 2 0 -1 2 ]
[ 3 1   2 5 ]

Constant Matrix :

-1 ]
[   0 ]
[   2 ]