layout | title | subtitle |
---|---|---|
page |
Version Control with Mercurial |
Creating a Repository |
- Explain how to initialize a new Mercurial repository.
We'll start by exploring how version control can be used to keep track of what one person did and when. We're going to pretend to be a researcher named Susan who wants to start running the Salish Sea NEMO ocean model as a daily forecast system. If the example in the next few sections seems contrived, be assured that it is only slightly so to avoid having to do too much typing. Lots of projects (and therefore version control repositories) start with a single text file in which someone writes down some initial ideas. The repository for this workshop started with a file called plan.rst.
Now that we have Mercurial configured, we can start using. Let's create a directory for Susan's NEMO forecast project:
$ mkdir forecast
$ cd forecast
and tell Mercurial to make it a repository --- a place where Mercurial can store old versions of our files:
$ hg init
Mercurial commands are written hg verb
,
where verb
is what we actually want it to do.
If we use ls
to show the directory's contents,
it appears that nothing has changed:
$ ls
But if we add the -a
flag to show everything,
we can see that Mercurial has created a hidden directory called .hg
:
$ ls -a
. .. .hg
Mercurial stores information about the project in this special sub-directory. If we ever delete it, we will lose the project's history.
We can check that everything is set up correctly by asking Mercurial to verify the structure of our repository:
$ hg verify
checking changesets
checking manifests
crosschecking files in changesets and manifests
checking files
0 files, 0 changesets, 0 total revisions
- Explain how to initialize a new Mercurial repository.