I was using git for the first time, I had a directory with several programs written in it and did the following steps
- I did
git add .
- then
git commit
, then it i got a messageAborting commit due to empty commit message.
- Then i thought, let me commit group of files under common message. So i thought of removing all the added files.
- So i did
git rm -r -f
- When i do a
ls
i have lost all my code. Is there any way that i can get them back, to my foolishness i don't have backup copy even.
Things that i have followed till now
I googled out some found some of the command but they are not working
git stash
if i type this command i get
fatal: bad revision 'HEAD' fatal: bad revision 'HEAD' fatal: Needed a single revision You do not have the initial commit yet
git reset HEAD
, if i type this command i get
Fatal: ambiguous argument 'HEAD': unknown revision or path not in the working tree. Use '--' to separate paths from revisions
I really need to get those files back!
Steps that i followed to create GIT
mkdir BareRepo
- In
BareRepo
Directory i didgit init
,git status
,git config --bool core.bare true
- Then i cloned the BareRepo
git clone BareRepo/ Programs/
- In the
Programs
directory i did all the above said thing
I am not sure this would work 100% but certainly worth a try I think:
git reflog
is your commandreflog records every action you perform inside git...so I am betting on this.
reflog will produce a list of commands that you performed on your repo
To recover your work, go through the log that was produced by reflog and do a
git reset --hard HEAD@{<x>}
.. substitute
x
with the number that defines state you want to like to be at.......that should reset your repo back to original state (hopefully)
You may be able to recover the files from the aborted commit
Based on the observation of @the-malkolm.
From the information in the question, there are no commits, and the files were not tracked at any time. As such git does not really know about any of the files that have been deleted.
That said however, there is hope. Simply because you attempted to commit your files before deleting them, there is a phantom commit floating around with all of your files in it.
Here's an example:
The above simulates the events in the question, and ordinarily this is the time to start rewriting the code again. There is no commit, the file is gone.
Identify that aborted commit
However inspecting the
.git
repository yields some information:There are objects in the git repository despite there being no commits. It's necessary to identify which of the two objects is the tree:
The first reference is the blob representing the README.md file - there will be one blob per file in the repository, the second in this example is the tree reference.
Recreating the working copy
Once the tree hash has been identified, it can be used to rebuild the index with read-tree:
At this time, the working copy is empty but the lost files are staged for commit.
Commit them:
And checkout to match the committed state of the repository:
And then, all files exist and have been committed.