Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 8756397
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 13, 20262026-06-13T14:04:37+00:00 2026-06-13T14:04:37+00:00

I have a file named foo . I make some modification M1 to foo

  • 0

I have a file named foo. I make some modification M1 to foo and stage it. Then I revert it in the working tree by checking it out from HEAD, and make another modification M2 to it. Now I want to merge these two modifications before commit. How can this be done? Thanks!

(I know branches are for this kind of work. But I’d like to know whether there is a way to merge a staged file with the modified version in the working tree.)

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-13T14:04:38+00:00Added an answer on June 13, 2026 at 2:04 pm

    The most obvious solution is to create two commits, and merge them. This is fairly safe, as once you get your changes into two different commits, it’s fairly hard to lose them, and if the merge doesn’t go as you want, you can throw away the merge commit and try again.

    For the first commit, you already have the changes staged, so just git commit should be sufficient.

    For the second, you have a state in your working copy that represents changes to the original HEAD. But now that you’ve done that commit, there’s an intervening one; HEAD is what was in the index, so it looks like your working copy reverts those changes. To get around this, we need to reset where our HEAD points, without changing what’s in the working copy.

    Before doing so, let’s save a pointer to our current HEAD: git branch was-in-index. Now we can reset to the previous HEAD (the parent of HEAD) with git reset HEAD^, and add and commit our changes git add some stuff; git commit (or git commit -a, if you want all of your changes).

    Now we have two branches; our current one, which contains the changes from the working copy, and was-in-index, which contains the changes which were in the index. Now you can merge these however you want; git merge was-in-index, git rebase was-in-index, or what have you. You can delete the was-in-index branch when you’re done.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have a resource file named filetypes.resx. Some how I figured out to bind
I have a file in my Subversion repository named Foo.cs. When I run the
I have a file named my file.pdf and I can't delete this file with
I have a file,named f1.txt, whose contents are 75 15 85 35 60 50
I have a file named file with three lines: line one line two line
I have a file named configuration.xml which resides in classes folder of my WEB-INF
Let's say I have a file named output1 How to match just digits form
I have a txt file named 'a.txt' with the following content: Hi=Python Now, I
I have a jar file named umar.jar in /root/umar/bin directory. I have a shell
I want to use some functions from a .cpp source file that has a

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.