Creating a Repository
Last updated on 2025-09-29 | Edit this page
Estimated time: 25 minutes
Overview
Questions
- Where does Git store information?
Objectives
- Create a local Git repository.
- Describe the purpose of the .gitdirectory.
Once Git is configured, we can start using it.
We will continue with the story of Wolfman and Dracula who are modeling the co-occurrences of vampires and werewolves on Mars.
We will do our work in the Desktop folder so let us
change our directory:
If your Desktop is backed up by OneDrive, change your
directory to it with:
Note: You can start typing OneDrive and then hit
Tab to autocomplete through “DOI/”. Then, starting typing
Desktop and hit Tab to autocomplete. If you
are struggling to find your Desktop via Git Bash, open your
File Explorer, hold SHIFT and right click on the
Desktop folder. You should see a menu with the option
Open Git Bash here. Click that option and use the Git Bash
terminal that is opened.
Now that we are in our Desktop, let us create a new
directory for our work and then change the current working directory to
the newly created one:
Then we tell Git to make vampires-and-werewolves a repository -- a place where Git can
store versions of our files:
If we show hidden files in File Explorer, we can see that a .git file has been created in the vampires-and-werewolves directory:

It is important to note that git init will create a
repository that can include subdirectories and their files—there is no
need to create separate repositories nested within the
vampires-and-werewolves repository, whether subdirectories
are present from the beginning or added later. Also, note that the
creation of the vampires-and-werewolves directory and its
initialization as a repository are completely separate processes.
If we use ls to show the directory’s contents, it
appears that nothing has changed:
But if we add the -a flag to show everything, we can see
that Git has created a hidden directory within
vampires-and-werewolves called .git:
OUTPUT
.	..	.gitGit uses this special subdirectory to store all the information about
the project, including the tracked files and sub-directories located
within the project’s directory. If we ever delete the .git
subdirectory, we will lose the project’s history.
Next, we will change the default branch to be called
main. This might be the default branch depending on your
settings and version of git. See the setup episode for
more information on this change.
We can check that everything is set up correctly by asking Git to tell us the status of our project:
OUTPUT
On branch main
No commits yet
nothing to commit (create/copy files and use "git add" to track)If you are using a different version of git, the exact
wording of the output might be slightly different.
We just used a variety of bash and git commands which can be confusing to keep track of. Luckily, we have compiled a list of some cheatsheats for quick reference.
Places to Create Git Repositories
Along with tracking information about the vampires and werewolves
modeling project on Mars (the project we have already created), Dracula
would also like to track information about vampires and werewolves on
various moons. Despite Wolfman’s concerns, Dracula creates a
moons project inside his
vampires-and-werewolves project with the following sequence
of commands:
BASH
$ cd ~/Desktop   # return to Desktop directory
$ cd vampires-and-werewolves     # go into vampires-and-werewolves directory, which is already a Git repository
$ ls -a          # ensure the .git subdirectory is still present in the vampires-and-werewolves directory
$ mkdir moons    # make a subdirectory vampires-and-werewolves/moons
$ cd moons       # go into moons subdirectory
$ git init       # make the moons subdirectory a Git repository
$ ls -a          # ensure the .git subdirectory is present indicating we have created a new Git repositoryIs the git init command, run inside the
moons subdirectory, required for tracking files stored in
the moons subdirectory?
No. Dracula does not need to make the moons subdirectory
a Git repository because the vampires-and-werewolves
repository can track any files, sub-directories, and subdirectory files
under the vampires-and-werewolves directory. Thus, in order
to track all information about moons, Dracula only needed to add the
moons subdirectory to the
vampires-and-werewolves directory.
Additionally, Git repositories can interfere with each other if they
are “nested”: the outer repository will try to version-control the inner
repository. Therefore, it is best to create each new Git repository in a
separate directory. To be sure that there is no conflicting repository
in the directory, check the output of git status. If it
looks like the following, you are good to go to create a new repository
as shown above:
OUTPUT
fatal: Not a git repository (or any of the parent directories): .gitCorrecting git init Mistakes
Wolfman explains to Dracula how a nested repository is redundant and
may cause confusion down the road. Dracula would like to remove the
nested repository. How can Dracula undo his last git init
in the moons subdirectory?
Background
Removing files from a Git repository needs to be done with caution. But we have not learned yet how to tell Git to track a particular file; we will learn this in the next episode. Files that are not tracked by Git can easily be removed like any other “ordinary” files with
Similarly a directory can be removed using rm -r dirname
or rm -rf dirname. If the files or folder being removed in
this fashion are tracked by Git, then their removal becomes another
change that we will need to track, as we will see in the next
episode.
Solution
Git keeps all of its files in the .git directory. To
recover from this little mistake, Dracula can just remove the
.git folder in the moons subdirectory by running the
following command from inside the vampires-and-werewolves
directory:
But be careful! Running this command in the wrong directory will
remove the entire Git history of a project you might want to keep.
Therefore, always check your current directory using the command
pwd.
- 
git initinitializes a repository.
- Git stores all of its repository data in the .gitdirectory.
- Git repositories should not be nested in your file system. Have only
one .gitfolder/directory within a directory.

