Show More
test-help.t
3177 lines
| 98.7 KiB
| text/troff
|
Tads3Lexer
/ tests / test-help.t
Matt Mackall
|
r12328 | Short help: | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
$ hg | ||||
Mercurial Distributed SCM | ||||
basic commands: | ||||
Olav Reinert
|
r16853 | add add the specified files on the next commit | ||
annotate show changeset information by line for each file | ||||
clone make a copy of an existing repository | ||||
commit commit the specified files or all outstanding changes | ||||
diff diff repository (or selected files) | ||||
export dump the header and diffs for one or more changesets | ||||
forget forget the specified files on the next commit | ||||
init create a new repository in the given directory | ||||
log show revision history of entire repository or files | ||||
anatoly techtonik
|
r23400 | merge merge another revision into working directory | ||
Olav Reinert
|
r16853 | pull pull changes from the specified source | ||
push push changes to the specified destination | ||||
remove remove the specified files on the next commit | ||||
serve start stand-alone webserver | ||||
status show changed files in the working directory | ||||
summary summarize working directory state | ||||
update update working directory (or switch revisions) | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
timeless
|
r29974 | (use 'hg help' for the full list of commands or 'hg -v' for details) | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
$ hg -q | ||||
Olav Reinert
|
r16853 | add add the specified files on the next commit | ||
annotate show changeset information by line for each file | ||||
clone make a copy of an existing repository | ||||
commit commit the specified files or all outstanding changes | ||||
diff diff repository (or selected files) | ||||
export dump the header and diffs for one or more changesets | ||||
forget forget the specified files on the next commit | ||||
init create a new repository in the given directory | ||||
log show revision history of entire repository or files | ||||
anatoly techtonik
|
r23400 | merge merge another revision into working directory | ||
Olav Reinert
|
r16853 | pull pull changes from the specified source | ||
push push changes to the specified destination | ||||
remove remove the specified files on the next commit | ||||
serve start stand-alone webserver | ||||
status show changed files in the working directory | ||||
summary summarize working directory state | ||||
update update working directory (or switch revisions) | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
$ hg help | ||||
Mercurial Distributed SCM | ||||
list of commands: | ||||
Olav Reinert
|
r15862 | add add the specified files on the next commit | ||
addremove add all new files, delete all missing files | ||||
annotate show changeset information by line for each file | ||||
archive create an unversioned archive of a repository revision | ||||
backout reverse effect of earlier changeset | ||||
bisect subdivision search of changesets | ||||
Matt Mackall
|
r21762 | bookmarks create a new bookmark or list existing bookmarks | ||
Olav Reinert
|
r15862 | branch set or show the current branch name | ||
branches list repository named branches | ||||
bundle create a changegroup file | ||||
cat output the current or given revision of files | ||||
clone make a copy of an existing repository | ||||
commit commit the specified files or all outstanding changes | ||||
Matt Mackall
|
r20570 | config show combined config settings from all hgrc files | ||
Olav Reinert
|
r15862 | copy mark files as copied for the next commit | ||
diff diff repository (or selected files) | ||||
export dump the header and diffs for one or more changesets | ||||
Matt Mackall
|
r22423 | files list tracked files | ||
Olav Reinert
|
r15862 | forget forget the specified files on the next commit | ||
graft copy changes from other branches onto the current branch | ||||
Kevin Bullock
|
r30009 | grep search revision history for a pattern in specified files | ||
Matt Mackall
|
r19469 | heads show branch heads | ||
Olav Reinert
|
r15862 | help show help for a given topic or a help overview | ||
Yuya Nishihara
|
r24364 | identify identify the working directory or specified revision | ||
Olav Reinert
|
r15862 | import import an ordered set of patches | ||
incoming show new changesets found in source | ||||
init create a new repository in the given directory | ||||
log show revision history of entire repository or files | ||||
manifest output the current or given revision of the project manifest | ||||
anatoly techtonik
|
r23400 | merge merge another revision into working directory | ||
Olav Reinert
|
r15862 | outgoing show changesets not found in the destination | ||
paths show aliases for remote repositories | ||||
phase set or show the current phase name | ||||
pull pull changes from the specified source | ||||
push push changes to the specified destination | ||||
recover roll back an interrupted transaction | ||||
remove remove the specified files on the next commit | ||||
rename rename files; equivalent of copy + remove | ||||
resolve redo merges or set/view the merge status of files | ||||
revert restore files to their checkout state | ||||
root print the root (top) of the current working directory | ||||
serve start stand-alone webserver | ||||
status show changed files in the working directory | ||||
summary summarize working directory state | ||||
tag add one or more tags for the current or given revision | ||||
tags list repository tags | ||||
unbundle apply one or more changegroup files | ||||
update update working directory (or switch revisions) | ||||
verify verify the integrity of the repository | ||||
version output version and copyright information | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
additional help topics: | ||||
Olav Reinert
|
r15862 | config Configuration Files | ||
dates Date Formats | ||||
diffs Diff Formats | ||||
environment Environment Variables | ||||
Martin Geisler
|
r16547 | extensions Using Additional Features | ||
Olav Reinert
|
r15862 | filesets Specifying File Sets | ||
glossary Glossary | ||||
Martin Geisler
|
r16547 | hgignore Syntax for Mercurial Ignore Files | ||
Olav Reinert
|
r15862 | hgweb Configuring hgweb | ||
Gregory Szorc
|
r27376 | internals Technical implementation topics | ||
Olav Reinert
|
r15862 | merge-tools Merge Tools | ||
multirevs Specifying Multiple Revisions | ||||
patterns File Name Patterns | ||||
Matt Mackall
|
r15996 | phases Working with Phases | ||
Olav Reinert
|
r15862 | revisions Specifying Single Revisions | ||
revsets Specifying Revision Sets | ||||
Gregory Szorc
|
r25881 | scripting Using Mercurial from scripts and automation | ||
Olav Reinert
|
r15862 | subrepos Subrepositories | ||
templating Template Usage | ||||
urls URL Paths | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
timeless
|
r29974 | (use 'hg help -v' to show built-in aliases and global options) | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
$ hg -q help | ||||
Olav Reinert
|
r15862 | add add the specified files on the next commit | ||
addremove add all new files, delete all missing files | ||||
annotate show changeset information by line for each file | ||||
archive create an unversioned archive of a repository revision | ||||
backout reverse effect of earlier changeset | ||||
bisect subdivision search of changesets | ||||
Matt Mackall
|
r21762 | bookmarks create a new bookmark or list existing bookmarks | ||
Olav Reinert
|
r15862 | branch set or show the current branch name | ||
branches list repository named branches | ||||
bundle create a changegroup file | ||||
cat output the current or given revision of files | ||||
clone make a copy of an existing repository | ||||
commit commit the specified files or all outstanding changes | ||||
Matt Mackall
|
r20570 | config show combined config settings from all hgrc files | ||
Olav Reinert
|
r15862 | copy mark files as copied for the next commit | ||
diff diff repository (or selected files) | ||||
export dump the header and diffs for one or more changesets | ||||
Matt Mackall
|
r22423 | files list tracked files | ||
Olav Reinert
|
r15862 | forget forget the specified files on the next commit | ||
graft copy changes from other branches onto the current branch | ||||
Kevin Bullock
|
r30009 | grep search revision history for a pattern in specified files | ||
Matt Mackall
|
r19469 | heads show branch heads | ||
Olav Reinert
|
r15862 | help show help for a given topic or a help overview | ||
Yuya Nishihara
|
r24364 | identify identify the working directory or specified revision | ||
Olav Reinert
|
r15862 | import import an ordered set of patches | ||
incoming show new changesets found in source | ||||
init create a new repository in the given directory | ||||
log show revision history of entire repository or files | ||||
manifest output the current or given revision of the project manifest | ||||
anatoly techtonik
|
r23400 | merge merge another revision into working directory | ||
Olav Reinert
|
r15862 | outgoing show changesets not found in the destination | ||
paths show aliases for remote repositories | ||||
phase set or show the current phase name | ||||
pull pull changes from the specified source | ||||
push push changes to the specified destination | ||||
recover roll back an interrupted transaction | ||||
remove remove the specified files on the next commit | ||||
rename rename files; equivalent of copy + remove | ||||
resolve redo merges or set/view the merge status of files | ||||
revert restore files to their checkout state | ||||
root print the root (top) of the current working directory | ||||
serve start stand-alone webserver | ||||
status show changed files in the working directory | ||||
summary summarize working directory state | ||||
tag add one or more tags for the current or given revision | ||||
tags list repository tags | ||||
unbundle apply one or more changegroup files | ||||
update update working directory (or switch revisions) | ||||
verify verify the integrity of the repository | ||||
version output version and copyright information | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
additional help topics: | ||||
Olav Reinert
|
r15862 | config Configuration Files | ||
dates Date Formats | ||||
diffs Diff Formats | ||||
environment Environment Variables | ||||
Martin Geisler
|
r16547 | extensions Using Additional Features | ||
Olav Reinert
|
r15862 | filesets Specifying File Sets | ||
glossary Glossary | ||||
Martin Geisler
|
r16547 | hgignore Syntax for Mercurial Ignore Files | ||
Olav Reinert
|
r15862 | hgweb Configuring hgweb | ||
Gregory Szorc
|
r27376 | internals Technical implementation topics | ||
Olav Reinert
|
r15862 | merge-tools Merge Tools | ||
multirevs Specifying Multiple Revisions | ||||
patterns File Name Patterns | ||||
Matt Mackall
|
r15996 | phases Working with Phases | ||
Olav Reinert
|
r15862 | revisions Specifying Single Revisions | ||
revsets Specifying Revision Sets | ||||
Gregory Szorc
|
r25881 | scripting Using Mercurial from scripts and automation | ||
Olav Reinert
|
r15862 | subrepos Subrepositories | ||
templating Template Usage | ||||
urls URL Paths | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
Augie Fackler
|
r20581 | Test extension help: | ||
Matt Mackall
|
r20622 | $ hg help extensions --config extensions.rebase= --config extensions.children= | ||
Augie Fackler
|
r20581 | Using Additional Features | ||
""""""""""""""""""""""""" | ||||
Mercurial has the ability to add new features through the use of | ||||
extensions. Extensions may add new commands, add options to existing | ||||
commands, change the default behavior of commands, or implement hooks. | ||||
To enable the "foo" extension, either shipped with Mercurial or in the | ||||
Python search path, create an entry for it in your configuration file, | ||||
like this: | ||||
[extensions] | ||||
foo = | ||||
You may also specify the full path to an extension: | ||||
[extensions] | ||||
myfeature = ~/.hgext/myfeature.py | ||||
timeless
|
r27729 | See 'hg help config' for more information on configuration files. | ||
Augie Fackler
|
r20581 | |||
Extensions are not loaded by default for a variety of reasons: they can | ||||
increase startup overhead; they may be meant for advanced usage only; they | ||||
may provide potentially dangerous abilities (such as letting you destroy | ||||
or modify history); they might not be ready for prime time; or they may | ||||
alter some usual behaviors of stock Mercurial. It is thus up to the user | ||||
to activate extensions as needed. | ||||
To explicitly disable an extension enabled in a configuration file of | ||||
broader scope, prepend its path with !: | ||||
[extensions] | ||||
# disabling extension bar residing in /path/to/extension/bar.py | ||||
bar = !/path/to/extension/bar.py | ||||
# ditto, but no path was supplied for extension baz | ||||
baz = ! | ||||
enabled extensions: | ||||
Yuya Nishihara
|
r28610 | chgserver command server extension for cHg (EXPERIMENTAL) (?) | ||
Augie Fackler
|
r20581 | children command to display child changesets (DEPRECATED) | ||
rebase command to move sets of revisions to a different ancestor | ||||
disabled extensions: | ||||
acl hooks for controlling repository access | ||||
blackbox log repository events to a blackbox for debugging | ||||
bugzilla hooks for integrating with the Bugzilla bug tracker | ||||
Mike Edgar
|
r24347 | censor erase file content at a given revision | ||
Augie Fackler
|
r20581 | churn command to display statistics about repository history | ||
Gregory Szorc
|
r26762 | clonebundles advertise pre-generated bundles to seed clones | ||
Augie Fackler
|
r20581 | color colorize output from some commands | ||
convert import revisions from foreign VCS repositories into | ||||
Mercurial | ||||
eol automatically manage newlines in repository files | ||||
extdiff command to allow external programs to compare revisions | ||||
factotum http authentication with factotum | ||||
gpg commands to sign and verify changesets | ||||
hgk browse the repository in a graphical way | ||||
highlight syntax highlighting for hgweb (requires Pygments) | ||||
histedit interactive history editing | ||||
keyword expand keywords in tracked files | ||||
largefiles track large binary files | ||||
mq manage a stack of patches | ||||
notify hooks for sending email push notifications | ||||
pager browse command output with an external pager | ||||
patchbomb command to send changesets as (a series of) patch emails | ||||
purge command to delete untracked files from the working | ||||
directory | ||||
relink recreates hardlinks between repository clones | ||||
schemes extend schemes with shortcuts to repository swarms | ||||
share share a common history between several working directories | ||||
shelve save and restore changes to the working directory | ||||
Mads Kiilerich
|
r23139 | strip strip changesets and their descendants from history | ||
Augie Fackler
|
r20581 | transplant command to transplant changesets from another branch | ||
win32mbcs allow the use of MBCS paths with problematic encodings | ||||
zeroconf discover and advertise repositories on the local network | ||||
timeless@mozdev.org
|
r26487 | |||
Verify that extension keywords appear in help templates | ||||
$ hg help --config extensions.transplant= templating|grep transplant > /dev/null | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | Test short command list with verbose option | ||
$ hg -v help shortlist | ||||
Matt Mackall
|
r15020 | Mercurial Distributed SCM | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
basic commands: | ||||
Olav Reinert
|
r16853 | add add the specified files on the next commit | ||
annotate, blame | ||||
show changeset information by line for each file | ||||
clone make a copy of an existing repository | ||||
commit, ci commit the specified files or all outstanding changes | ||||
diff diff repository (or selected files) | ||||
export dump the header and diffs for one or more changesets | ||||
forget forget the specified files on the next commit | ||||
init create a new repository in the given directory | ||||
log, history show revision history of entire repository or files | ||||
anatoly techtonik
|
r23400 | merge merge another revision into working directory | ||
Olav Reinert
|
r16853 | pull pull changes from the specified source | ||
push push changes to the specified destination | ||||
remove, rm remove the specified files on the next commit | ||||
serve start stand-alone webserver | ||||
status, st show changed files in the working directory | ||||
summary, sum summarize working directory state | ||||
update, up, checkout, co | ||||
update working directory (or switch revisions) | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
Matt Mackall
|
r22117 | global options ([+] can be repeated): | ||
Matt Mackall
|
r15145 | |||
-R --repository REPO repository root directory or name of overlay bundle | ||||
file | ||||
--cwd DIR change working directory | ||||
-y --noninteractive do not prompt, automatically pick the first choice for | ||||
all prompts | ||||
Augie Fackler
|
r30024 | -q --[no-]quiet suppress output | ||
-v --[no-]verbose enable additional output | ||||
Matt Mackall
|
r15145 | --config CONFIG [+] set/override config option (use 'section.name=value') | ||
Augie Fackler
|
r30024 | --[no-]debug enable debugging output | ||
--[no-]debugger start debugger | ||||
Matt Mackall
|
r15145 | --encoding ENCODE set the charset encoding (default: ascii) | ||
--encodingmode MODE set the charset encoding mode (default: strict) | ||||
Augie Fackler
|
r30024 | --[no-]traceback always print a traceback on exception | ||
--[no-]time time how long the command takes | ||||
--[no-]profile print command execution profile | ||||
Matt Mackall
|
r15145 | --version output version information and exit | ||
-h --help display help and exit | ||||
Augie Fackler
|
r30024 | --[no-]hidden consider hidden changesets | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
timeless
|
r29974 | (use 'hg help' for the full list of commands) | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
$ hg add -h | ||||
hg add [OPTION]... [FILE]... | ||||
add the specified files on the next commit | ||||
Schedule files to be version controlled and added to the repository. | ||||
The files will be added to the repository at the next commit. To undo an | ||||
timeless
|
r27729 | add before that, see 'hg forget'. | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
timeless
|
r27424 | If no names are given, add all files to the repository (except files | ||
matching ".hgignore"). | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
Returns 0 if all files are successfully added. | ||||
Matt Mackall
|
r22117 | options ([+] can be repeated): | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
Matt Mackall
|
r15145 | -I --include PATTERN [+] include names matching the given patterns | ||
-X --exclude PATTERN [+] exclude names matching the given patterns | ||||
Augie Fackler
|
r30024 | -S --[no-]subrepos recurse into subrepositories | ||
-n --[no-]dry-run do not perform actions, just print output | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
Matt Mackall
|
r22110 | (some details hidden, use --verbose to show complete help) | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
Verbose help for add | ||||
$ hg add -hv | ||||
hg add [OPTION]... [FILE]... | ||||
add the specified files on the next commit | ||||
Schedule files to be version controlled and added to the repository. | ||||
The files will be added to the repository at the next commit. To undo an | ||||
timeless
|
r27729 | add before that, see 'hg forget'. | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
timeless
|
r27424 | If no names are given, add all files to the repository (except files | ||
matching ".hgignore"). | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
Mathias De Maré
|
r27143 | Examples: | ||
timeless
|
r27729 | - New (unknown) files are added automatically by 'hg add': | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
Mathias De Maré
|
r27143 | $ ls | ||
foo.c | ||||
$ hg status | ||||
? foo.c | ||||
$ hg add | ||||
adding foo.c | ||||
$ hg status | ||||
A foo.c | ||||
- Specific files to be added can be specified: | ||||
$ ls | ||||
bar.c foo.c | ||||
$ hg status | ||||
? bar.c | ||||
? foo.c | ||||
$ hg add bar.c | ||||
$ hg status | ||||
A bar.c | ||||
? foo.c | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
Returns 0 if all files are successfully added. | ||||
Matt Mackall
|
r22117 | options ([+] can be repeated): | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
Matt Mackall
|
r15145 | -I --include PATTERN [+] include names matching the given patterns | ||
-X --exclude PATTERN [+] exclude names matching the given patterns | ||||
Augie Fackler
|
r30024 | -S --[no-]subrepos recurse into subrepositories | ||
-n --[no-]dry-run do not perform actions, just print output | ||||
Matt Mackall
|
r15145 | |||
Matt Mackall
|
r22117 | global options ([+] can be repeated): | ||
Matt Mackall
|
r15145 | |||
-R --repository REPO repository root directory or name of overlay bundle | ||||
file | ||||
--cwd DIR change working directory | ||||
-y --noninteractive do not prompt, automatically pick the first choice for | ||||
all prompts | ||||
Augie Fackler
|
r30024 | -q --[no-]quiet suppress output | ||
-v --[no-]verbose enable additional output | ||||
Matt Mackall
|
r15145 | --config CONFIG [+] set/override config option (use 'section.name=value') | ||
Augie Fackler
|
r30024 | --[no-]debug enable debugging output | ||
--[no-]debugger start debugger | ||||
Matt Mackall
|
r15145 | --encoding ENCODE set the charset encoding (default: ascii) | ||
--encodingmode MODE set the charset encoding mode (default: strict) | ||||
Augie Fackler
|
r30024 | --[no-]traceback always print a traceback on exception | ||
--[no-]time time how long the command takes | ||||
--[no-]profile print command execution profile | ||||
Matt Mackall
|
r15145 | --version output version information and exit | ||
-h --help display help and exit | ||||
Augie Fackler
|
r30024 | --[no-]hidden consider hidden changesets | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
Jun Wu
|
r29070 | Test the textwidth config option | ||
$ hg root -h --config ui.textwidth=50 | ||||
hg root | ||||
print the root (top) of the current working | ||||
directory | ||||
Print the root directory of the current | ||||
repository. | ||||
Returns 0 on success. | ||||
(some details hidden, use --verbose to show | ||||
complete help) | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | Test help option with version option | ||
$ hg add -h --version | ||||
Brodie Rao
|
r12376 | Mercurial Distributed SCM (version *) (glob) | ||
Matt Mackall
|
r26421 | (see https://mercurial-scm.org for more information) | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
timeless
|
r27925 | Copyright (C) 2005-2016 Matt Mackall and others | ||
Dan Villiom Podlaski Christiansen
|
r12073 | This is free software; see the source for copying conditions. There is NO | ||
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. | ||||
$ hg add --skjdfks | ||||
hg add: option --skjdfks not recognized | ||||
hg add [OPTION]... [FILE]... | ||||
add the specified files on the next commit | ||||
Matt Mackall
|
r22117 | options ([+] can be repeated): | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
Matt Mackall
|
r15145 | -I --include PATTERN [+] include names matching the given patterns | ||
-X --exclude PATTERN [+] exclude names matching the given patterns | ||||
Augie Fackler
|
r30024 | -S --[no-]subrepos recurse into subrepositories | ||
-n --[no-]dry-run do not perform actions, just print output | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
timeless
|
r29974 | (use 'hg add -h' to show more help) | ||
Matt Mackall
|
r12316 | [255] | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
Test ambiguous command help | ||||
$ hg help ad | ||||
list of commands: | ||||
Olav Reinert
|
r16853 | add add the specified files on the next commit | ||
addremove add all new files, delete all missing files | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
timeless
|
r29974 | (use 'hg help -v ad' to show built-in aliases and global options) | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
Test command without options | ||||
$ hg help verify | ||||
hg verify | ||||
verify the integrity of the repository | ||||
Verify the integrity of the current repository. | ||||
This will perform an extensive check of the repository's integrity, | ||||
validating the hashes and checksums of each entry in the changelog, | ||||
manifest, and tracked files, as well as the integrity of their crosslinks | ||||
and indices. | ||||
Matt Mackall
|
r26421 | Please see https://mercurial-scm.org/wiki/RepositoryCorruption for more | ||
FUJIWARA Katsunori
|
r17717 | information about recovery from corruption of the repository. | ||
Dan Villiom Podlaski Christiansen
|
r12073 | Returns 0 on success, 1 if errors are encountered. | ||
Matt Mackall
|
r22110 | (some details hidden, use --verbose to show complete help) | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
$ hg help diff | ||||
hg diff [OPTION]... ([-c REV] | [-r REV1 [-r REV2]]) [FILE]... | ||||
diff repository (or selected files) | ||||
Show differences between revisions for the specified files. | ||||
Differences between files are shown using the unified diff format. | ||||
Erik Zielke
|
r12389 | Note: | ||
timeless
|
r27729 | 'hg diff' may generate unexpected results for merges, as it will | ||
timeless
|
r27476 | default to comparing against the working directory's first parent | ||
changeset if no revisions are specified. | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
When two revision arguments are given, then changes are shown between | ||||
those revisions. If only one revision is specified then that revision is | ||||
compared to the working directory, and, when no revisions are specified, | ||||
timeless
|
r27452 | the working directory files are compared to its first parent. | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
Alternatively you can specify -c/--change with a revision to see the | ||||
changes in that changeset relative to its first parent. | ||||
Without the -a/--text option, diff will avoid generating diffs of files it | ||||
detects as binary. With -a, diff will generate a diff anyway, probably | ||||
with undesirable results. | ||||
Use the -g/--git option to generate diffs in the git extended diff format. | ||||
timeless
|
r27729 | For more information, read 'hg help diffs'. | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
Returns 0 on success. | ||||
Matt Mackall
|
r22117 | options ([+] can be repeated): | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
Augie Fackler
|
r30024 | -r --rev REV [+] revision | ||
-c --change REV change made by revision | ||||
-a --[no-]text treat all files as text | ||||
-g --[no-]git use git extended diff format | ||||
--[no-]nodates omit dates from diff headers | ||||
--[no-]noprefix omit a/ and b/ prefixes from filenames | ||||
-p --[no-]show-function show which function each change is in | ||||
--[no-]reverse produce a diff that undoes the changes | ||||
-w --[no-]ignore-all-space ignore white space when comparing lines | ||||
-b --[no-]ignore-space-change ignore changes in the amount of white space | ||||
-B --[no-]ignore-blank-lines ignore changes whose lines are all blank | ||||
-U --unified NUM number of lines of context to show | ||||
--[no-]stat output diffstat-style summary of changes | ||||
--root DIR produce diffs relative to subdirectory | ||||
-I --include PATTERN [+] include names matching the given patterns | ||||
-X --exclude PATTERN [+] exclude names matching the given patterns | ||||
-S --[no-]subrepos recurse into subrepositories | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
Matt Mackall
|
r22110 | (some details hidden, use --verbose to show complete help) | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
$ hg help status | ||||
hg status [OPTION]... [FILE]... | ||||
aliases: st | ||||
show changed files in the working directory | ||||
Show status of files in the repository. If names are given, only files | ||||
that match are shown. Files that are clean or ignored or the source of a | ||||
copy/move operation, are not listed unless -c/--clean, -i/--ignored, | ||||
-C/--copies or -A/--all are given. Unless options described with "show | ||||
only ..." are given, the options -mardu are used. | ||||
Option -q/--quiet hides untracked (unknown and ignored) files unless | ||||
explicitly requested with -u/--unknown or -i/--ignored. | ||||
Christian Ebert
|
r12390 | Note: | ||
timeless
|
r27729 | 'hg status' may appear to disagree with diff if permissions have | ||
timeless
|
r27476 | changed or a merge has occurred. The standard diff format does not | ||
report permission changes and diff only reports changes relative to one | ||||
merge parent. | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
If one revision is given, it is used as the base revision. If two | ||||
revisions are given, the differences between them are shown. The --change | ||||
option can also be used as a shortcut to list the changed files of a | ||||
revision from its first parent. | ||||
The codes used to show the status of files are: | ||||
M = modified | ||||
A = added | ||||
R = removed | ||||
C = clean | ||||
! = missing (deleted by non-hg command, but still tracked) | ||||
? = not tracked | ||||
I = ignored | ||||
Matt Mackall
|
r20660 | = origin of the previous file (with --copies) | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
Returns 0 on success. | ||||
Matt Mackall
|
r22117 | options ([+] can be repeated): | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
Augie Fackler
|
r30024 | -A --[no-]all show status of all files | ||
-m --[no-]modified show only modified files | ||||
-a --[no-]added show only added files | ||||
-r --[no-]removed show only removed files | ||||
-d --[no-]deleted show only deleted (but tracked) files | ||||
-c --[no-]clean show only files without changes | ||||
-u --[no-]unknown show only unknown (not tracked) files | ||||
-i --[no-]ignored show only ignored files | ||||
-n --[no-]status hide status prefix | ||||
-C --[no-]copies show source of copied files | ||||
-0 --[no-]print0 end filenames with NUL, for use with xargs | ||||
Matt Mackall
|
r15145 | --rev REV [+] show difference from revision | ||
--change REV list the changed files of a revision | ||||
-I --include PATTERN [+] include names matching the given patterns | ||||
-X --exclude PATTERN [+] exclude names matching the given patterns | ||||
Augie Fackler
|
r30024 | -S --[no-]subrepos recurse into subrepositories | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
Matt Mackall
|
r22110 | (some details hidden, use --verbose to show complete help) | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
$ hg -q help status | ||||
hg status [OPTION]... [FILE]... | ||||
show changed files in the working directory | ||||
$ hg help foo | ||||
Pierre-Yves David
|
r21289 | abort: no such help topic: foo | ||
timeless
|
r29974 | (try 'hg help --keyword foo') | ||
Matt Mackall
|
r12316 | [255] | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
$ hg skjdfks | ||||
hg: unknown command 'skjdfks' | ||||
Mercurial Distributed SCM | ||||
basic commands: | ||||
Olav Reinert
|
r16853 | add add the specified files on the next commit | ||
annotate show changeset information by line for each file | ||||
clone make a copy of an existing repository | ||||
commit commit the specified files or all outstanding changes | ||||
diff diff repository (or selected files) | ||||
export dump the header and diffs for one or more changesets | ||||
forget forget the specified files on the next commit | ||||
init create a new repository in the given directory | ||||
log show revision history of entire repository or files | ||||
anatoly techtonik
|
r23400 | merge merge another revision into working directory | ||
Olav Reinert
|
r16853 | pull pull changes from the specified source | ||
push push changes to the specified destination | ||||
remove remove the specified files on the next commit | ||||
serve start stand-alone webserver | ||||
status show changed files in the working directory | ||||
summary summarize working directory state | ||||
update update working directory (or switch revisions) | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
timeless
|
r29974 | (use 'hg help' for the full list of commands or 'hg -v' for details) | ||
Matt Mackall
|
r12316 | [255] | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
Simon Heimberg
|
r20743 | |||
Jordi Gutiérrez Hermoso
|
r26364 | Make sure that we don't run afoul of the help system thinking that | ||
this is a section and erroring out weirdly. | ||||
$ hg .log | ||||
hg: unknown command '.log' | ||||
Bryan O'Sullivan
|
r27623 | (did you mean log?) | ||
Jordi Gutiérrez Hermoso
|
r26364 | [255] | ||
$ hg log. | ||||
hg: unknown command 'log.' | ||||
Bryan O'Sullivan
|
r27623 | (did you mean log?) | ||
Jordi Gutiérrez Hermoso
|
r26364 | [255] | ||
$ hg pu.lh | ||||
hg: unknown command 'pu.lh' | ||||
(did you mean one of pull, push?) | ||||
[255] | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | $ cat > helpext.py <<EOF | ||
> import os | ||||
Gregory Szorc
|
r21254 | > from mercurial import cmdutil, commands | ||
> | ||||
> cmdtable = {} | ||||
> command = cmdutil.command(cmdtable) | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | > | ||
Gregory Szorc
|
r21254 | > @command('nohelp', | ||
> [('', 'longdesc', 3, 'x'*90), | ||||
> ('n', '', None, 'normal desc'), | ||||
> ('', 'newline', '', 'line1\nline2')], | ||||
Gregory Szorc
|
r21773 | > 'hg nohelp', | ||
> norepo=True) | ||||
Yuya Nishihara
|
r26370 | > @command('debugoptDEP', [('', 'dopt', None, 'option is (DEPRECATED)')]) | ||
> @command('debugoptEXP', [('', 'eopt', None, 'option is (EXPERIMENTAL)')]) | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | > def nohelp(ui, *args, **kwargs): | ||
> pass | ||||
> | ||||
timeless
|
r28828 | > def uisetup(ui): | ||
> ui.setconfig('alias', 'shellalias', '!echo hi', 'helpext') | ||||
> ui.setconfig('alias', 'hgalias', 'summary', 'helpext') | ||||
> | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | > EOF | ||
$ echo '[extensions]' >> $HGRCPATH | ||||
$ echo "helpext = `pwd`/helpext.py" >> $HGRCPATH | ||||
timeless
|
r28828 | Test for aliases | ||
$ hg help hgalias | ||||
hg hgalias [--remote] | ||||
alias for: hg summary | ||||
summarize working directory state | ||||
This generates a brief summary of the working directory state, including | ||||
parents, branch, commit status, phase and available updates. | ||||
With the --remote option, this will check the default paths for incoming | ||||
and outgoing changes. This can be time-consuming. | ||||
Returns 0 on success. | ||||
defined by: helpext | ||||
options: | ||||
Augie Fackler
|
r30024 | --[no-]remote check for push and pull | ||
timeless
|
r28828 | |||
(some details hidden, use --verbose to show complete help) | ||||
$ hg help shellalias | ||||
hg shellalias | ||||
shell alias for: | ||||
echo hi | ||||
defined by: helpext | ||||
(some details hidden, use --verbose to show complete help) | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | Test command with no help text | ||
$ hg help nohelp | ||||
hg nohelp | ||||
(no help text available) | ||||
Simon Heimberg
|
r20654 | options: | ||
--longdesc VALUE xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx | ||||
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx (default: 3) | ||||
Augie Fackler
|
r30024 | -n --[no-] normal desc | ||
Simon Heimberg
|
r20654 | --newline VALUE line1 line2 | ||
Matt Mackall
|
r22110 | (some details hidden, use --verbose to show complete help) | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
Thomas Arendsen Hein
|
r16884 | $ hg help -k nohelp | ||
Commands: | ||||
nohelp hg nohelp | ||||
Extension Commands: | ||||
nohelp (no help text available) | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | Test that default list of commands omits extension commands | ||
$ hg help | ||||
Mercurial Distributed SCM | ||||
list of commands: | ||||
Olav Reinert
|
r15862 | add add the specified files on the next commit | ||
addremove add all new files, delete all missing files | ||||
annotate show changeset information by line for each file | ||||
archive create an unversioned archive of a repository revision | ||||
backout reverse effect of earlier changeset | ||||
bisect subdivision search of changesets | ||||
Matt Mackall
|
r21762 | bookmarks create a new bookmark or list existing bookmarks | ||
Olav Reinert
|
r15862 | branch set or show the current branch name | ||
branches list repository named branches | ||||
bundle create a changegroup file | ||||
cat output the current or given revision of files | ||||
clone make a copy of an existing repository | ||||
commit commit the specified files or all outstanding changes | ||||
Matt Mackall
|
r20570 | config show combined config settings from all hgrc files | ||
Olav Reinert
|
r15862 | copy mark files as copied for the next commit | ||
diff diff repository (or selected files) | ||||
export dump the header and diffs for one or more changesets | ||||
Matt Mackall
|
r22423 | files list tracked files | ||
Olav Reinert
|
r15862 | forget forget the specified files on the next commit | ||
graft copy changes from other branches onto the current branch | ||||
Kevin Bullock
|
r30009 | grep search revision history for a pattern in specified files | ||
Matt Mackall
|
r19469 | heads show branch heads | ||
Olav Reinert
|
r15862 | help show help for a given topic or a help overview | ||
Yuya Nishihara
|
r24364 | identify identify the working directory or specified revision | ||
Olav Reinert
|
r15862 | import import an ordered set of patches | ||
incoming show new changesets found in source | ||||
init create a new repository in the given directory | ||||
log show revision history of entire repository or files | ||||
manifest output the current or given revision of the project manifest | ||||
anatoly techtonik
|
r23400 | merge merge another revision into working directory | ||
Olav Reinert
|
r15862 | outgoing show changesets not found in the destination | ||
paths show aliases for remote repositories | ||||
phase set or show the current phase name | ||||
pull pull changes from the specified source | ||||
push push changes to the specified destination | ||||
recover roll back an interrupted transaction | ||||
remove remove the specified files on the next commit | ||||
rename rename files; equivalent of copy + remove | ||||
resolve redo merges or set/view the merge status of files | ||||
revert restore files to their checkout state | ||||
root print the root (top) of the current working directory | ||||
serve start stand-alone webserver | ||||
status show changed files in the working directory | ||||
summary summarize working directory state | ||||
tag add one or more tags for the current or given revision | ||||
tags list repository tags | ||||
unbundle apply one or more changegroup files | ||||
update update working directory (or switch revisions) | ||||
verify verify the integrity of the repository | ||||
version output version and copyright information | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
enabled extensions: | ||||
Olav Reinert
|
r15861 | helpext (no help text available) | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
additional help topics: | ||||
Olav Reinert
|
r15862 | config Configuration Files | ||
dates Date Formats | ||||
diffs Diff Formats | ||||
environment Environment Variables | ||||
Martin Geisler
|
r16547 | extensions Using Additional Features | ||
Olav Reinert
|
r15862 | filesets Specifying File Sets | ||
glossary Glossary | ||||
Martin Geisler
|
r16547 | hgignore Syntax for Mercurial Ignore Files | ||
Olav Reinert
|
r15862 | hgweb Configuring hgweb | ||
Gregory Szorc
|
r27376 | internals Technical implementation topics | ||
Olav Reinert
|
r15862 | merge-tools Merge Tools | ||
multirevs Specifying Multiple Revisions | ||||
patterns File Name Patterns | ||||
Matt Mackall
|
r15996 | phases Working with Phases | ||
Olav Reinert
|
r15862 | revisions Specifying Single Revisions | ||
revsets Specifying Revision Sets | ||||
Gregory Szorc
|
r25881 | scripting Using Mercurial from scripts and automation | ||
Olav Reinert
|
r15862 | subrepos Subrepositories | ||
templating Template Usage | ||||
urls URL Paths | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
timeless
|
r29974 | (use 'hg help -v' to show built-in aliases and global options) | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
Yun Lee
|
r13888 | |||
Mads Kiilerich
|
r20822 | Test list of internal help commands | ||
$ hg help debug | ||||
debug commands (internal and unsupported): | ||||
debugancestor | ||||
find the ancestor revision of two revisions in a given index | ||||
Gregory Szorc
|
r26758 | debugapplystreamclonebundle | ||
apply a stream clone bundle file | ||||
Mads Kiilerich
|
r20822 | debugbuilddag | ||
builds a repo with a given DAG from scratch in the current | ||||
empty repo | ||||
debugbundle lists the contents of a bundle | ||||
debugcheckstate | ||||
validate the correctness of the current dirstate | ||||
debugcommands | ||||
list all available commands and options | ||||
debugcomplete | ||||
returns the completion list associated with the given command | ||||
Gregory Szorc
|
r26757 | debugcreatestreamclonebundle | ||
create a stream clone bundle file | ||||
Mads Kiilerich
|
r20822 | debugdag format the changelog or an index DAG as a concise textual | ||
description | ||||
debugdata dump the contents of a data file revision | ||||
debugdate parse and display a date | ||||
Gregory Szorc
|
r27263 | debugdeltachain | ||
dump information about delta chains in a revlog | ||||
Mads Kiilerich
|
r20822 | debugdirstate | ||
show the contents of the current dirstate | ||||
debugdiscovery | ||||
runs the changeset discovery protocol in isolation | ||||
liscju
|
r26351 | debugextensions | ||
show information about active extensions | ||||
Mads Kiilerich
|
r20822 | debugfileset parse and apply a fileset specification | ||
debugfsinfo show information detected about current filesystem | ||||
debuggetbundle | ||||
retrieves a bundle from a repo | ||||
Laurent Charignon
|
r27671 | debugignore display the combined ignore pattern and information about | ||
ignored files | ||||
Mads Kiilerich
|
r20822 | debugindex dump the contents of an index file | ||
debugindexdot | ||||
dump an index DAG as a graphviz dot file | ||||
debuginstall test Mercurial installation | ||||
debugknown test whether node ids are known to a repo | ||||
Matt Mackall
|
r22559 | debuglocks show or modify state of locks | ||
Siddharth Agarwal
|
r26501 | debugmergestate | ||
print merge state | ||||
Sean Farley
|
r23762 | debugnamecomplete | ||
complete "names" - tags, open branch names, bookmark names | ||||
Mads Kiilerich
|
r20822 | debugobsolete | ||
create arbitrary obsolete marker | ||||
debugoptDEP (no help text available) | ||||
Siddharth Agarwal
|
r24871 | debugoptEXP (no help text available) | ||
Mads Kiilerich
|
r20822 | debugpathcomplete | ||
complete part or all of a tracked path | ||||
debugpushkey access the pushkey key/value protocol | ||||
debugpvec (no help text available) | ||||
debugrebuilddirstate | ||||
rebuild the dirstate as it would look like for the given | ||||
revision | ||||
Gregory Szorc
|
r25652 | debugrebuildfncache | ||
rebuild the fncache file | ||||
Mads Kiilerich
|
r20822 | debugrename dump rename information | ||
debugrevlog show data and statistics about a revlog | ||||
debugrevspec parse and apply a revision specification | ||||
debugsetparents | ||||
manually set the parents of the current working directory | ||||
debugsub (no help text available) | ||||
debugsuccessorssets | ||||
show set of successors for revision | ||||
Yuya Nishihara
|
r28548 | debugtemplate | ||
parse and apply a template | ||||
Mads Kiilerich
|
r20822 | debugwalk show how files match on given patterns | ||
debugwireargs | ||||
(no help text available) | ||||
timeless
|
r29974 | (use 'hg help -v debug' to show built-in aliases and global options) | ||
Mads Kiilerich
|
r20822 | |||
Gregory Szorc
|
r27376 | internals topic renders index of available sub-topics | ||
$ hg help internals | ||||
Technical implementation topics | ||||
""""""""""""""""""""""""""""""" | ||||
Gregory Szorc
|
r29747 | bundles Bundles | ||
changegroups Changegroups | ||||
requirements Repository Requirements | ||||
revlogs Revision Logs | ||||
Gregory Szorc
|
r29859 | wireprotocol Wire Protocol | ||
Yun Lee
|
r13888 | |||
Gregory Szorc
|
r27379 | sub-topics can be accessed | ||
$ hg help internals.changegroups | ||||
Gregory Szorc
|
r29747 | Changegroups | ||
"""""""""""" | ||||
Gregory Szorc
|
r27379 | |||
Changegroups are representations of repository revlog data, specifically | ||||
the changelog, manifest, and filelogs. | ||||
Augie Fackler
|
r27434 | There are 3 versions of changegroups: "1", "2", and "3". From a high- | ||
level, versions "1" and "2" are almost exactly the same, with the only | ||||
difference being a header on entries in the changeset segment. Version "3" | ||||
adds support for exchanging treemanifests and includes revlog flags in the | ||||
delta header. | ||||
Gregory Szorc
|
r27379 | |||
Changegroups consists of 3 logical segments: | ||||
+---------------------------------+ | ||||
| | | | | ||||
| changeset | manifest | filelogs | | ||||
| | | | | ||||
+---------------------------------+ | ||||
The principle building block of each segment is a *chunk*. A *chunk* is a | ||||
framed piece of data: | ||||
+---------------------------------------+ | ||||
| | | | ||||
| length | data | | ||||
| (32 bits) | <length> bytes | | ||||
| | | | ||||
+---------------------------------------+ | ||||
Each chunk starts with a 32-bit big-endian signed integer indicating the | ||||
length of the raw data that follows. | ||||
There is a special case chunk that has 0 length ("0x00000000"). We call | ||||
this an *empty chunk*. | ||||
Delta Groups | ||||
Gregory Szorc
|
r29747 | ============ | ||
Gregory Szorc
|
r27379 | |||
A *delta group* expresses the content of a revlog as a series of deltas, | ||||
or patches against previous revisions. | ||||
Delta groups consist of 0 or more *chunks* followed by the *empty chunk* | ||||
to signal the end of the delta group: | ||||
+------------------------------------------------------------------------+ | ||||
| | | | | | | ||||
| chunk0 length | chunk0 data | chunk1 length | chunk1 data | 0x0 | | ||||
| (32 bits) | (various) | (32 bits) | (various) | (32 bits) | | ||||
| | | | | | | ||||
+------------------------------------------------------------+-----------+ | ||||
Each *chunk*'s data consists of the following: | ||||
+-----------------------------------------+ | ||||
| | | | | ||||
| delta header | mdiff header | delta | | ||||
| (various) | (12 bytes) | (various) | | ||||
| | | | | ||||
+-----------------------------------------+ | ||||
The *length* field is the byte length of the remaining 3 logical pieces of | ||||
data. The *delta* is a diff from an existing entry in the changelog. | ||||
Augie Fackler
|
r27434 | The *delta header* is different between versions "1", "2", and "3" of the | ||
Gregory Szorc
|
r27379 | changegroup format. | ||
Version 1: | ||||
+------------------------------------------------------+ | ||||
| | | | | | ||||
| node | p1 node | p2 node | link node | | ||||
| (20 bytes) | (20 bytes) | (20 bytes) | (20 bytes) | | ||||
| | | | | | ||||
+------------------------------------------------------+ | ||||
Version 2: | ||||
+------------------------------------------------------------------+ | ||||
| | | | | | | ||||
| node | p1 node | p2 node | base node | link node | | ||||
| (20 bytes) | (20 bytes) | (20 bytes) | (20 bytes) | (20 bytes) | | ||||
| | | | | | | ||||
+------------------------------------------------------------------+ | ||||
Augie Fackler
|
r27434 | Version 3: | ||
+------------------------------------------------------------------------------+ | ||||
| | | | | | | | ||||
| node | p1 node | p2 node | base node | link node | flags | | ||||
| (20 bytes) | (20 bytes) | (20 bytes) | (20 bytes) | (20 bytes) | (2 bytes) | | ||||
| | | | | | | | ||||
+------------------------------------------------------------------------------+ | ||||
Gregory Szorc
|
r27379 | The *mdiff header* consists of 3 32-bit big-endian signed integers | ||
describing offsets at which to apply the following delta content: | ||||
+-------------------------------------+ | ||||
| | | | | ||||
| offset | old length | new length | | ||||
| (32 bits) | (32 bits) | (32 bits) | | ||||
| | | | | ||||
+-------------------------------------+ | ||||
In version 1, the delta is always applied against the previous node from | ||||
the changegroup or the first parent if this is the first entry in the | ||||
changegroup. | ||||
In version 2, the delta base node is encoded in the entry in the | ||||
changegroup. This allows the delta to be expressed against any parent, | ||||
which can result in smaller deltas and more efficient encoding of data. | ||||
Changeset Segment | ||||
Gregory Szorc
|
r29747 | ================= | ||
Gregory Szorc
|
r27379 | |||
The *changeset segment* consists of a single *delta group* holding | ||||
changelog data. It is followed by an *empty chunk* to denote the boundary | ||||
to the *manifests segment*. | ||||
Manifest Segment | ||||
Gregory Szorc
|
r29747 | ================ | ||
Gregory Szorc
|
r27379 | |||
The *manifest segment* consists of a single *delta group* holding manifest | ||||
data. It is followed by an *empty chunk* to denote the boundary to the | ||||
*filelogs segment*. | ||||
Filelogs Segment | ||||
Gregory Szorc
|
r29747 | ================ | ||
Gregory Szorc
|
r27379 | |||
The *filelogs* segment consists of multiple sub-segments, each | ||||
corresponding to an individual file whose data is being described: | ||||
+--------------------------------------+ | ||||
| | | | | | ||||
| filelog0 | filelog1 | filelog2 | ... | | ||||
| | | | | | ||||
+--------------------------------------+ | ||||
Augie Fackler
|
r27434 | In version "3" of the changegroup format, filelogs may include directory | ||
logs when treemanifests are in use. directory logs are identified by | ||||
having a trailing '/' on their filename (see below). | ||||
Gregory Szorc
|
r27379 | The final filelog sub-segment is followed by an *empty chunk* to denote | ||
the end of the segment and the overall changegroup. | ||||
Each filelog sub-segment consists of the following: | ||||
+------------------------------------------+ | ||||
| | | | | ||||
| filename size | filename | delta group | | ||||
| (32 bits) | (various) | (various) | | ||||
| | | | | ||||
+------------------------------------------+ | ||||
That is, a *chunk* consisting of the filename (not terminated or padded) | ||||
followed by N chunks constituting the *delta group* for this file. | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | Test list of commands with command with no help text | ||
$ hg help helpext | ||||
helpext extension - no help text available | ||||
list of commands: | ||||
Olav Reinert
|
r16853 | nohelp (no help text available) | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
timeless
|
r29974 | (use 'hg help -v helpext' to show built-in aliases and global options) | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
Simon Heimberg
|
r20743 | |||
Siddharth Agarwal
|
r24871 | test deprecated and experimental options are hidden in command help | ||
Simon Heimberg
|
r20743 | $ hg help debugoptDEP | ||
hg debugoptDEP | ||||
(no help text available) | ||||
options: | ||||
Matt Mackall
|
r22110 | (some details hidden, use --verbose to show complete help) | ||
Simon Heimberg
|
r20743 | |||
Siddharth Agarwal
|
r24871 | $ hg help debugoptEXP | ||
hg debugoptEXP | ||||
(no help text available) | ||||
options: | ||||
(some details hidden, use --verbose to show complete help) | ||||
test deprecated and experimental options is shown with -v | ||||
Simon Heimberg
|
r20743 | $ hg help -v debugoptDEP | grep dopt | ||
Augie Fackler
|
r30024 | --[no-]dopt option is (DEPRECATED) | ||
Siddharth Agarwal
|
r24871 | $ hg help -v debugoptEXP | grep eopt | ||
Augie Fackler
|
r30024 | --[no-]eopt option is (EXPERIMENTAL) | ||
Simon Heimberg
|
r20743 | |||
Kent Frazier
|
r21039 | #if gettext | ||
Simon Heimberg
|
r20743 | test deprecated option is hidden with translation with untranslated description | ||
(use many globy for not failing on changed transaction) | ||||
$ LANGUAGE=sv hg help debugoptDEP | ||||
hg debugoptDEP | ||||
(*) (glob) | ||||
Matt Mackall
|
r22116 | options: | ||
Simon Heimberg
|
r20743 | |||
Matt Mackall
|
r22110 | (some details hidden, use --verbose to show complete help) | ||
Kent Frazier
|
r21039 | #endif | ||
Simon Heimberg
|
r20743 | |||
Matt Mackall
|
r21961 | Test commands that collide with topics (issue4240) | ||
$ hg config -hq | ||||
hg config [-u] [NAME]... | ||||
show combined config settings from all hgrc files | ||||
$ hg showconfig -hq | ||||
hg config [-u] [NAME]... | ||||
show combined config settings from all hgrc files | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | Test a help topic | ||
$ hg help revs | ||||
Specifying Single Revisions | ||||
Dan Villiom Podlaski Christiansen
|
r18748 | """"""""""""""""""""""""""" | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
Mercurial supports several ways to specify individual revisions. | ||||
A plain integer is treated as a revision number. Negative integers are | ||||
treated as sequential offsets from the tip, with -1 denoting the tip, -2 | ||||
denoting the revision prior to the tip, and so forth. | ||||
A 40-digit hexadecimal string is treated as a unique revision identifier. | ||||
A hexadecimal string less than 40 characters long is treated as a unique | ||||
revision identifier and is referred to as a short-form identifier. A | ||||
short-form identifier is only valid if it is the prefix of exactly one | ||||
full-length identifier. | ||||
Kevin Bullock
|
r16740 | Any other string is treated as a bookmark, tag, or branch name. A bookmark | ||
is a movable pointer to a revision. A tag is a permanent name associated | ||||
Mads Kiilerich
|
r20245 | with a revision. A branch name denotes the tipmost open branch head of | ||
that branch - or if they are all closed, the tipmost closed head of the | ||||
Kevin Bullock
|
r16740 | branch. Bookmark, tag, and branch names must not contain the ":" | ||
character. | ||||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
Kevin Bullock
|
r16740 | The reserved name "tip" always identifies the most recent revision. | ||
Dan Villiom Podlaski Christiansen
|
r12073 | |||
The reserved name "null" indicates the null revision. This is the revision | ||||
of an empty repository, and the parent of revision 0. | ||||
The reserved name "." indicates the working directory parent. If no | ||||
working directory is checked out, it is equivalent to null. If an | ||||
uncommitted merge is in progress, "." is the revision of the first parent. | ||||
Patrick Mezard
|
r12820 | |||
timeless@mozdev.org
|
r26113 | Test repeated config section name | ||
$ hg help config.host | ||||
"http_proxy.host" | ||||
Host name and (optional) port of the proxy server, for example | ||||
"myproxy:8000". | ||||
"smtp.host" | ||||
Host name of mail server, e.g. "mail.example.com". | ||||
timeless@mozdev.org
|
r26170 | Unrelated trailing paragraphs shouldn't be included | ||
$ hg help config.extramsg | grep '^$' | ||||
timeless@mozdev.org
|
r26159 | Test capitalized section name | ||
$ hg help scripting.HGPLAIN > /dev/null | ||||
timeless@mozdev.org
|
r26157 | Help subsection: | ||
$ hg help config.charsets |grep "Email example:" > /dev/null | ||||
[1] | ||||
timeless@mozdev.org
|
r26237 | Show nested definitions | ||
("profiling.type"[break]"ls"[break]"stat"[break]) | ||||
$ hg help config.type | egrep '^$'|wc -l | ||||
\s*3 (re) | ||||
timeless
|
r27614 | Separate sections from subsections | ||
$ hg help config.format | egrep '^ ("|-)|^\s*$' | uniq | ||||
"format" | ||||
-------- | ||||
"usegeneraldelta" | ||||
"dotencode" | ||||
"usefncache" | ||||
"usestore" | ||||
"profiling" | ||||
----------- | ||||
"format" | ||||
"progress" | ||||
---------- | ||||
"format" | ||||
timeless@mozdev.org
|
r26157 | Last item in help config.*: | ||
$ hg help config.`hg help config|grep '^ "'| \ | ||||
> tail -1|sed 's![ "]*!!g'`| \ | ||||
timeless
|
r29979 | > grep 'hg help -c config' > /dev/null | ||
timeless@mozdev.org
|
r26157 | [1] | ||
note to use help -c for general hg help config: | ||||
timeless
|
r29979 | $ hg help config |grep 'hg help -c config' > /dev/null | ||
timeless@mozdev.org
|
r26157 | |||
Patrick Mezard
|
r13584 | Test templating help | ||
$ hg help templating | egrep '(desc|diffstat|firstline|nonempty) ' | ||||
Olav Reinert
|
r15861 | desc String. The text of the changeset description. | ||
diffstat String. Statistics of changes with the following format: | ||||
firstline Any text. Returns the first line of text. | ||||
nonempty Any text. Returns '(none)' if the string is empty. | ||||
Patrick Mezard
|
r13584 | |||
Yuya Nishihara
|
r26415 | Test deprecated items | ||
$ hg help -v templating | grep currentbookmark | ||||
currentbookmark | ||||
$ hg help templating | (grep currentbookmark || true) | ||||
Patrick Mezard
|
r12820 | Test help hooks | ||
$ cat > helphook1.py <<EOF | ||||
> from mercurial import help | ||||
> | ||||
Yuya Nishihara
|
r26414 | > def rewrite(ui, topic, doc): | ||
Patrick Mezard
|
r12820 | > return doc + '\nhelphook1\n' | ||
> | ||||
> def extsetup(ui): | ||||
> help.addtopichook('revsets', rewrite) | ||||
> EOF | ||||
$ cat > helphook2.py <<EOF | ||||
> from mercurial import help | ||||
> | ||||
Yuya Nishihara
|
r26414 | > def rewrite(ui, topic, doc): | ||
Patrick Mezard
|
r12820 | > return doc + '\nhelphook2\n' | ||
> | ||||
> def extsetup(ui): | ||||
> help.addtopichook('revsets', rewrite) | ||||
> EOF | ||||
$ echo '[extensions]' >> $HGRCPATH | ||||
$ echo "helphook1 = `pwd`/helphook1.py" >> $HGRCPATH | ||||
$ echo "helphook2 = `pwd`/helphook2.py" >> $HGRCPATH | ||||
$ hg help revsets | grep helphook | ||||
helphook1 | ||||
helphook2 | ||||
Olav Reinert
|
r16942 | |||
timeless
|
r27324 | help -c should only show debug --debug | ||
timeless
|
r27325 | $ hg help -c --debug|egrep debug|wc -l|egrep '^\s*0\s*$' | ||
timeless
|
r27324 | [1] | ||
help -c should only show deprecated for -v | ||||
timeless
|
r27325 | $ hg help -c -v|egrep DEPRECATED|wc -l|egrep '^\s*0\s*$' | ||
timeless
|
r27324 | [1] | ||
timeless
|
r27763 | Test -s / --system | ||
$ hg help config.files -s windows |grep 'etc/mercurial' | \ | ||||
> wc -l | sed -e 's/ //g' | ||||
0 | ||||
$ hg help config.files --system unix | grep 'USER' | \ | ||||
> wc -l | sed -e 's/ //g' | ||||
0 | ||||
timeless@mozdev.org
|
r26238 | Test -e / -c / -k combinations | ||
timeless
|
r27386 | $ hg help -c|egrep '^[A-Z].*:|^ debug' | ||
timeless
|
r27325 | Commands: | ||
timeless
|
r27386 | $ hg help -e|egrep '^[A-Z].*:|^ debug' | ||
timeless
|
r27325 | Extensions: | ||
timeless
|
r27387 | $ hg help -k|egrep '^[A-Z].*:|^ debug' | ||
timeless
|
r27325 | Topics: | ||
Commands: | ||||
Extensions: | ||||
Extension Commands: | ||||
Yuya Nishihara
|
r27115 | $ hg help -c schemes | ||
abort: no such help topic: schemes | ||||
timeless
|
r29974 | (try 'hg help --keyword schemes') | ||
timeless@mozdev.org
|
r26238 | [255] | ||
Yuya Nishihara
|
r27115 | $ hg help -e schemes |head -1 | ||
schemes extension - extend schemes with shortcuts to repository swarms | ||||
timeless@mozdev.org
|
r26238 | $ hg help -c -k dates |egrep '^(Topics|Extensions|Commands):' | ||
Commands: | ||||
$ hg help -e -k a |egrep '^(Topics|Extensions|Commands):' | ||||
Extensions: | ||||
$ hg help -e -c -k date |egrep '^(Topics|Extensions|Commands):' | ||||
Extensions: | ||||
Commands: | ||||
$ hg help -c commit > /dev/null | ||||
$ hg help -e -c commit > /dev/null | ||||
$ hg help -e commit > /dev/null | ||||
abort: no such help topic: commit | ||||
timeless
|
r29974 | (try 'hg help --keyword commit') | ||
timeless@mozdev.org
|
r26238 | [255] | ||
Olav Reinert
|
r16942 | Test keyword search help | ||
FUJIWARA Katsunori
|
r19769 | $ cat > prefixedname.py <<EOF | ||
> '''matched against word "clone" | ||||
> ''' | ||||
> EOF | ||||
$ echo '[extensions]' >> $HGRCPATH | ||||
$ echo "dot.dot.prefixedname = `pwd`/prefixedname.py" >> $HGRCPATH | ||||
Olav Reinert
|
r16942 | $ hg help -k clone | ||
Topics: | ||||
config Configuration Files | ||||
extensions Using Additional Features | ||||
glossary Glossary | ||||
phases Working with Phases | ||||
Mads Kiilerich
|
r17322 | subrepos Subrepositories | ||
Olav Reinert
|
r16942 | urls URL Paths | ||
Commands: | ||||
timeless
|
r27324 | bookmarks create a new bookmark or list existing bookmarks | ||
clone make a copy of an existing repository | ||||
paths show aliases for remote repositories | ||||
update update working directory (or switch revisions) | ||||
Olav Reinert
|
r16942 | |||
Extensions: | ||||
Gregory Szorc
|
r27738 | clonebundles advertise pre-generated bundles to seed clones | ||
FUJIWARA Katsunori
|
r19769 | prefixedname matched against word "clone" | ||
relink recreates hardlinks between repository clones | ||||
Olav Reinert
|
r16942 | |||
Extension Commands: | ||||
qclone clone main and patch repository at same time | ||||
Pierre-Yves David
|
r21289 | Test unfound topic | ||
$ hg help nonexistingtopicthatwillneverexisteverever | ||||
abort: no such help topic: nonexistingtopicthatwillneverexisteverever | ||||
timeless
|
r29974 | (try 'hg help --keyword nonexistingtopicthatwillneverexisteverever') | ||
Pierre-Yves David
|
r21289 | [255] | ||
Pierre-Yves David
|
r21288 | Test unfound keyword | ||
$ hg help --keyword nonexistingwordthatwillneverexisteverever | ||||
abort: no matches | ||||
timeless
|
r29974 | (try 'hg help' for a list of topics) | ||
Pierre-Yves David
|
r21288 | [255] | ||
FUJIWARA Katsunori
|
r17837 | Test omit indicating for help | ||
$ cat > addverboseitems.py <<EOF | ||||
> '''extension to test omit indicating. | ||||
> | ||||
> This paragraph is never omitted (for extension) | ||||
> | ||||
> .. container:: verbose | ||||
> | ||||
> This paragraph is omitted, | ||||
André Sintzoff
|
r23612 | > if :hg:\`help\` is invoked without \`\`-v\`\` (for extension) | ||
FUJIWARA Katsunori
|
r17837 | > | ||
> This paragraph is never omitted, too (for extension) | ||||
> ''' | ||||
> | ||||
> from mercurial import help, commands | ||||
> testtopic = """This paragraph is never omitted (for topic). | ||||
> | ||||
> .. container:: verbose | ||||
> | ||||
> This paragraph is omitted, | ||||
André Sintzoff
|
r23612 | > if :hg:\`help\` is invoked without \`\`-v\`\` (for topic) | ||
FUJIWARA Katsunori
|
r17837 | > | ||
> This paragraph is never omitted, too (for topic) | ||||
> """ | ||||
> def extsetup(ui): | ||||
> help.helptable.append((["topic-containing-verbose"], | ||||
> "This is the topic to test omit indicating.", | ||||
Yuya Nishihara
|
r26413 | > lambda ui: testtopic)) | ||
FUJIWARA Katsunori
|
r17837 | > EOF | ||
$ echo '[extensions]' >> $HGRCPATH | ||||
$ echo "addverboseitems = `pwd`/addverboseitems.py" >> $HGRCPATH | ||||
$ hg help addverboseitems | ||||
addverboseitems extension - extension to test omit indicating. | ||||
This paragraph is never omitted (for extension) | ||||
This paragraph is never omitted, too (for extension) | ||||
Matt Mackall
|
r22114 | (some details hidden, use --verbose to show complete help) | ||
FUJIWARA Katsunori
|
r17837 | |||
no commands defined | ||||
$ hg help -v addverboseitems | ||||
addverboseitems extension - extension to test omit indicating. | ||||
This paragraph is never omitted (for extension) | ||||
timeless
|
r27729 | This paragraph is omitted, if 'hg help' is invoked without "-v" (for | ||
André Sintzoff
|
r23612 | extension) | ||
FUJIWARA Katsunori
|
r17837 | |||
This paragraph is never omitted, too (for extension) | ||||
no commands defined | ||||
$ hg help topic-containing-verbose | ||||
This is the topic to test omit indicating. | ||||
Dan Villiom Podlaski Christiansen
|
r18748 | """""""""""""""""""""""""""""""""""""""""" | ||
FUJIWARA Katsunori
|
r17837 | |||
This paragraph is never omitted (for topic). | ||||
This paragraph is never omitted, too (for topic) | ||||
Matt Mackall
|
r22114 | (some details hidden, use --verbose to show complete help) | ||
FUJIWARA Katsunori
|
r17837 | $ hg help -v topic-containing-verbose | ||
This is the topic to test omit indicating. | ||||
Dan Villiom Podlaski Christiansen
|
r18748 | """""""""""""""""""""""""""""""""""""""""" | ||
FUJIWARA Katsunori
|
r17837 | |||
This paragraph is never omitted (for topic). | ||||
timeless
|
r27729 | This paragraph is omitted, if 'hg help' is invoked without "-v" (for | ||
André Sintzoff
|
r23612 | topic) | ||
FUJIWARA Katsunori
|
r17837 | |||
This paragraph is never omitted, too (for topic) | ||||
Matt Mackall
|
r22587 | Test section lookup | ||
$ hg help revset.merge | ||||
"merge()" | ||||
Changeset is a merge changeset. | ||||
$ hg help glossary.dag | ||||
DAG | ||||
The repository of changesets of a distributed version control system | ||||
(DVCS) can be described as a directed acyclic graph (DAG), consisting | ||||
of nodes and edges, where nodes correspond to changesets and edges | ||||
imply a parent -> child relation. This graph can be visualized by | ||||
timeless
|
r27729 | graphical tools such as 'hg log --graph'. In Mercurial, the DAG is | ||
Matt Mackall
|
r22587 | limited by the requirement for children to have at most two parents. | ||
Jordi Gutiérrez Hermoso
|
r22770 | |||
$ hg help hgrc.paths | ||||
"paths" | ||||
------- | ||||
Gregory Szorc
|
r27266 | Assigns symbolic names and behavior to repositories. | ||
Options are symbolic names defining the URL or directory that is the | ||||
location of the repository. Example: | ||||
[paths] | ||||
my_server = https://example.com/my_repo | ||||
local_path = /home/me/repo | ||||
These symbolic names can be used from the command line. To pull from | ||||
timeless
|
r27729 | "my_server": 'hg pull my_server'. To push to "local_path": 'hg push | ||
local_path'. | ||||
Gregory Szorc
|
r27266 | |||
Options containing colons (":") denote sub-options that can influence | ||||
behavior for that specific path. Example: | ||||
[paths] | ||||
my_server = https://example.com/my_path | ||||
my_server:pushurl = ssh://example.com/my_path | ||||
The following sub-options can be defined: | ||||
"pushurl" | ||||
The URL to use for push operations. If not defined, the location | ||||
defined by the path's main entry is used. | ||||
Gregory Szorc
|
r29413 | "pushrev" | ||
A revset defining which revisions to push by default. | ||||
When 'hg push' is executed without a "-r" argument, the revset defined | ||||
by this sub-option is evaluated to determine what to push. | ||||
For example, a value of "." will push the working directory's revision | ||||
by default. | ||||
Revsets specifying bookmarks will not result in the bookmark being | ||||
pushed. | ||||
Gregory Szorc
|
r27266 | The following special named paths exist: | ||
Jordi Gutiérrez Hermoso
|
r22770 | |||
"default" | ||||
Gregory Szorc
|
r27266 | The URL or directory to use when no source or remote is specified. | ||
timeless
|
r27729 | 'hg clone' will automatically define this path to the location the | ||
Gregory Szorc
|
r27266 | repository was cloned from. | ||
Jordi Gutiérrez Hermoso
|
r22770 | |||
"default-push" | ||||
timeless
|
r27729 | (deprecated) The URL or directory for the default 'hg push' location. | ||
Gregory Szorc
|
r27266 | "default:pushurl" should be used instead. | ||
Jordi Gutiérrez Hermoso
|
r22770 | |||
Matt Mackall
|
r22587 | $ hg help glossary.mcguffin | ||
abort: help section not found | ||||
[255] | ||||
Mads Kiilerich
|
r23122 | $ hg help glossary.mc.guffin | ||
abort: help section not found | ||||
[255] | ||||
Matt Harbison
|
r25723 | $ hg help template.files | ||
files List of strings. All files modified, added, or removed by | ||||
this changeset. | ||||
Hannes Oldenburg
|
r30008 | files(pattern) | ||
All files of the current changeset matching the pattern. See | ||||
'hg help patterns'. | ||||
Matt Harbison
|
r25723 | |||
FUJIWARA Katsunori
|
r29155 | Test section lookup by translated message | ||
str.lower() instead of encoding.lower(str) on translated message might | ||||
make message meaningless, because some encoding uses 0x41(A) - 0x5a(Z) | ||||
as the second or later byte of multi-byte character. | ||||
For example, "\x8bL\x98^" (translation of "record" in ja_JP.cp932) | ||||
contains 0x4c (L). str.lower() replaces 0x4c(L) by 0x6c(l) and this | ||||
replacement makes message meaningless. | ||||
This tests that section lookup by translated string isn't broken by | ||||
such str.lower(). | ||||
$ python <<EOF | ||||
> def escape(s): | ||||
> return ''.join('\u%x' % ord(uc) for uc in s.decode('cp932')) | ||||
> # translation of "record" in ja_JP.cp932 | ||||
> upper = "\x8bL\x98^" | ||||
> # str.lower()-ed section name should be treated as different one | ||||
> lower = "\x8bl\x98^" | ||||
> with open('ambiguous.py', 'w') as fp: | ||||
> fp.write("""# ambiguous section names in ja_JP.cp932 | ||||
> u'''summary of extension | ||||
> | ||||
> %s | ||||
> ---- | ||||
> | ||||
> Upper name should show only this message | ||||
> | ||||
> %s | ||||
> ---- | ||||
> | ||||
> Lower name should show only this message | ||||
> | ||||
> subsequent section | ||||
> ------------------ | ||||
> | ||||
timeless
|
r29979 | > This should be hidden at 'hg help ambiguous' with section name. | ||
FUJIWARA Katsunori
|
r29155 | > ''' | ||
> """ % (escape(upper), escape(lower))) | ||||
> EOF | ||||
$ cat >> $HGRCPATH <<EOF | ||||
> [extensions] | ||||
> ambiguous = ./ambiguous.py | ||||
> EOF | ||||
$ python <<EOF | sh | ||||
> upper = "\x8bL\x98^" | ||||
> print "hg --encoding cp932 help -e ambiguous.%s" % upper | ||||
> EOF | ||||
\x8bL\x98^ (esc) | ||||
---- | ||||
Upper name should show only this message | ||||
$ python <<EOF | sh | ||||
> lower = "\x8bl\x98^" | ||||
> print "hg --encoding cp932 help -e ambiguous.%s" % lower | ||||
> EOF | ||||
\x8bl\x98^ (esc) | ||||
---- | ||||
Lower name should show only this message | ||||
$ cat >> $HGRCPATH <<EOF | ||||
> [extensions] | ||||
> ambiguous = ! | ||||
> EOF | ||||
liscju
|
r29895 | Show help content of disabled extensions | ||
$ cat >> $HGRCPATH <<EOF | ||||
> [extensions] | ||||
> ambiguous = !./ambiguous.py | ||||
> EOF | ||||
$ hg help -e ambiguous | ||||
ambiguous extension - (no help text available) | ||||
timeless
|
r29974 | (use 'hg help extensions' for information on enabling extensions) | ||
liscju
|
r29895 | |||
Augie Fackler
|
r24100 | Test dynamic list of merge tools only shows up once | ||
$ hg help merge-tools | ||||
Merge Tools | ||||
""""""""""" | ||||
To merge files Mercurial uses merge tools. | ||||
A merge tool combines two different versions of a file into a merged file. | ||||
Merge tools are given the two files and the greatest common ancestor of | ||||
the two file versions, so they can determine the changes made on both | ||||
branches. | ||||
timeless
|
r27729 | Merge tools are used both for 'hg resolve', 'hg merge', 'hg update', 'hg | ||
backout' and in several extensions. | ||||
Augie Fackler
|
r24100 | |||
Usually, the merge tool tries to automatically reconcile the files by | ||||
combining all non-overlapping changes that occurred separately in the two | ||||
different evolutions of the same initial base file. Furthermore, some | ||||
interactive merge programs make it easier to manually resolve conflicting | ||||
merges, either in a graphical way, or by inserting some conflict markers. | ||||
Mercurial does not include any interactive merge programs but relies on | ||||
external tools for that. | ||||
Available merge tools | ||||
===================== | ||||
External merge tools and their properties are configured in the merge- | ||||
tools configuration section - see hgrc(5) - but they can often just be | ||||
named by their executable. | ||||
A merge tool is generally usable if its executable can be found on the | ||||
system and if it can handle the merge. The executable is found if it is an | ||||
absolute or relative executable path or the name of an application in the | ||||
executable search path. The tool is assumed to be able to handle the merge | ||||
if it can handle symlinks if the file is a symlink, if it can handle | ||||
binary files if the file is binary, and if a GUI is available if the tool | ||||
requires a GUI. | ||||
There are some internal merge tools which can be used. The internal merge | ||||
tools are: | ||||
":dump" | ||||
Creates three versions of the files to merge, containing the contents of | ||||
local, other and base. These files can then be used to perform a merge | ||||
manually. If the file to be merged is named "a.txt", these files will | ||||
accordingly be named "a.txt.local", "a.txt.other" and "a.txt.base" and | ||||
they will be placed in the same directory as "a.txt". | ||||
":fail" | ||||
Rather than attempting to merge files that were modified on both | ||||
branches, it marks them as unresolved. The resolve command must be used | ||||
to resolve these conflicts. | ||||
":local" | ||||
timeless
|
r28640 | Uses the local 'p1()' version of files as the merged version. | ||
Augie Fackler
|
r24100 | |||
":merge" | ||||
Uses the internal non-interactive simple merge algorithm for merging | ||||
files. It will fail if there are any conflicts and leave markers in the | ||||
partially merged file. Markers will have two sections, one for each side | ||||
of merge. | ||||
Jordi Gutiérrez Hermoso
|
r26224 | ":merge-local" | ||
Like :merge, but resolve all conflicts non-interactively in favor of the | ||||
timeless
|
r28640 | local 'p1()' changes. | ||
Jordi Gutiérrez Hermoso
|
r26224 | |||
":merge-other" | ||||
Like :merge, but resolve all conflicts non-interactively in favor of the | ||||
timeless
|
r28640 | other 'p2()' changes. | ||
Jordi Gutiérrez Hermoso
|
r26224 | |||
Augie Fackler
|
r24100 | ":merge3" | ||
Uses the internal non-interactive simple merge algorithm for merging | ||||
files. It will fail if there are any conflicts and leave markers in the | ||||
partially merged file. Marker will have three sections, one from each | ||||
side of the merge and one for the base content. | ||||
":other" | ||||
timeless
|
r28640 | Uses the other 'p2()' version of files as the merged version. | ||
Augie Fackler
|
r24100 | |||
":prompt" | ||||
timeless
|
r28640 | Asks the user which of the local 'p1()' or the other 'p2()' version to | ||
keep as the merged version. | ||||
Augie Fackler
|
r24100 | |||
":tagmerge" | ||||
Uses the internal tag merge algorithm (experimental). | ||||
Erik Huelsmann
|
r26071 | ":union" | ||
Uses the internal non-interactive simple merge algorithm for merging | ||||
files. It will use both left and right sides for conflict regions. No | ||||
markers are inserted. | ||||
Augie Fackler
|
r24100 | Internal tools are always available and do not require a GUI but will by | ||
default not handle symlinks or binary files. | ||||
Choosing a merge tool | ||||
===================== | ||||
Mercurial uses these rules when deciding which merge tool to use: | ||||
1. If a tool has been specified with the --tool option to merge or | ||||
resolve, it is used. If it is the name of a tool in the merge-tools | ||||
configuration, its configuration is used. Otherwise the specified tool | ||||
must be executable by the shell. | ||||
2. If the "HGMERGE" environment variable is present, its value is used and | ||||
must be executable by the shell. | ||||
3. If the filename of the file to be merged matches any of the patterns in | ||||
the merge-patterns configuration section, the first usable merge tool | ||||
corresponding to a matching pattern is used. Here, binary capabilities | ||||
of the merge tool are not considered. | ||||
4. If ui.merge is set it will be considered next. If the value is not the | ||||
name of a configured tool, the specified value is used and must be | ||||
executable by the shell. Otherwise the named tool is used if it is | ||||
usable. | ||||
5. If any usable merge tools are present in the merge-tools configuration | ||||
section, the one with the highest priority is used. | ||||
6. If a program named "hgmerge" can be found on the system, it is used - | ||||
but it will by default not be used for symlinks and binary files. | ||||
7. If the file to be merged is not binary and is not a symlink, then | ||||
internal ":merge" is used. | ||||
8. The merge of the file fails and must be resolved before commit. | ||||
Note: | ||||
After selecting a merge program, Mercurial will by default attempt to | ||||
merge the files using a simple merge algorithm first. Only if it | ||||
doesn't succeed because of conflicting changes Mercurial will actually | ||||
execute the merge program. Whether to use the simple merge algorithm | ||||
first can be controlled by the premerge setting of the merge tool. | ||||
Premerge is enabled by default unless the file is binary or a symlink. | ||||
See the merge-tools and ui sections of hgrc(5) for details on the | ||||
configuration of merge tools. | ||||
FUJIWARA Katsunori
|
r17648 | Test usage of section marks in help documents | ||
$ cd "$TESTDIR"/../doc | ||||
$ python check-seclevel.py | ||||
Dan Villiom Podlaski Christiansen
|
r18744 | $ cd $TESTTMP | ||
#if serve | ||||
Test the help pages in hgweb. | ||||
Dish up an empty repo; serve it cold. | ||||
$ hg init "$TESTTMP/test" | ||||
$ hg serve -R "$TESTTMP/test" -n test -p $HGPORT -d --pid-file=hg.pid | ||||
$ cat hg.pid >> $DAEMON_PIDS | ||||
Matt Mackall
|
r25472 | $ get-with-headers.py 127.0.0.1:$HGPORT "help" | ||
Dan Villiom Podlaski Christiansen
|
r18744 | 200 Script output follows | ||
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> | ||||
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en-US"> | ||||
<head> | ||||
<link rel="icon" href="/static/hgicon.png" type="image/png" /> | ||||
<meta name="robots" content="index, nofollow" /> | ||||
<link rel="stylesheet" href="/static/style-paper.css" type="text/css" /> | ||||
<script type="text/javascript" src="/static/mercurial.js"></script> | ||||
<title>Help: Index</title> | ||||
</head> | ||||
<body> | ||||
<div class="container"> | ||||
<div class="menu"> | ||||
<div class="logo"> | ||||
Matt Mackall
|
r26421 | <a href="https://mercurial-scm.org/"> | ||
Dan Villiom Podlaski Christiansen
|
r18744 | <img src="/static/hglogo.png" alt="mercurial" /></a> | ||
</div> | ||||
<ul> | ||||
<li><a href="/shortlog">log</a></li> | ||||
<li><a href="/graph">graph</a></li> | ||||
<li><a href="/tags">tags</a></li> | ||||
<li><a href="/bookmarks">bookmarks</a></li> | ||||
<li><a href="/branches">branches</a></li> | ||||
</ul> | ||||
<ul> | ||||
<li class="active">help</li> | ||||
</ul> | ||||
</div> | ||||
<div class="main"> | ||||
<h2 class="breadcrumb"><a href="/">Mercurial</a> </h2> | ||||
<form class="search" action="/log"> | ||||
<p><input name="rev" id="search1" type="text" size="30" /></p> | ||||
Alexander Plavin
|
r19796 | <div id="hint">Find changesets by keywords (author, files, the commit message), revision | ||
number or hash, or <a href="/help/revsets">revset expression</a>.</div> | ||||
Dan Villiom Podlaski Christiansen
|
r18744 | </form> | ||
<table class="bigtable"> | ||||
r30019 | <tr><td colspan="2"><h2><a name="topics" href="#topics">Topics</a></h2></td></tr> | |||
Dan Villiom Podlaski Christiansen
|
r18745 | |||
<tr><td> | ||||
<a href="/help/config"> | ||||
config | ||||
</a> | ||||
</td><td> | ||||
Configuration Files | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/dates"> | ||||
dates | ||||
</a> | ||||
</td><td> | ||||
Date Formats | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/diffs"> | ||||
diffs | ||||
</a> | ||||
</td><td> | ||||
Diff Formats | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/environment"> | ||||
environment | ||||
</a> | ||||
</td><td> | ||||
Environment Variables | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/extensions"> | ||||
extensions | ||||
</a> | ||||
</td><td> | ||||
Using Additional Features | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/filesets"> | ||||
filesets | ||||
</a> | ||||
</td><td> | ||||
Specifying File Sets | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/glossary"> | ||||
glossary | ||||
</a> | ||||
</td><td> | ||||
Glossary | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/hgignore"> | ||||
hgignore | ||||
</a> | ||||
</td><td> | ||||
Syntax for Mercurial Ignore Files | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/hgweb"> | ||||
hgweb | ||||
</a> | ||||
</td><td> | ||||
Configuring hgweb | ||||
</td></tr> | ||||
<tr><td> | ||||
Gregory Szorc
|
r27376 | <a href="/help/internals"> | ||
internals | ||||
</a> | ||||
</td><td> | ||||
Technical implementation topics | ||||
</td></tr> | ||||
<tr><td> | ||||
Dan Villiom Podlaski Christiansen
|
r18745 | <a href="/help/merge-tools"> | ||
merge-tools | ||||
</a> | ||||
</td><td> | ||||
Merge Tools | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/multirevs"> | ||||
multirevs | ||||
</a> | ||||
</td><td> | ||||
Specifying Multiple Revisions | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/patterns"> | ||||
patterns | ||||
</a> | ||||
</td><td> | ||||
File Name Patterns | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/phases"> | ||||
phases | ||||
</a> | ||||
</td><td> | ||||
Working with Phases | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/revisions"> | ||||
revisions | ||||
</a> | ||||
</td><td> | ||||
Specifying Single Revisions | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/revsets"> | ||||
revsets | ||||
</a> | ||||
</td><td> | ||||
Specifying Revision Sets | ||||
</td></tr> | ||||
<tr><td> | ||||
Gregory Szorc
|
r25881 | <a href="/help/scripting"> | ||
scripting | ||||
</a> | ||||
</td><td> | ||||
Using Mercurial from scripts and automation | ||||
</td></tr> | ||||
<tr><td> | ||||
Dan Villiom Podlaski Christiansen
|
r18745 | <a href="/help/subrepos"> | ||
subrepos | ||||
</a> | ||||
</td><td> | ||||
Subrepositories | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/templating"> | ||||
templating | ||||
</a> | ||||
</td><td> | ||||
Template Usage | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/urls"> | ||||
urls | ||||
</a> | ||||
</td><td> | ||||
URL Paths | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/topic-containing-verbose"> | ||||
topic-containing-verbose | ||||
</a> | ||||
</td><td> | ||||
This is the topic to test omit indicating. | ||||
</td></tr> | ||||
Dan Villiom Podlaski Christiansen
|
r18744 | |||
Gregory Szorc
|
r27578 | |||
Dan Villiom Podlaski Christiansen
|
r18744 | <tr><td colspan="2"><h2><a name="main" href="#main">Main Commands</a></h2></td></tr> | ||
Dan Villiom Podlaski Christiansen
|
r18745 | |||
<tr><td> | ||||
<a href="/help/add"> | ||||
add | ||||
</a> | ||||
</td><td> | ||||
add the specified files on the next commit | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/annotate"> | ||||
annotate | ||||
</a> | ||||
</td><td> | ||||
show changeset information by line for each file | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/clone"> | ||||
clone | ||||
</a> | ||||
</td><td> | ||||
make a copy of an existing repository | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/commit"> | ||||
commit | ||||
</a> | ||||
</td><td> | ||||
commit the specified files or all outstanding changes | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/diff"> | ||||
diff | ||||
</a> | ||||
</td><td> | ||||
diff repository (or selected files) | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/export"> | ||||
export | ||||
</a> | ||||
</td><td> | ||||
dump the header and diffs for one or more changesets | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/forget"> | ||||
forget | ||||
</a> | ||||
</td><td> | ||||
forget the specified files on the next commit | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/init"> | ||||
init | ||||
</a> | ||||
</td><td> | ||||
create a new repository in the given directory | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/log"> | ||||
log | ||||
</a> | ||||
</td><td> | ||||
show revision history of entire repository or files | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/merge"> | ||||
merge | ||||
</a> | ||||
</td><td> | ||||
anatoly techtonik
|
r23400 | merge another revision into working directory | ||
Dan Villiom Podlaski Christiansen
|
r18745 | </td></tr> | ||
<tr><td> | ||||
<a href="/help/pull"> | ||||
pull | ||||
</a> | ||||
</td><td> | ||||
pull changes from the specified source | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/push"> | ||||
push | ||||
</a> | ||||
</td><td> | ||||
push changes to the specified destination | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/remove"> | ||||
remove | ||||
</a> | ||||
</td><td> | ||||
remove the specified files on the next commit | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/serve"> | ||||
serve | ||||
</a> | ||||
</td><td> | ||||
start stand-alone webserver | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/status"> | ||||
status | ||||
</a> | ||||
</td><td> | ||||
show changed files in the working directory | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/summary"> | ||||
summary | ||||
</a> | ||||
</td><td> | ||||
summarize working directory state | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/update"> | ||||
update | ||||
</a> | ||||
</td><td> | ||||
update working directory (or switch revisions) | ||||
</td></tr> | ||||
Dan Villiom Podlaski Christiansen
|
r18744 | |||
Gregory Szorc
|
r27578 | |||
Dan Villiom Podlaski Christiansen
|
r18744 | <tr><td colspan="2"><h2><a name="other" href="#other">Other Commands</a></h2></td></tr> | ||
Dan Villiom Podlaski Christiansen
|
r18745 | |||
<tr><td> | ||||
<a href="/help/addremove"> | ||||
addremove | ||||
</a> | ||||
</td><td> | ||||
add all new files, delete all missing files | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/archive"> | ||||
archive | ||||
</a> | ||||
</td><td> | ||||
create an unversioned archive of a repository revision | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/backout"> | ||||
backout | ||||
</a> | ||||
</td><td> | ||||
reverse effect of earlier changeset | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/bisect"> | ||||
bisect | ||||
</a> | ||||
</td><td> | ||||
subdivision search of changesets | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/bookmarks"> | ||||
bookmarks | ||||
</a> | ||||
</td><td> | ||||
Matt Mackall
|
r21762 | create a new bookmark or list existing bookmarks | ||
Dan Villiom Podlaski Christiansen
|
r18745 | </td></tr> | ||
<tr><td> | ||||
<a href="/help/branch"> | ||||
branch | ||||
</a> | ||||
</td><td> | ||||
set or show the current branch name | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/branches"> | ||||
branches | ||||
</a> | ||||
</td><td> | ||||
list repository named branches | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/bundle"> | ||||
bundle | ||||
</a> | ||||
</td><td> | ||||
create a changegroup file | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/cat"> | ||||
cat | ||||
</a> | ||||
</td><td> | ||||
output the current or given revision of files | ||||
</td></tr> | ||||
<tr><td> | ||||
Matt Mackall
|
r20570 | <a href="/help/config"> | ||
config | ||||
</a> | ||||
</td><td> | ||||
show combined config settings from all hgrc files | ||||
</td></tr> | ||||
<tr><td> | ||||
Dan Villiom Podlaski Christiansen
|
r18745 | <a href="/help/copy"> | ||
copy | ||||
</a> | ||||
</td><td> | ||||
mark files as copied for the next commit | ||||
</td></tr> | ||||
<tr><td> | ||||
Matt Mackall
|
r22423 | <a href="/help/files"> | ||
files | ||||
</a> | ||||
</td><td> | ||||
list tracked files | ||||
</td></tr> | ||||
<tr><td> | ||||
Dan Villiom Podlaski Christiansen
|
r18745 | <a href="/help/graft"> | ||
graft | ||||
</a> | ||||
</td><td> | ||||
copy changes from other branches onto the current branch | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/grep"> | ||||
grep | ||||
</a> | ||||
</td><td> | ||||
Kevin Bullock
|
r30009 | search revision history for a pattern in specified files | ||
Dan Villiom Podlaski Christiansen
|
r18745 | </td></tr> | ||
<tr><td> | ||||
<a href="/help/heads"> | ||||
heads | ||||
</a> | ||||
</td><td> | ||||
Matt Mackall
|
r19469 | show branch heads | ||
Dan Villiom Podlaski Christiansen
|
r18745 | </td></tr> | ||
<tr><td> | ||||
<a href="/help/help"> | ||||
help | ||||
</a> | ||||
</td><td> | ||||
show help for a given topic or a help overview | ||||
</td></tr> | ||||
<tr><td> | ||||
timeless
|
r28828 | <a href="/help/hgalias"> | ||
hgalias | ||||
</a> | ||||
</td><td> | ||||
summarize working directory state | ||||
</td></tr> | ||||
<tr><td> | ||||
Dan Villiom Podlaski Christiansen
|
r18745 | <a href="/help/identify"> | ||
identify | ||||
</a> | ||||
</td><td> | ||||
Yuya Nishihara
|
r24364 | identify the working directory or specified revision | ||
Dan Villiom Podlaski Christiansen
|
r18745 | </td></tr> | ||
<tr><td> | ||||
<a href="/help/import"> | ||||
import | ||||
</a> | ||||
</td><td> | ||||
import an ordered set of patches | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/incoming"> | ||||
incoming | ||||
</a> | ||||
</td><td> | ||||
show new changesets found in source | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/manifest"> | ||||
manifest | ||||
</a> | ||||
</td><td> | ||||
output the current or given revision of the project manifest | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/nohelp"> | ||||
nohelp | ||||
</a> | ||||
</td><td> | ||||
(no help text available) | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/outgoing"> | ||||
outgoing | ||||
</a> | ||||
</td><td> | ||||
show changesets not found in the destination | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/paths"> | ||||
paths | ||||
</a> | ||||
</td><td> | ||||
show aliases for remote repositories | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/phase"> | ||||
phase | ||||
</a> | ||||
</td><td> | ||||
set or show the current phase name | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/recover"> | ||||
recover | ||||
</a> | ||||
</td><td> | ||||
roll back an interrupted transaction | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/rename"> | ||||
rename | ||||
</a> | ||||
</td><td> | ||||
rename files; equivalent of copy + remove | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/resolve"> | ||||
resolve | ||||
</a> | ||||
</td><td> | ||||
redo merges or set/view the merge status of files | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/revert"> | ||||
revert | ||||
</a> | ||||
</td><td> | ||||
restore files to their checkout state | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/root"> | ||||
root | ||||
</a> | ||||
</td><td> | ||||
print the root (top) of the current working directory | ||||
</td></tr> | ||||
<tr><td> | ||||
timeless
|
r28828 | <a href="/help/shellalias"> | ||
shellalias | ||||
</a> | ||||
</td><td> | ||||
(no help text available) | ||||
</td></tr> | ||||
<tr><td> | ||||
Dan Villiom Podlaski Christiansen
|
r18745 | <a href="/help/tag"> | ||
tag | ||||
</a> | ||||
</td><td> | ||||
add one or more tags for the current or given revision | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/tags"> | ||||
tags | ||||
</a> | ||||
</td><td> | ||||
list repository tags | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/unbundle"> | ||||
unbundle | ||||
</a> | ||||
</td><td> | ||||
apply one or more changegroup files | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/verify"> | ||||
verify | ||||
</a> | ||||
</td><td> | ||||
verify the integrity of the repository | ||||
</td></tr> | ||||
<tr><td> | ||||
<a href="/help/version"> | ||||
version | ||||
</a> | ||||
</td><td> | ||||
output version and copyright information | ||||
</td></tr> | ||||
Gregory Szorc
|
r27578 | |||
Dan Villiom Podlaski Christiansen
|
r18744 | </table> | ||
</div> | ||||
</div> | ||||
<script type="text/javascript">process_dates()</script> | ||||
</body> | ||||
</html> | ||||
Matt Mackall
|
r25472 | $ get-with-headers.py 127.0.0.1:$HGPORT "help/add" | ||
Dan Villiom Podlaski Christiansen
|
r18744 | 200 Script output follows | ||
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> | ||||
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en-US"> | ||||
<head> | ||||
<link rel="icon" href="/static/hgicon.png" type="image/png" /> | ||||
<meta name="robots" content="index, nofollow" /> | ||||
<link rel="stylesheet" href="/static/style-paper.css" type="text/css" /> | ||||
<script type="text/javascript" src="/static/mercurial.js"></script> | ||||
<title>Help: add</title> | ||||
</head> | ||||
<body> | ||||
<div class="container"> | ||||
<div class="menu"> | ||||
<div class="logo"> | ||||
Matt Mackall
|
r26421 | <a href="https://mercurial-scm.org/"> | ||
Dan Villiom Podlaski Christiansen
|
r18744 | <img src="/static/hglogo.png" alt="mercurial" /></a> | ||
</div> | ||||
<ul> | ||||
<li><a href="/shortlog">log</a></li> | ||||
<li><a href="/graph">graph</a></li> | ||||
<li><a href="/tags">tags</a></li> | ||||
<li><a href="/bookmarks">bookmarks</a></li> | ||||
<li><a href="/branches">branches</a></li> | ||||
</ul> | ||||
<ul> | ||||
<li class="active"><a href="/help">help</a></li> | ||||
</ul> | ||||
</div> | ||||
<div class="main"> | ||||
<h2 class="breadcrumb"><a href="/">Mercurial</a> </h2> | ||||
<h3>Help: add</h3> | ||||
<form class="search" action="/log"> | ||||
<p><input name="rev" id="search1" type="text" size="30" /></p> | ||||
Alexander Plavin
|
r19796 | <div id="hint">Find changesets by keywords (author, files, the commit message), revision | ||
number or hash, or <a href="/help/revsets">revset expression</a>.</div> | ||||
Dan Villiom Podlaski Christiansen
|
r18744 | </form> | ||
Dan Villiom Podlaski Christiansen
|
r18747 | <div id="doc"> | ||
<p> | ||||
Dan Villiom Podlaski Christiansen
|
r18744 | hg add [OPTION]... [FILE]... | ||
Dan Villiom Podlaski Christiansen
|
r18747 | </p> | ||
<p> | ||||
Dan Villiom Podlaski Christiansen
|
r18744 | add the specified files on the next commit | ||
Dan Villiom Podlaski Christiansen
|
r18747 | </p> | ||
<p> | ||||
Schedule files to be version controlled and added to the | ||||
repository. | ||||
</p> | ||||
<p> | ||||
The files will be added to the repository at the next commit. To | ||||
timeless
|
r27729 | undo an add before that, see 'hg forget'. | ||
Dan Villiom Podlaski Christiansen
|
r18747 | </p> | ||
<p> | ||||
timeless
|
r27424 | If no names are given, add all files to the repository (except | ||
files matching ".hgignore"). | ||||
Dan Villiom Podlaski Christiansen
|
r18747 | </p> | ||
<p> | ||||
Mathias De Maré
|
r27143 | Examples: | ||
Alexander Plavin
|
r19079 | </p> | ||
Mathias De Maré
|
r27143 | <ul> | ||
timeless
|
r27729 | <li> New (unknown) files are added automatically by 'hg add': | ||
Alexander Plavin
|
r19079 | <pre> | ||
\$ ls (re) | ||||
foo.c | ||||
\$ hg status (re) | ||||
? foo.c | ||||
\$ hg add (re) | ||||
adding foo.c | ||||
\$ hg status (re) | ||||
A foo.c | ||||
</pre> | ||||
Mathias De Maré
|
r27143 | <li> Specific files to be added can be specified: | ||
<pre> | ||||
\$ ls (re) | ||||
bar.c foo.c | ||||
\$ hg status (re) | ||||
? bar.c | ||||
? foo.c | ||||
\$ hg add bar.c (re) | ||||
\$ hg status (re) | ||||
A bar.c | ||||
? foo.c | ||||
</pre> | ||||
</ul> | ||||
Alexander Plavin
|
r19079 | <p> | ||
Dan Villiom Podlaski Christiansen
|
r18747 | Returns 0 if all files are successfully added. | ||
</p> | ||||
<p> | ||||
Matt Mackall
|
r22117 | options ([+] can be repeated): | ||
Dan Villiom Podlaski Christiansen
|
r18747 | </p> | ||
<table> | ||||
Dan Villiom Podlaski Christiansen
|
r18751 | <tr><td>-I</td> | ||
<td>--include PATTERN [+]</td> | ||||
<td>include names matching the given patterns</td></tr> | ||||
<tr><td>-X</td> | ||||
<td>--exclude PATTERN [+]</td> | ||||
<td>exclude names matching the given patterns</td></tr> | ||||
<tr><td>-S</td> | ||||
Augie Fackler
|
r30024 | <td>--[no-]subrepos</td> | ||
Dan Villiom Podlaski Christiansen
|
r18751 | <td>recurse into subrepositories</td></tr> | ||
<tr><td>-n</td> | ||||
Augie Fackler
|
r30024 | <td>--[no-]dry-run</td> | ||
Dan Villiom Podlaski Christiansen
|
r18751 | <td>do not perform actions, just print output</td></tr> | ||
Dan Villiom Podlaski Christiansen
|
r18747 | </table> | ||
<p> | ||||
Matt Mackall
|
r22117 | global options ([+] can be repeated): | ||
Dan Villiom Podlaski Christiansen
|
r18747 | </p> | ||
<table> | ||||
Dan Villiom Podlaski Christiansen
|
r18751 | <tr><td>-R</td> | ||
<td>--repository REPO</td> | ||||
<td>repository root directory or name of overlay bundle file</td></tr> | ||||
<tr><td></td> | ||||
<td>--cwd DIR</td> | ||||
<td>change working directory</td></tr> | ||||
<tr><td>-y</td> | ||||
<td>--noninteractive</td> | ||||
<td>do not prompt, automatically pick the first choice for all prompts</td></tr> | ||||
<tr><td>-q</td> | ||||
Augie Fackler
|
r30024 | <td>--[no-]quiet</td> | ||
Dan Villiom Podlaski Christiansen
|
r18751 | <td>suppress output</td></tr> | ||
<tr><td>-v</td> | ||||
Augie Fackler
|
r30024 | <td>--[no-]verbose</td> | ||
Dan Villiom Podlaski Christiansen
|
r18751 | <td>enable additional output</td></tr> | ||
<tr><td></td> | ||||
<td>--config CONFIG [+]</td> | ||||
<td>set/override config option (use 'section.name=value')</td></tr> | ||||
<tr><td></td> | ||||
Augie Fackler
|
r30024 | <td>--[no-]debug</td> | ||
Dan Villiom Podlaski Christiansen
|
r18751 | <td>enable debugging output</td></tr> | ||
<tr><td></td> | ||||
Augie Fackler
|
r30024 | <td>--[no-]debugger</td> | ||
Dan Villiom Podlaski Christiansen
|
r18751 | <td>start debugger</td></tr> | ||
<tr><td></td> | ||||
<td>--encoding ENCODE</td> | ||||
<td>set the charset encoding (default: ascii)</td></tr> | ||||
<tr><td></td> | ||||
<td>--encodingmode MODE</td> | ||||
<td>set the charset encoding mode (default: strict)</td></tr> | ||||
<tr><td></td> | ||||
Augie Fackler
|
r30024 | <td>--[no-]traceback</td> | ||
Dan Villiom Podlaski Christiansen
|
r18751 | <td>always print a traceback on exception</td></tr> | ||
<tr><td></td> | ||||
Augie Fackler
|
r30024 | <td>--[no-]time</td> | ||
Dan Villiom Podlaski Christiansen
|
r18751 | <td>time how long the command takes</td></tr> | ||
<tr><td></td> | ||||
Augie Fackler
|
r30024 | <td>--[no-]profile</td> | ||
Dan Villiom Podlaski Christiansen
|
r18751 | <td>print command execution profile</td></tr> | ||
<tr><td></td> | ||||
<td>--version</td> | ||||
<td>output version information and exit</td></tr> | ||||
<tr><td>-h</td> | ||||
<td>--help</td> | ||||
<td>display help and exit</td></tr> | ||||
<tr><td></td> | ||||
Augie Fackler
|
r30024 | <td>--[no-]hidden</td> | ||
Dan Villiom Podlaski Christiansen
|
r18751 | <td>consider hidden changesets</td></tr> | ||
Dan Villiom Podlaski Christiansen
|
r18747 | </table> | ||
Dan Villiom Podlaski Christiansen
|
r18744 | |||
Dan Villiom Podlaski Christiansen
|
r18747 | </div> | ||
Dan Villiom Podlaski Christiansen
|
r18744 | </div> | ||
</div> | ||||
<script type="text/javascript">process_dates()</script> | ||||
</body> | ||||
</html> | ||||
Matt Mackall
|
r25472 | $ get-with-headers.py 127.0.0.1:$HGPORT "help/remove" | ||
Dan Villiom Podlaski Christiansen
|
r18744 | 200 Script output follows | ||
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> | ||||
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en-US"> | ||||
<head> | ||||
<link rel="icon" href="/static/hgicon.png" type="image/png" /> | ||||
<meta name="robots" content="index, nofollow" /> | ||||
<link rel="stylesheet" href="/static/style-paper.css" type="text/css" /> | ||||
<script type="text/javascript" src="/static/mercurial.js"></script> | ||||
<title>Help: remove</title> | ||||
</head> | ||||
<body> | ||||
<div class="container"> | ||||
<div class="menu"> | ||||
<div class="logo"> | ||||
Matt Mackall
|
r26421 | <a href="https://mercurial-scm.org/"> | ||
Dan Villiom Podlaski Christiansen
|
r18744 | <img src="/static/hglogo.png" alt="mercurial" /></a> | ||
</div> | ||||
<ul> | ||||
<li><a href="/shortlog">log</a></li> | ||||
<li><a href="/graph">graph</a></li> | ||||
<li><a href="/tags">tags</a></li> | ||||
<li><a href="/bookmarks">bookmarks</a></li> | ||||
<li><a href="/branches">branches</a></li> | ||||
</ul> | ||||
<ul> | ||||
<li class="active"><a href="/help">help</a></li> | ||||
</ul> | ||||
</div> | ||||
<div class="main"> | ||||
<h2 class="breadcrumb"><a href="/">Mercurial</a> </h2> | ||||
<h3>Help: remove</h3> | ||||
<form class="search" action="/log"> | ||||
<p><input name="rev" id="search1" type="text" size="30" /></p> | ||||
Alexander Plavin
|
r19796 | <div id="hint">Find changesets by keywords (author, files, the commit message), revision | ||
number or hash, or <a href="/help/revsets">revset expression</a>.</div> | ||||
Dan Villiom Podlaski Christiansen
|
r18744 | </form> | ||
Dan Villiom Podlaski Christiansen
|
r18747 | <div id="doc"> | ||
<p> | ||||
Dan Villiom Podlaski Christiansen
|
r18744 | hg remove [OPTION]... FILE... | ||
Dan Villiom Podlaski Christiansen
|
r18747 | </p> | ||
<p> | ||||
Dan Villiom Podlaski Christiansen
|
r18744 | aliases: rm | ||
Dan Villiom Podlaski Christiansen
|
r18747 | </p> | ||
<p> | ||||
Dan Villiom Podlaski Christiansen
|
r18744 | remove the specified files on the next commit | ||
Dan Villiom Podlaski Christiansen
|
r18747 | </p> | ||
<p> | ||||
Schedule the indicated files for removal from the current branch. | ||||
</p> | ||||
<p> | ||||
This command schedules the files to be removed at the next commit. | ||||
timeless
|
r27729 | To undo a remove before that, see 'hg revert'. To undo added | ||
files, see 'hg forget'. | ||||
Dan Villiom Podlaski Christiansen
|
r18747 | </p> | ||
<p> | ||||
Alexander Plavin
|
r19079 | -A/--after can be used to remove only files that have already | ||
been deleted, -f/--force can be used to force deletion, and -Af | ||||
can be used to remove files from the next revision without | ||||
deleting them from the working directory. | ||||
</p> | ||||
<p> | ||||
The following table details the behavior of remove for different | ||||
file states (columns) and option combinations (rows). The file | ||||
states are Added [A], Clean [C], Modified [M] and Missing [!] | ||||
timeless
|
r27729 | (as reported by 'hg status'). The actions are Warn, Remove | ||
Alexander Plavin
|
r19079 | (from branch) and Delete (from disk): | ||
</p> | ||||
<table> | ||||
FUJIWARA Katsunori
|
r19960 | <tr><td>opt/state</td> | ||
Alexander Plavin
|
r19079 | <td>A</td> | ||
<td>C</td> | ||||
<td>M</td> | ||||
<td>!</td></tr> | ||||
<tr><td>none</td> | ||||
<td>W</td> | ||||
<td>RD</td> | ||||
<td>W</td> | ||||
<td>R</td></tr> | ||||
<tr><td>-f</td> | ||||
<td>R</td> | ||||
<td>RD</td> | ||||
<td>RD</td> | ||||
<td>R</td></tr> | ||||
<tr><td>-A</td> | ||||
<td>W</td> | ||||
<td>W</td> | ||||
<td>W</td> | ||||
<td>R</td></tr> | ||||
<tr><td>-Af</td> | ||||
<td>R</td> | ||||
<td>R</td> | ||||
<td>R</td> | ||||
<td>R</td></tr> | ||||
</table> | ||||
<p> | ||||
timeless
|
r27489 | <b>Note:</b> | ||
</p> | ||||
<p> | ||||
timeless
|
r27729 | 'hg remove' never deletes files in Added [A] state from the | ||
timeless
|
r27489 | working directory, not even if "--force" is specified. | ||
Alexander Plavin
|
r19079 | </p> | ||
<p> | ||||
Dan Villiom Podlaski Christiansen
|
r18747 | Returns 0 on success, 1 if any warnings encountered. | ||
</p> | ||||
<p> | ||||
Matt Mackall
|
r22117 | options ([+] can be repeated): | ||
Dan Villiom Podlaski Christiansen
|
r18747 | </p> | ||
<table> | ||||
Dan Villiom Podlaski Christiansen
|
r18751 | <tr><td>-A</td> | ||
Augie Fackler
|
r30024 | <td>--[no-]after</td> | ||
Dan Villiom Podlaski Christiansen
|
r18751 | <td>record delete for missing files</td></tr> | ||
<tr><td>-f</td> | ||||
Augie Fackler
|
r30024 | <td>--[no-]force</td> | ||
liscju
|
r28902 | <td>forget added files, delete modified files</td></tr> | ||
Matt Harbison
|
r23325 | <tr><td>-S</td> | ||
Augie Fackler
|
r30024 | <td>--[no-]subrepos</td> | ||
Matt Harbison
|
r23325 | <td>recurse into subrepositories</td></tr> | ||
Dan Villiom Podlaski Christiansen
|
r18751 | <tr><td>-I</td> | ||
<td>--include PATTERN [+]</td> | ||||
<td>include names matching the given patterns</td></tr> | ||||
<tr><td>-X</td> | ||||
<td>--exclude PATTERN [+]</td> | ||||
<td>exclude names matching the given patterns</td></tr> | ||||
Dan Villiom Podlaski Christiansen
|
r18747 | </table> | ||
<p> | ||||
Matt Mackall
|
r22117 | global options ([+] can be repeated): | ||
Dan Villiom Podlaski Christiansen
|
r18747 | </p> | ||
<table> | ||||
Dan Villiom Podlaski Christiansen
|
r18751 | <tr><td>-R</td> | ||
<td>--repository REPO</td> | ||||
<td>repository root directory or name of overlay bundle file</td></tr> | ||||
<tr><td></td> | ||||
<td>--cwd DIR</td> | ||||
<td>change working directory</td></tr> | ||||
<tr><td>-y</td> | ||||
<td>--noninteractive</td> | ||||
<td>do not prompt, automatically pick the first choice for all prompts</td></tr> | ||||
<tr><td>-q</td> | ||||
Augie Fackler
|
r30024 | <td>--[no-]quiet</td> | ||
Dan Villiom Podlaski Christiansen
|
r18751 | <td>suppress output</td></tr> | ||
<tr><td>-v</td> | ||||
Augie Fackler
|
r30024 | <td>--[no-]verbose</td> | ||
Dan Villiom Podlaski Christiansen
|
r18751 | <td>enable additional output</td></tr> | ||
<tr><td></td> | ||||
<td>--config CONFIG [+]</td> | ||||
<td>set/override config option (use 'section.name=value')</td></tr> | ||||
<tr><td></td> | ||||
Augie Fackler
|
r30024 | <td>--[no-]debug</td> | ||
Dan Villiom Podlaski Christiansen
|
r18751 | <td>enable debugging output</td></tr> | ||
<tr><td></td> | ||||
Augie Fackler
|
r30024 | <td>--[no-]debugger</td> | ||
Dan Villiom Podlaski Christiansen
|
r18751 | <td>start debugger</td></tr> | ||
<tr><td></td> | ||||
<td>--encoding ENCODE</td> | ||||
<td>set the charset encoding (default: ascii)</td></tr> | ||||
<tr><td></td> | ||||
<td>--encodingmode MODE</td> | ||||
<td>set the charset encoding mode (default: strict)</td></tr> | ||||
<tr><td></td> | ||||
Augie Fackler
|
r30024 | <td>--[no-]traceback</td> | ||
Dan Villiom Podlaski Christiansen
|
r18751 | <td>always print a traceback on exception</td></tr> | ||
<tr><td></td> | ||||
Augie Fackler
|
r30024 | <td>--[no-]time</td> | ||
Dan Villiom Podlaski Christiansen
|
r18751 | <td>time how long the command takes</td></tr> | ||
<tr><td></td> | ||||
Augie Fackler
|
r30024 | <td>--[no-]profile</td> | ||
Dan Villiom Podlaski Christiansen
|
r18751 | <td>print command execution profile</td></tr> | ||
<tr><td></td> | ||||
<td>--version</td> | ||||
<td>output version information and exit</td></tr> | ||||
<tr><td>-h</td> | ||||
<td>--help</td> | ||||
<td>display help and exit</td></tr> | ||||
<tr><td></td> | ||||
Augie Fackler
|
r30024 | <td>--[no-]hidden</td> | ||
Dan Villiom Podlaski Christiansen
|
r18751 | <td>consider hidden changesets</td></tr> | ||
Dan Villiom Podlaski Christiansen
|
r18747 | </table> | ||
Dan Villiom Podlaski Christiansen
|
r18744 | |||
Dan Villiom Podlaski Christiansen
|
r18747 | </div> | ||
Dan Villiom Podlaski Christiansen
|
r18744 | </div> | ||
</div> | ||||
<script type="text/javascript">process_dates()</script> | ||||
</body> | ||||
</html> | ||||
Matt Mackall
|
r25472 | $ get-with-headers.py 127.0.0.1:$HGPORT "help/revisions" | ||
Dan Villiom Podlaski Christiansen
|
r18744 | 200 Script output follows | ||
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> | ||||
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en-US"> | ||||
<head> | ||||
<link rel="icon" href="/static/hgicon.png" type="image/png" /> | ||||
<meta name="robots" content="index, nofollow" /> | ||||
<link rel="stylesheet" href="/static/style-paper.css" type="text/css" /> | ||||
<script type="text/javascript" src="/static/mercurial.js"></script> | ||||
<title>Help: revisions</title> | ||||
</head> | ||||
<body> | ||||
<div class="container"> | ||||
<div class="menu"> | ||||
<div class="logo"> | ||||
Matt Mackall
|
r26421 | <a href="https://mercurial-scm.org/"> | ||
Dan Villiom Podlaski Christiansen
|
r18744 | <img src="/static/hglogo.png" alt="mercurial" /></a> | ||
</div> | ||||
<ul> | ||||
<li><a href="/shortlog">log</a></li> | ||||
<li><a href="/graph">graph</a></li> | ||||
<li><a href="/tags">tags</a></li> | ||||
<li><a href="/bookmarks">bookmarks</a></li> | ||||
<li><a href="/branches">branches</a></li> | ||||
</ul> | ||||
<ul> | ||||
<li class="active"><a href="/help">help</a></li> | ||||
</ul> | ||||
</div> | ||||
<div class="main"> | ||||
<h2 class="breadcrumb"><a href="/">Mercurial</a> </h2> | ||||
<h3>Help: revisions</h3> | ||||
<form class="search" action="/log"> | ||||
<p><input name="rev" id="search1" type="text" size="30" /></p> | ||||
Alexander Plavin
|
r19796 | <div id="hint">Find changesets by keywords (author, files, the commit message), revision | ||
number or hash, or <a href="/help/revsets">revset expression</a>.</div> | ||||
Dan Villiom Podlaski Christiansen
|
r18744 | </form> | ||
Dan Villiom Podlaski Christiansen
|
r18747 | <div id="doc"> | ||
Dan Villiom Podlaski Christiansen
|
r18748 | <h1>Specifying Single Revisions</h1> | ||
Dan Villiom Podlaski Christiansen
|
r18747 | <p> | ||
Mercurial supports several ways to specify individual revisions. | ||||
</p> | ||||
<p> | ||||
A plain integer is treated as a revision number. Negative integers are | ||||
treated as sequential offsets from the tip, with -1 denoting the tip, | ||||
-2 denoting the revision prior to the tip, and so forth. | ||||
</p> | ||||
<p> | ||||
A 40-digit hexadecimal string is treated as a unique revision | ||||
identifier. | ||||
</p> | ||||
<p> | ||||
A hexadecimal string less than 40 characters long is treated as a | ||||
unique revision identifier and is referred to as a short-form | ||||
identifier. A short-form identifier is only valid if it is the prefix | ||||
of exactly one full-length identifier. | ||||
</p> | ||||
<p> | ||||
Any other string is treated as a bookmark, tag, or branch name. A | ||||
bookmark is a movable pointer to a revision. A tag is a permanent name | ||||
Mads Kiilerich
|
r20245 | associated with a revision. A branch name denotes the tipmost open branch head | ||
of that branch - or if they are all closed, the tipmost closed head of the | ||||
branch. Bookmark, tag, and branch names must not contain the ":" character. | ||||
Dan Villiom Podlaski Christiansen
|
r18747 | </p> | ||
<p> | ||||
Dan Villiom Podlaski Christiansen
|
r18750 | The reserved name "tip" always identifies the most recent revision. | ||
Dan Villiom Podlaski Christiansen
|
r18747 | </p> | ||
<p> | ||||
Dan Villiom Podlaski Christiansen
|
r18750 | The reserved name "null" indicates the null revision. This is the | ||
Dan Villiom Podlaski Christiansen
|
r18747 | revision of an empty repository, and the parent of revision 0. | ||
</p> | ||||
<p> | ||||
Dan Villiom Podlaski Christiansen
|
r18750 | The reserved name "." indicates the working directory parent. If no | ||
Dan Villiom Podlaski Christiansen
|
r18747 | working directory is checked out, it is equivalent to null. If an | ||
Dan Villiom Podlaski Christiansen
|
r18750 | uncommitted merge is in progress, "." is the revision of the first | ||
Dan Villiom Podlaski Christiansen
|
r18747 | parent. | ||
</p> | ||||
Dan Villiom Podlaski Christiansen
|
r18744 | |||
Dan Villiom Podlaski Christiansen
|
r18747 | </div> | ||
Dan Villiom Podlaski Christiansen
|
r18744 | </div> | ||
</div> | ||||
<script type="text/javascript">process_dates()</script> | ||||
</body> | ||||
</html> | ||||
Gregory Szorc
|
r27581 | Sub-topic indexes rendered properly | ||
$ get-with-headers.py 127.0.0.1:$HGPORT "help/internals" | ||||
200 Script output follows | ||||
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> | ||||
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en-US"> | ||||
<head> | ||||
<link rel="icon" href="/static/hgicon.png" type="image/png" /> | ||||
<meta name="robots" content="index, nofollow" /> | ||||
<link rel="stylesheet" href="/static/style-paper.css" type="text/css" /> | ||||
<script type="text/javascript" src="/static/mercurial.js"></script> | ||||
<title>Help: internals</title> | ||||
</head> | ||||
<body> | ||||
<div class="container"> | ||||
<div class="menu"> | ||||
<div class="logo"> | ||||
<a href="https://mercurial-scm.org/"> | ||||
<img src="/static/hglogo.png" alt="mercurial" /></a> | ||||
</div> | ||||
<ul> | ||||
<li><a href="/shortlog">log</a></li> | ||||
<li><a href="/graph">graph</a></li> | ||||
<li><a href="/tags">tags</a></li> | ||||
<li><a href="/bookmarks">bookmarks</a></li> | ||||
<li><a href="/branches">branches</a></li> | ||||
</ul> | ||||
<ul> | ||||
<li><a href="/help">help</a></li> | ||||
</ul> | ||||
</div> | ||||
<div class="main"> | ||||
<h2 class="breadcrumb"><a href="/">Mercurial</a> </h2> | ||||
<form class="search" action="/log"> | ||||
<p><input name="rev" id="search1" type="text" size="30" /></p> | ||||
<div id="hint">Find changesets by keywords (author, files, the commit message), revision | ||||
number or hash, or <a href="/help/revsets">revset expression</a>.</div> | ||||
</form> | ||||
<table class="bigtable"> | ||||
r30019 | <tr><td colspan="2"><h2><a name="topics" href="#topics">Topics</a></h2></td></tr> | |||
Gregory Szorc
|
r27581 | |||
<tr><td> | ||||
<a href="/help/internals.bundles"> | ||||
bundles | ||||
</a> | ||||
</td><td> | ||||
Gregory Szorc
|
r29747 | Bundles | ||
Gregory Szorc
|
r27581 | </td></tr> | ||
<tr><td> | ||||
<a href="/help/internals.changegroups"> | ||||
changegroups | ||||
</a> | ||||
</td><td> | ||||
Gregory Szorc
|
r29747 | Changegroups | ||
Gregory Szorc
|
r27581 | </td></tr> | ||
Gregory Szorc
|
r27631 | <tr><td> | ||
Gregory Szorc
|
r28523 | <a href="/help/internals.requirements"> | ||
requirements | ||||
</a> | ||||
</td><td> | ||||
Gregory Szorc
|
r29747 | Repository Requirements | ||
Gregory Szorc
|
r28523 | </td></tr> | ||
<tr><td> | ||||
Gregory Szorc
|
r27631 | <a href="/help/internals.revlogs"> | ||
revlogs | ||||
</a> | ||||
</td><td> | ||||
Gregory Szorc
|
r29747 | Revision Logs | ||
Gregory Szorc
|
r27631 | </td></tr> | ||
Gregory Szorc
|
r29859 | <tr><td> | ||
<a href="/help/internals.wireprotocol"> | ||||
wireprotocol | ||||
</a> | ||||
</td><td> | ||||
Wire Protocol | ||||
Gregory Szorc
|
r27631 | </td></tr> | ||
Gregory Szorc
|
r27581 | |||
</table> | ||||
</div> | ||||
</div> | ||||
<script type="text/javascript">process_dates()</script> | ||||
</body> | ||||
</html> | ||||
Gregory Szorc
|
r27582 | Sub-topic topics rendered properly | ||
$ get-with-headers.py 127.0.0.1:$HGPORT "help/internals.changegroups" | ||||
200 Script output follows | ||||
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> | ||||
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en-US"> | ||||
<head> | ||||
<link rel="icon" href="/static/hgicon.png" type="image/png" /> | ||||
<meta name="robots" content="index, nofollow" /> | ||||
<link rel="stylesheet" href="/static/style-paper.css" type="text/css" /> | ||||
<script type="text/javascript" src="/static/mercurial.js"></script> | ||||
<title>Help: internals.changegroups</title> | ||||
</head> | ||||
<body> | ||||
<div class="container"> | ||||
<div class="menu"> | ||||
<div class="logo"> | ||||
<a href="https://mercurial-scm.org/"> | ||||
<img src="/static/hglogo.png" alt="mercurial" /></a> | ||||
</div> | ||||
<ul> | ||||
<li><a href="/shortlog">log</a></li> | ||||
<li><a href="/graph">graph</a></li> | ||||
<li><a href="/tags">tags</a></li> | ||||
<li><a href="/bookmarks">bookmarks</a></li> | ||||
<li><a href="/branches">branches</a></li> | ||||
</ul> | ||||
<ul> | ||||
<li class="active"><a href="/help">help</a></li> | ||||
</ul> | ||||
</div> | ||||
<div class="main"> | ||||
<h2 class="breadcrumb"><a href="/">Mercurial</a> </h2> | ||||
<h3>Help: internals.changegroups</h3> | ||||
<form class="search" action="/log"> | ||||
<p><input name="rev" id="search1" type="text" size="30" /></p> | ||||
<div id="hint">Find changesets by keywords (author, files, the commit message), revision | ||||
number or hash, or <a href="/help/revsets">revset expression</a>.</div> | ||||
</form> | ||||
<div id="doc"> | ||||
Gregory Szorc
|
r29747 | <h1>Changegroups</h1> | ||
Gregory Szorc
|
r27582 | <p> | ||
Changegroups are representations of repository revlog data, specifically | ||||
the changelog, manifest, and filelogs. | ||||
</p> | ||||
<p> | ||||
There are 3 versions of changegroups: "1", "2", and "3". From a | ||||
high-level, versions "1" and "2" are almost exactly the same, with | ||||
the only difference being a header on entries in the changeset | ||||
segment. Version "3" adds support for exchanging treemanifests and | ||||
includes revlog flags in the delta header. | ||||
</p> | ||||
<p> | ||||
Changegroups consists of 3 logical segments: | ||||
</p> | ||||
<pre> | ||||
+---------------------------------+ | ||||
| | | | | ||||
| changeset | manifest | filelogs | | ||||
| | | | | ||||
+---------------------------------+ | ||||
</pre> | ||||
<p> | ||||
The principle building block of each segment is a *chunk*. A *chunk* | ||||
is a framed piece of data: | ||||
</p> | ||||
<pre> | ||||
+---------------------------------------+ | ||||
| | | | ||||
| length | data | | ||||
| (32 bits) | <length> bytes | | ||||
| | | | ||||
+---------------------------------------+ | ||||
</pre> | ||||
<p> | ||||
Each chunk starts with a 32-bit big-endian signed integer indicating | ||||
the length of the raw data that follows. | ||||
</p> | ||||
<p> | ||||
There is a special case chunk that has 0 length ("0x00000000"). We | ||||
call this an *empty chunk*. | ||||
</p> | ||||
Gregory Szorc
|
r29747 | <h2>Delta Groups</h2> | ||
Gregory Szorc
|
r27582 | <p> | ||
A *delta group* expresses the content of a revlog as a series of deltas, | ||||
or patches against previous revisions. | ||||
</p> | ||||
<p> | ||||
Delta groups consist of 0 or more *chunks* followed by the *empty chunk* | ||||
to signal the end of the delta group: | ||||
</p> | ||||
<pre> | ||||
+------------------------------------------------------------------------+ | ||||
| | | | | | | ||||
| chunk0 length | chunk0 data | chunk1 length | chunk1 data | 0x0 | | ||||
| (32 bits) | (various) | (32 bits) | (various) | (32 bits) | | ||||
| | | | | | | ||||
+------------------------------------------------------------+-----------+ | ||||
</pre> | ||||
<p> | ||||
Each *chunk*'s data consists of the following: | ||||
</p> | ||||
<pre> | ||||
+-----------------------------------------+ | ||||
| | | | | ||||
| delta header | mdiff header | delta | | ||||
| (various) | (12 bytes) | (various) | | ||||
| | | | | ||||
+-----------------------------------------+ | ||||
</pre> | ||||
<p> | ||||
The *length* field is the byte length of the remaining 3 logical pieces | ||||
of data. The *delta* is a diff from an existing entry in the changelog. | ||||
</p> | ||||
<p> | ||||
The *delta header* is different between versions "1", "2", and | ||||
"3" of the changegroup format. | ||||
</p> | ||||
<p> | ||||
Version 1: | ||||
</p> | ||||
<pre> | ||||
+------------------------------------------------------+ | ||||
| | | | | | ||||
| node | p1 node | p2 node | link node | | ||||
| (20 bytes) | (20 bytes) | (20 bytes) | (20 bytes) | | ||||
| | | | | | ||||
+------------------------------------------------------+ | ||||
</pre> | ||||
<p> | ||||
Version 2: | ||||
</p> | ||||
<pre> | ||||
+------------------------------------------------------------------+ | ||||
| | | | | | | ||||
| node | p1 node | p2 node | base node | link node | | ||||
| (20 bytes) | (20 bytes) | (20 bytes) | (20 bytes) | (20 bytes) | | ||||
| | | | | | | ||||
+------------------------------------------------------------------+ | ||||
</pre> | ||||
<p> | ||||
Version 3: | ||||
</p> | ||||
<pre> | ||||
+------------------------------------------------------------------------------+ | ||||
| | | | | | | | ||||
| node | p1 node | p2 node | base node | link node | flags | | ||||
| (20 bytes) | (20 bytes) | (20 bytes) | (20 bytes) | (20 bytes) | (2 bytes) | | ||||
| | | | | | | | ||||
+------------------------------------------------------------------------------+ | ||||
</pre> | ||||
<p> | ||||
The *mdiff header* consists of 3 32-bit big-endian signed integers | ||||
describing offsets at which to apply the following delta content: | ||||
</p> | ||||
<pre> | ||||
+-------------------------------------+ | ||||
| | | | | ||||
| offset | old length | new length | | ||||
| (32 bits) | (32 bits) | (32 bits) | | ||||
| | | | | ||||
+-------------------------------------+ | ||||
</pre> | ||||
<p> | ||||
In version 1, the delta is always applied against the previous node from | ||||
the changegroup or the first parent if this is the first entry in the | ||||
changegroup. | ||||
</p> | ||||
<p> | ||||
In version 2, the delta base node is encoded in the entry in the | ||||
changegroup. This allows the delta to be expressed against any parent, | ||||
which can result in smaller deltas and more efficient encoding of data. | ||||
</p> | ||||
Gregory Szorc
|
r29747 | <h2>Changeset Segment</h2> | ||
Gregory Szorc
|
r27582 | <p> | ||
The *changeset segment* consists of a single *delta group* holding | ||||
changelog data. It is followed by an *empty chunk* to denote the | ||||
boundary to the *manifests segment*. | ||||
</p> | ||||
Gregory Szorc
|
r29747 | <h2>Manifest Segment</h2> | ||
Gregory Szorc
|
r27582 | <p> | ||
The *manifest segment* consists of a single *delta group* holding | ||||
manifest data. It is followed by an *empty chunk* to denote the boundary | ||||
to the *filelogs segment*. | ||||
</p> | ||||
Gregory Szorc
|
r29747 | <h2>Filelogs Segment</h2> | ||
Gregory Szorc
|
r27582 | <p> | ||
The *filelogs* segment consists of multiple sub-segments, each | ||||
corresponding to an individual file whose data is being described: | ||||
</p> | ||||
<pre> | ||||
+--------------------------------------+ | ||||
| | | | | | ||||
| filelog0 | filelog1 | filelog2 | ... | | ||||
| | | | | | ||||
+--------------------------------------+ | ||||
</pre> | ||||
<p> | ||||
In version "3" of the changegroup format, filelogs may include | ||||
directory logs when treemanifests are in use. directory logs are | ||||
identified by having a trailing '/' on their filename (see below). | ||||
</p> | ||||
<p> | ||||
The final filelog sub-segment is followed by an *empty chunk* to denote | ||||
the end of the segment and the overall changegroup. | ||||
</p> | ||||
<p> | ||||
Each filelog sub-segment consists of the following: | ||||
</p> | ||||
<pre> | ||||
+------------------------------------------+ | ||||
| | | | | ||||
| filename size | filename | delta group | | ||||
| (32 bits) | (various) | (various) | | ||||
| | | | | ||||
+------------------------------------------+ | ||||
</pre> | ||||
<p> | ||||
That is, a *chunk* consisting of the filename (not terminated or padded) | ||||
followed by N chunks constituting the *delta group* for this file. | ||||
</p> | ||||
</div> | ||||
</div> | ||||
</div> | ||||
<script type="text/javascript">process_dates()</script> | ||||
</body> | ||||
</html> | ||||
Matt Mackall
|
r25474 | $ killdaemons.py | ||
Dan Villiom Podlaski Christiansen
|
r18744 | |||
#endif | ||||