Skip to main content

Git Series (5) — Picking a specific commit

There are scenarios when we want to apply the changes of an earlier commit in a repo, on top of the current repo tree of some branch in the same repo. 
Or
In some scenarios, we just want all the changes from an earlier commit of this repo into the current staging area and make some more changes before finally committing all the changes to the repo tree.

For both scenarios, the git cherry-pick command comes in handy.

Git documentation describes cherry-pick as

Let’s explain this with an example

Step 1- Create a git repo

mkdir git-example-cherry-pick && \ 
cd git-example-cherry-pick && \
git init

Step 2- Add a few commits

echo "First change" >> first.file && \
git add first.file && \
git commit -m "first commit"


echo "Second change" >> second.file && \
git add second.file && \
git commit -m "second commit"


echo "Third change" >> third.file && \
git add third.file && \
git commit -m "third commit"

Step 3- Switch to a new branch and add a commit

git checkout -b branch-one


echo "4 change" >> 4.file && \
git add 4.file && \
git commit -m "4 commit"

Step 4- Switch to another branch and add a commit

Let’s create a new branch named branch-two. We will create this branch out of the master branch, so the file named 4.file created in branch-one in step 3 will not be present in this new branch branch-two.

git checkout -b branch-two master


echo "5 change" >> 5.file && \
git add 5.file && \
git commit -m "5 commit"

Step 5- Use cherry-pick

Now if you see the files in the current folder, you will not see a file named 4.file. This file was created as part of a 4th commit which was applied only on branch-one

To apply the same changes in the current branch, we need the commit hash of the commit. git log command can be used for the same.
This is what I see when I look at the git logs for branch-one.

Now we are on branch-two, Let's apply the change from commit by using the cherry-pick.

git cherry-pick 0938880

This takes all the changes done under the mentioned commit & applies them on top of the current HEAD. In our case, one new file named 4.file will be added.

Duplicate commits problem

With the cherry-pick, the exact same changes are applied with a new commit SHA identifier. In other words, cherry-pick causes duplicate commits.

If you really needed the code from an earlier commit which you are cherry-picking as a base from your own further changes, you can use the command with the — no-commit option
This will not create a duplicate commit but will put the changes from that earlier commit into your working directory. 
Now you can make your changes on top of this code and then commit.

git cherry-pick 0938880 --no-commit

This is all for a simple but very useful cherry-pick command.

Comments

Popular posts from this blog

An Introduction to Quartz Scheduler

It's a common use case to have an enterprise application, perform specific work, at a specific time or in response to a specific action. In other words, “There is an ask to execute a  Job  upon a predefined  Trigger ”. This brings us to the need for a  Scheduling System.  A system, where  Jobs  &  Trigger  can be registered and the system will manage the remaining complexity. Thankfully for the Java systems,  Quartz  is for rescue. It‘s an open-source library that has been extensively used in enterprise applications for more than a decade. Components in Quartz Sub System: Following are the all major component in the Quartz subsystem: Scheduler : It’s the control room of Quartz. It maintains everything required for scheduling,  such as managing listeners ,  scheduling jobs , clustering, transactions & job persistence. It maintains a registry of  JobDetails ,  Listeners  &  Triggers , and executes Job & Listeners when their associated Trigger is fired. SchedulerFactor

Unable to Redo in VS-Code & Intellij

Since the beginning of personal computers, few keyboard shortcuts are common among all operating systems and software. The ubiquitous cmd+c (copy), cmd+v(paste) , cmd+z (undo) and cmd+y (redo) I am not sure why, both of my favorite IDEs,  Visual Studio Code  &  Intellij  decided to not use  cmd+Y for redo.Below are the quick steps to configure  cmd+Y for a redo in VS-Code & Intellij Visual Studio Code Open VS Code & Go to keyboard shortcuts There will be a search bar at the top Type “  redo  “ in the search bar. You can see on my system its still mapped to  shift+cmd+z Double click on  ⇧ ⌘ z  and the below box will appear. Do not click anywhere or type anything on the keyboard except the key you want to assign, in our case it was  cmd+y,  so type  cmd+y Press Enter and you are done. Now you can use  cmd+z  for undo and  cmd+y  to redo like always Intellij It is also as simple as VS-Code Open IntelliJ & go to  Preferences In the search bar search for the  redo. In the ri

My Custom Built Desktop. The Questions & The Answers!

If  you want to avoid overpriced pre-builts like the M1 Mac Mini, Mac Pro, or Dell XPS Desktop without compromising on performance, a self-built desktop is a preferred option. It's also a great choice if you enjoy building things. custom built with ASUS-PRIME-P If you choose to build a custom PC, be prepared to invest time in researching and assembling compatible components.  In this post, I'll share my experience building this colorful powerhouse. I'll cover: Why did I do it.  Key questions to ask when selecting components Thought process behind component choices Components used in my build Benchmark comparisons . ** My second custom-build **.  ***  Disclaimer: Not an Apple product. Just a free apple sticker is used *** Why did I do it I decided to get a desktop during the pre-MacM1 era (yes, that’s a thing). After browsing many websites, I found that well-configured prebuilt PCs were overpriced, while cheaper ones had subpar components. Unable to choose between the option

Time Zones, Meridian, Longitude, IDL… It's more politics than science.

Once, I was working on a few geospatial APIs handling many time zones. While writing tests, I realized I did not know much about timezones. A lame excuse might be, my subpar schooling as a village kid. Nevertheless, I decided to turn the pages on timezones, what I found was more politics than science. Photo by  Arpit Rastogi  on  Unsplash Before diving into anomalies, let’s talk about history then we will go to science followed by politics. History The world without time zones By 300 BCE, the western world agreed that the earth is round. Each developed civilization devised its unique distinct system to measure distances, times & absolute locations, but relative to prime locations within their civilizations. It all worked in ancient times because long-distance travel was not prevalent among common people. Only merchants or armies traveled long distances. And they already developed systems that worked on their predetermined routes, irrespective of the time differences between locatio

BDD (1) — Behavior Driven Development

A wise man ( narcissist me ) once said, “Life is all about the question and answers. The trick to a meaningful life is,  To ask the right questions to yourself, so you can get on the right path to search for the answer .” The very first question one should always ask oneself is WHY.  Let's discuss our WHY in the current case. Why BDD Let's take a step back and start with the well-known software development practice TDD ( Test-Driven Development).  In TDD, the very first thing developers do is, set up the technical expectations from the code by writing failing test cases. After the expectation is set, the code is written/modified to finally pass all of the failing tests. It's an  Acceptance driven development strategy . TDD works fine to create a robust technically working product. But the whole TDD approach revolves only around technical teams. It barely involves the business analysis or product owners to validate the business aspect of a feature, they get involved only aft