Making your first commit
Great, now we have Git set up! You might have some questions about the Git Setup process:
Adding files to a snapshot
By default, Git does not know what files it should be including in a snapshot (and this is a good thing because we don't want Git to just add every file as they may contain sensitive information).
This is where the "three areas" concept comes into play. It is often good to think of your projects with Git as three separate concepts:

Working directory: where your codebase actually resides
Staging area: set of files that you want to include in a snapshot
Repository: local/remote repository storing metadata about the project and Git
By default, all of your files reside in the working directory and are not yet added to the staging area. If you want a file included in the staging area, then you must first add it to the staging area (we will cover how this happens later on).

The traditional way is to use the commands in Command Glossary to add files to the staged area, then using git commit. Let's try using lazygit to speed up this workflow.
To start, let's first initialize a repository somewhere.
mkdir recipe_repo
cd recipe_repo
git initMake a new file, recipe.txt and modifying it a little.
Now, run lazygit
lazygitHit 2 to go to the files submenu.
Hit a to stage all commits (this is the same as
git commit -A)Hit spacebar to stage commits by individual files
Hit Enter to enter into a file and use spacebar to select line by line which files to stage (This is known as interactive staging)
Once you've selected what you want to commit, press c, and enter a message, then hit Enter to commit
Adding a new file
Create a new file in the folder and add some text to it.
echo 'Hello world' >> hello.txtIf you don't want to use bash commands, you can just create the file using your preferred method as well.
Making your first commit
Getting the status of a repository
Now, run the following command to view the status of your repository:
git statusYou should see the following:
On branch main
No commits yet
Untracked files:
(use "git add <file>..." to include in what will be committed)
hello.txt
nothing added to commit but untracked files present (use "git add" to track)Recall that in Fundamental Concepts, Git does not automatically add files to a snapshot as it does not know exactly what you want. So we want to tell Git that we want hello.txt in the snapshot.
Tracking files
You may notice that the git status message states that hello.txt is untracked. Untracked files are those that have never been registered with Git before. They are often new files that have been added to the repository and have not existed in any snapshots.
Files that have been added to a snapshot before are considered "tracked" and Git knows to look out for changes between snapshots.
Adding files to the staging area
As discussed in Introducing the commit, a file from the working directory needs to be explicitly added to the staging area for a snapshot to include it. By default, an untracked file that is added to a snapshot becomes tracked for future snapshots.
To add hello.txt to the staging area, use the following command:
git add hello.txtThen, use git status to view the status of your repository again:
On branch main
No commits yet
Changes to be committed:
(use "git rm --cached <file>..." to unstage)
new file: hello.txtNotice that now, instead of stating that your file is untracked, Git is indicating that the changes have not committed. This is a sign that the file(s) have been tracked and added to the snapshot.
Taking the snapshot
Now, to take the snapshot (make the commit), you can use the following:
git commit -m "First commit"The -m flag is used to specify the commit message. Every commit has an accompanying message that you can use to indicate what the commit contains/entails.
There you have it! You have made a local repository and created a snapshot! We will now look at how we can integrate Github with your local repository!
Ignoring files
See: Ignoring Files
Last updated