система управления исходным кодом Mercurial (Mercurial source code management system)
WORKING WITH PHASES
What are phases?
Phases are a system for tracking which changesets have been or
should be shared. This helps prevent common mistakes when
modifying history (for instance, with the mq or rebase
extensions).
Each changeset in a repository is in one of the following phases:
• public : changeset is visible on a public server
• draft : changeset is not yet published
• secret : changeset should not be pushed, pulled, or cloned
These phases are ordered (public < draft < secret) and no
changeset can be in a lower phase than its ancestors. For
instance, if a changeset is public, all its ancestors are also
public. Lastly, changeset phases should only be changed towards
the public phase.
How are phases managed?
For the most part, phases should work transparently. By default,
a changeset is created in the draft phase and is moved into the
public phase when it is pushed to another repository.
Once changesets become public, extensions like mq and rebase will
refuse to operate on them to prevent creating duplicate
changesets. Phases can also be manually manipulated with the hg
phase
command if needed. See hg help -v phase
for examples.
Phases and servers
Normally, all servers are publishing
by default. This means:
- all draft changesets that are pulled or cloned appear in phase
public on the client
- all draft changesets that are pushed appear as public on both
client and server
- secret changesets are neither pushed, pulled, or cloned
Note Pulling a draft changeset from a publishing server does
not mark it as public on the server side due to the
read-only nature of pull.
Sometimes it may be desirable to push and pull changesets in the
draft phase to share unfinished work. This can be done by setting
a repository to disable publishing in its configuration file:
[phases]
publish = False
See hg help config
for more information on config files.
Note Servers running older versions of Mercurial are treated as
publishing.
Examples
• list changesets in draft or secret phase:
hg log -r "not public()"
• change all secret changesets to draft:
hg phase --draft "secret()"
• forcibly move the current changeset and descendants from
public to draft:
hg phase --force --draft .
• show a list of changeset revision and phase:
hg log --template "{rev} {phase}\n"
• resynchronize draft changesets relative to a remote
repository:
hg phase -fd 'outgoing(URL)'
See hg help phase
for more information on manually manipulating
phases.