Tuesday, 13 August 2019

Git for Beginners and Intermediate level

Yeah, we have seen this title in lot many other posts. Trust me, all are same. Yet different in their approach trying to share the knowledge in most simplistic and summarised manner.


courtesy: git

I could have shown all the following commands with a nice black background and explaining each command, but this is not about learning git.
This is all about knowing the things that are surely needed in your daily git interactions. 

How am I sure about it? 

Cause I have gone through them in the beginning of my career. 
And ever since, I was able to handle all my daily transactions smoother.
No need to depend on any IDE, SourceTree or anything else.

What makes it so special?

Following are the list of git commands, like my own cheat sheet grouped together while going through git transactions happening in real time environment. Total age of this document is 8 years and it is still getting updated.

Tip: Be patient, try each unknown command. Read till the end to find the best things hidden.


git init — initializes git repo in your local dir
 git remote add origin 
https://github.com/username/project.git — creates a remote which you use to contact with source repo
 git pull origin master — gets data from master branch of your source
 git pull — gets data from all branches of your sources.

For Submodules

$ git submodule update — init
 $ git submodule foreach git checkout -t origin/develop
 $ git checkout -t origin/develop
 $ git submodule foreach pull/push origin <branchName>

To configure Git

git config — global user.name “Your Name Here”
 git config — global user.email “your_email@example.com”

To Edit git config file

git config — global — edit

For Branching

git branch <branchname> — creates a branch
 git checkout <branchname> — switches you to this branch
 git checkout -b <branchname> — creates and Switched to the new branch
git status — To know about the status of your local repo.
 git add -a — To add everything from workspace
git commit -m “Initial commit”
 or git commit -am “Initial Commit”
 git commit — amend — to push with last commit message

# If you want to edit last push commit message (Strictly not to be tried on other's repo)

 git commit — amend -m “new commit message”
git push origin +<branchname>:<branchname>
git push -u origin international
 git push
 git branch -d <branchname> — deletes a branch locally.
 git push origin :<branchname> — deletes a remote branch
 git pull origin <branchname>
 git merge <branchname> — merges branch with master
git rev-parse HEAD — To know the current HEAD

# If you want to get some specific commit from pull requests or any other branches, do cherry-pick:

 git cherry-pick abc0123


# If you need to do multiple cherry-pick, then start from old to new.

git cherry-pick a
git cherry-pick b
git cherry-pick c
git cherry-pick d
...

# For RPC Error

if error: RPC failed; result=22, HTTP code = 411
 The default file post size for Git has been exceeded.

 git config http.postBuffer 524288000 [set to 500 MB]


git branch -m old-branch-name new-branch-name — rename local branch
 git branch -m <new name> — rename the current branch
 git push origin :old-branch-name — delete remote branch with old name
 git push origin new-branch-name — create remote renamed branch

For Tags

 git tag -a <tagname> -m “tag message”
 git commit -am “Initial Commit”
 git push origin <tagname>
 git pull origin <tagname>
 git show <tagname>
 git tag -d <tagname>

# Delete a tag in cloud

 git tag -d 12345
 git push origin :refs/tags/12345

FOR UTILITIES:

 git status
 git log
 git remote (-v) show
 git branch (-v)
 git mv oldname newname
 git remote rm <remote name> — to delete a remote

GIT TRICKS:

 git tag -a v3.2.9 -m “updating version to 3.2.9” — to apply a tag for current head
 git push origin — tags — to push tags to current branch.
 git merge — abort — To Stop merging
 git reset — hard master@{10} — Revert to the tenth commit in the list
 git checkout -b branchX master@{‘one month ago’} — Start a new branch from the commit that the master pointed to one month back.
 git reset — hard 60510a. — Jump to specific checkout

SOFT RESET:

git reset — soft HEAD^ — To revert last commit.The above undo the last commit and keeps all the changes you made.
Means, you could still see all the changes made in that commit.
Use case: You dont want this commit in that branch, but the changes you made in the last commit are needed for another branch/feature.

HARD RESET:

git reset — hard HEAD^ — To undo all your local changes.The above undo the last commit and deletes all the changes you made.
Means, you can’t see the changes anymore and you can’t get them back.
Use case: You don’t want this commit in that branch, and the changes you made are not needed anymore.
Note: Check twice before applying ‘reset’ with ‘hard’. You can’t undo it once done.

git stash — To make changes saved and place aside while pulling or pushing
 git pull
 git stash pop — To apply the saved changes after you pull from Source repo.

REMOVING REMOTE

 git remote -v
 # View current remotes
# origin git@github.com:user/repo.git (fetch)
 # origin git@github.com:user/repo.git (push)
 # destination git@github.com:forker/repo.git (fetch)
 # destination git@github.com:forker/repo.git (push)
 git remote rm destination
 # Remove remote
git remote -v
 # Verify removal
# origin git@github.com:user/repo.git (fetch)
 # origin git@github.com:user/repo.git (push)

# To work with multiple accounts of git or github

#to delete a commit from source (Github)

 #http://stackoverflow.com/questions/10817906/delete-a-commit-from-github
 git push -f origin HEAD^:master

# Git cherrypick multiple commits

# Git archive or export zip

 git archive HEAD — format=zip > archive.zip
 git archive HEAD | gzip > archive.tar.gz

# To delete every branch except the one that you currently have checked out:

 for b in `git branch | grep -v \*`; do git branch -D $b; done

# To delete all other branch except ‘master’

 git branch | grep -ve “ master$” | xargs git branch -D

# To delete all the local branches except ‘master’

 git branch | grep -v “main” | xargs git branch -D

# Use orphan branch

 git checkout — orphan <your new branch>
 git rm -rf .
 <do your work>
 git add your files
 git commit -m ‘Initial commit’



Note: Feel free to ask if you are stuck anywhere.
 ** Please try to experiment with your sample repositories before you work with real code repo’s.

-Anilrajkumar Battini

PS:Be careful with anything that deletes, Double check before pressing return.

Monday, 30 December 2013

Mac Tips and Tricks (Mavericks days)

I am not so good at mac or hack. But I find myself spending big time to make good use of mac.

So if any of you feel this page made your day happy, then I feel happy too.

Finder:       

Everybody uses Finder.
So what's the best shortcut to use finder........

                                                         Option + Command + Spacebar.

This actually opens a searching window. But the point is, you can open a finder without using the cursor.  If you are able to see the sidebar which contains your favorite folders, fine, If not 

   Option + Command + S

This actually shows/hides your sidebar of finder.

Dock:


What so special about dock here, it shows everything that you are working on.
Oops, sometimes that might be a problem. 
People, some of them, uses very wide range of apps in their system and their dock is like a mile long.
So if you want to hide the apps from dock but they should work in the background, here it is.

Add the following to application info.plist to make it go away from dock.

<key>LSUIElement</key>
<string>1</string>

To get to info.plist, go to Applications, select your app, tap with two fingers, you will get a menu, select 'Show Package Contents' , then Contents, there you find your info.plist.

Revealer:

Sometimes people want to deal with hidden files, that can be done easily by this.


No History:



Some times we want apps not to store any data.
Cause we can't run after history and it's issues.

What we should do to tell the app not to store any history or Cache.
This might be your browser, preview or any other app.
For example: Let me tell my itunes not to store the history.

defaults write com.apple.iTunes NSRecentDocumentsLimit 0
defaults delete com.apple.iTunes.LSSharedFileList RecentDocuments
defaults write com.apple.iTunes.LSSharedFileList RecentDocuments -dict-add MaxAmount 0


Type the above 3 lines in your terminal and press return.
The bold letter are the identifier of your app in your system.

Now the question is how to get the Identifier.
Open Activitiy Monitor and double click of your desired app and click on Sample button.
There you go you will see the identifier in that given data.

Browser:


So, how do you reopen the closed tab in your browser.
Don't say, you go to history and all.  Here it is.,

Safari                             : Command + Z
Others                            : Command + Shift + T (opposite to create a new tab Cmd + T)

Now how do you go to address bar, 
Don't use cursor             : Command + L

Close or Quit:

                              

What do you really wanna do Close or Quit:

Close the app                  : Command +W
Quit the app                    : Command + Q


So guys if the post is not readable or understandable, please excuse me, I am at LKG level in writing blogs.

Thanks,
Anilrajkumar Battini