If you’ve been working in web development for a while, you may run into scenarios where you make some changes or delete some files, and somehow lose work and a lot of time as a result.
Today I wanna show you some tips in VS Code to prevent that from happening.
The first thing you want to do when you need to modify a file is to copy and paste it, then rename the new file to “V2”. If you need more versions, you keep copy/pasting until you get to “V3”, “V4”, “V_final”, then “V_finalfinal”, and then “_-this-time-for-real-final_version_V7”.
Just kidding :)
If you’ve been in the field a while and that brought up some deeply rooted trauma, I know a great therapist.
But technology has advanced enough that we don’t need to rely on that sort of format. We have tools like Git, which has been around for a while and hopefully you’ve heard of it.
VS Code has some really nice Git integrations that they have well documented. It allows you to:
- Take a snapshot of the current state of the project
- Shows you side by side comparison to see each change
- See changes from within a file
- Compare and revert changes in bulk, or one at a time
All of that is really nice, but that’s not what I wanted to show you.
In almost every single project that I’ve worked on, I’ve hit a point where I’ve committed some code and then actually wanted to go back and change some things about that commit.
Maybe I included files that should not have been there, or I forgot to include some changes that should have been in there.
I’ve always had to look up how you undo the most recent commit:
git reset --hard HEAD~1
I can never remember that, but the good news is I don’t have to.
VS Code has it built in. You can go to the source control tab, then in the little kebab menu, go to the “Commit” section and there’s an option to “Undo Last Commit”.
That’s handy, but for the folks that prefer keyboard shortcuts, you can actually open up the command pallet with ctrl+shift+P
(Windows) and search for “Undo Last Commit”. I usually just type “undo” and press “enter”. It’s really quick once you’re used to it.
Also pretty handy, but even that isn’t the coolest trick, because there are scenarios where Git is not actually going to help you.
Say, for example, that we actually added a .gitignore
file to our project and we included a file we wanted to work on. That would exclude the file from version control. Which means we can’t make changes and then revert. This is a really common practice with something like ENV variables.
Now, if you accidentally delete this file, you better hope you have a backup.
You might be able to find it in the trash bin, but in my case, it actually goes straight to being deleted from disc. So it doesn’t exist in the trash bin. So how am I gonna get this back?
Fortunately, VS Code has this Timeline view, which is really, really cool because it will actually show you changes made to a file in between commit. You can think of it sort of like atomic version control.
It will show me the state of the file every time I hit save. It makes it really easy to go back and forth between versions.
And one of the coolest features here is if I delete a file, I can just create a new file with the same name and it will restore the timeline.
That feature has saved my butt a bunch of times (if you watch any of my live streams, you know what I’m talking about).
That’s all I got. Now you can go out there and be as reckless with your code as you want.
Thank you so much for reading. If you liked my work, and want to support it, the best ways are financial support, spreading the word, or following along on email or Bluesky.
Originally published on austingil.com.
you’re awesome. thanks for this.
You’re awesome! Thanks for this comment :)
so I used your trick to create a file that was lost, and indeed I could see the file history … any idea if there is a place where I could see if there are any additional lost files that I don’t know about?
Unfortunately, I don’t know. I’m sure there must be something stored on the local file system. From what I can tell, the VS Code team is pretty responsive to questions like this. Sorry I can’t be of more assistance.
Thank you, thank you.
And thank you again.
One remark: my VS Code was preset to filter on Git History, I had to click the filter button to show Local History too, and it was all there 🎉
You know, I can’t really take credit for the feature. Just for sharing it. But either way, I’m glad to hear you found this useful and it saved you some work :)