SYNOPSIS

mtn [options...] command [arguments...]

DESCRIPTION

monotone is a highly reliable, very customizable distributed version control system that provides lightweight branches, history-sensitive merging and a flexible trust setup. monotone has an easy-to-learn command set and comes with a rich interface for scripting purposes and thorough documentation.

For more information on monotone, visit http://www.monotone.ca.

The complete documentation, including a tutorial for a quick start with the system, can be found online on http://www.monotone.ca/docs.

GLOBAL OPTIONS

--confdir <arg>

set location of configuration directory

--date-format <arg>

strftime(3) format specification for printing dates

--db [ -d ] <arg>

set name of database

--dump <arg>

file to dump debugging log to, on failure

--help [ -h ]

display help message

--ignore-suspend-certs / --no-ignore-suspend-certs

do not ignore revisions marked as suspended

--key [ -k ] <arg> / --use-default-key

sets the key for signatures, using either the key name or the key hash

--keydir <arg>

set location of key store

--log <arg>

file to write the log to

--no-builtin-rcfile / --builtin-rcfile

do not load the built-in lua file with the default hooks

--no-default-confdir / --allow-default-confdir

forbid use of the default confdir

--no-format-dates

print date certs exactly as stored in the database

--no-standard-rcfiles / --standard-rcfiles

do not load '~/.monotone/monotonerc' or '_MTN/monotonerc' lua files

--no-workspace / --allow-workspace

don't look for a workspace

--non-interactive / --interactive

do not prompt the user for input

--quiet [ -q ]

decrease verbosity (undo previous '-v', then disable informational output, then disable warnings)

--rcfile <arg> / --clear-rcfiles

load extra lua file

--root <arg>

limit search for workspace to specified root

--ssh-sign <arg>

controls use of ssh-agent. valid arguments are: 'yes' to use ssh-agent to make signatures if possible, 'no' to force use of monotone's internal code, 'only' to force use of ssh-agent, 'check' to sign with both and compare

--ticker <arg>

set ticker style (count|dot|none)

--timestamps

show timestamps in front of errors, warnings and progress messages

--verbose [ -v ]

increase verbosity (undo previous '-q', and then enable debug output)

--version

print version number, then exit

--xargs [ -@ ] <arg>

insert command line arguments taken from the given file

COMMANDS

command group 'automation'

Commands that aid in scripted execution.

automate ancestors REV1 [REV2 [REV3 [...]]]

Prints the ancestors of the given revisions.

automate ancestry_difference NEW_REV [OLD_REV1 [OLD_REV2 [...]]]

Lists the ancestors of the first revision given, not in the others.

automate branches

Prints all branch certs in the revision graph.

automate cert REVISION-ID NAME VALUE

Adds a revision certificate.

automate certs REV

Prints all certificates attached to a revision.

automate checkout [DIRECTORY]

Checks out a revision from the database into a directory. If a revision is given, that's the one that will be checked out. Otherwise, it will be the head of the branch (given or implicit). If no directory is given, the branch name will be used as directory.

--branch [ -b ] <arg>

select branch cert for operation

--move-conflicting-paths / --no-move-conflicting-paths

move conflicting, unversioned paths into '_MTN/resolutions' before proceeding with any workspace change

--revision [ -r ] <arg>

select revision id for operation

automate children REV

Prints the children of a revision.

automate common_ancestors REV1 [REV2 [REV3 [...]]]

Prints revisions that are common ancestors of a list of revisions.

automate content_diff [FILE [...]]

Calculates diffs of files.

--depth <arg>

limit the number of levels of directories to descend

--exclude <arg>

leave out anything described by its argument

--reverse

reverse order of diff

--revision [ -r ] <arg>

select revision id for operation

--with-header / --without-header

show the matching cset in the diff header

automate descendents REV1 [REV2 [REV3 [...]]]

Prints the descendents of the given revisions.

automate drop_attribute PATH [KEY]

Drops an attribute or all of them from a certain path.

automate drop_db_variables DOMAIN [NAME]

Drops a database variable.

automate drop_public_key KEY_NAME_OR_HASH

Drops a public key.

automate erase_ancestors [REV1 [REV2 [REV3 [...]]]]

Erases the ancestors in a list of revisions.

automate erase_descendants [REV1 [REV2 [REV3 [...]]]]

Erases the descendants in a list of revisions.

automate file_merge LEFT_REVID LEFT_FILENAME RIGHT_REVID RIGHT_FILENAME

Prints the results of the internal line merger, given two child revisions and file names.

automate generate_key KEY_NAME PASSPHRASE

Generates an RSA key-pair.

--force-duplicate-key

force genkey to not error out when the named key already exists

automate get_attributes PATH

Prints all attributes for the specified path. If an explicit revision is given, the file's attributes at this specific revision are returned.

--revision [ -r ] <arg>

select revision id for operation

automate get_base_revision_id

Shows the revision on which the workspace is based.

automate get_content_changed REV FILE

Lists the revisions that changed the content relative to another revision.

automate get_corresponding_path REV1 FILE REV2

Prints the name of a file in a target revision relative to a given revision.

automate get_current_revision [PATHS ...]

Shows change information for a workspace.

--depth <arg>

limit the number of levels of directories to descend

--exclude <arg>

leave out anything described by its argument

automate get_current_revision_id

Shows the revision of the current workspace.

automate get_db_variables [DOMAIN]

Retrieve database variables.

automate get_extended_manifest_of REVISION

Prints the extended manifest for the given identifier.

automate get_file FILEID

Prints the contents of a file (given an identifier).

automate get_file_of FILENAME

Prints the contents of a file (given a name).

--revision [ -r ] <arg>

select revision id for operation

automate get_file_size FILEID

Prints the size of a file (given an identifier).

automate get_manifest_of [REVID]

Shows the manifest associated with a revision.

automate get_option OPTION

Shows the value of an option.

automate get_public_key KEY_NAME_OR_HASH

Prints a public key packet.

automate get_revision REVID

Shows change information for a revision.

automate get_workspace_root

Prints the workspace root for the current directory.

automate graph

Prints the complete ancestry graph.

automate heads [BRANCH]

Prints the heads of the given branch.

automate identify PATH

Prints the file identifier of a file.

automate interface_version

Prints the automation interface's version.

automate inventory [PATH]...

Prints a summary of files found in the workspace.

--depth <arg>

limit the number of levels of directories to descend

--exclude <arg>

leave out anything described by its argument

--no-corresponding-renames / --corresponding-renames

don't output corresponding renames if restricted on such nodes

--no-ignored / --ignored

don't output ignored files

--no-unchanged / --unchanged

don't output unchanged files

--no-unknown / --unknown

don't output unknown files

automate keys

Lists all keys in the keystore.

automate leaves

Lists the leaves of the revision graph.

automate log [PATH] ...

Lists the selected revision history.

--depth <arg>

limit the number of levels of directories to descend

--exclude <arg>

leave out anything described by its argument

--from <arg> / --clear-from

revision(s) to start logging at

--last <arg>

limit log output to the last number of entries

--next <arg>

limit log output to the next number of entries

--no-merges / --merges

exclude merges when printing logs

--to <arg> / --clear-to

revision(s) to stop logging at

automate lua LUA_FUNCTION [ARG1 [ARG2 [...]]]

Executes the given lua function and returns the result.

automate packet_for_fdata FILEID

Prints the file data in packet format.

automate packet_for_fdelta OLD_FILE NEW_FILE

Prints the file delta in packet format.

automate packet_for_rdata REVID

Prints the revision data in packet format.

automate packets_for_certs REVID

Prints the certs associated with a revision in packet format.

automate parents REV

Prints the parents of a revision.

automate pull [URI]
automate pull [ADDRESS[:PORTNUMBER] [PATTERN ...]]

Pulls branches from a netsync server.

--dry-run / --no-dry-run

don't perform the operation, just show what would have happened

--exclude <arg>

leave out anything described by its argument

--set-default / --no-set-default

use the current netsync arguments and options as the future default

automate push [URI]
automate push [ADDRESS[:PORTNUMBER] [PATTERN ...]]

Pushes branches to a netsync server.

--dry-run / --no-dry-run

don't perform the operation, just show what would have happened

--exclude <arg>

leave out anything described by its argument

--key-to-push <arg>

push the specified key even if it hasn't signed anything

--set-default / --no-set-default

use the current netsync arguments and options as the future default

automate put_file [FILEID] CONTENTS

Stores a file in the database.

automate put_public_key KEY-PACKET-DATA

Store the public key in the database.

automate put_revision REVISION-DATA

Stores a revision into the database.

automate read_packets PACKET-DATA

Load the given packets into the database.

automate remote COMMAND [ARGS]

Executes COMMAND on a remote server.

--remote-stdio-host <arg>

sets the host (and optionally the port) for a remote netsync action

--set-default / --no-set-default

use the current netsync arguments and options as the future default

automate remote_stdio [URI]
automate remote_stdio [ADDRESS[:PORTNUMBER]]

Opens an 'automate stdio' connection to a remote server.

--set-default / --no-set-default

use the current netsync arguments and options as the future default

automate roots

Lists the roots of the revision graph.

automate select SELECTOR

Lists the revisions that match a selector.

automate set_attribute PATH KEY VALUE

Sets an attribute on a certain path.

automate set_db_variable DOMAIN NAME VALUE

Sets a database variable.

automate show_conflicts [LEFT_REVID RIGHT_REVID]

Shows the conflicts between two revisions. If no arguments are given, LEFT_REVID and RIGHT_REVID default to the first two heads that would be chosen by the 'merge' command.

--branch [ -b ] <arg>

select branch cert for operation

--ignore-suspend-certs / --no-ignore-suspend-certs

do not ignore revisions marked as suspended

automate stdio

Automates several commands in one run.

--automate-stdio-size <arg>

block size in bytes for 'automate stdio' output

automate sync [URI]
automate sync [ADDRESS[:PORTNUMBER] [PATTERN ...]]

Synchronizes branches with a netsync server.

--dry-run / --no-dry-run

don't perform the operation, just show what would have happened

--exclude <arg>

leave out anything described by its argument

--key-to-push <arg>

push the specified key even if it hasn't signed anything

--set-default / --no-set-default

use the current netsync arguments and options as the future default

automate tags [BRANCH_PATTERN]

Prints all tags attached to a set of branches.

automate toposort [REV1 [REV2 [REV3 [...]]]]

Topologically sorts a list of revisions.

automate update

Updates the workspace.

--branch [ -b ] <arg>

select branch cert for operation

--move-conflicting-paths / --no-move-conflicting-paths

move conflicting, unversioned paths into '_MTN/resolutions' before proceeding with any workspace change

--revision [ -r ] <arg>

select revision id for operation

command group 'database'

Commands that manipulate the database.

db changesetify

Converts the database to the changeset format.

db check

Does some sanity checks on the database. Ensures that the database is consistent by issuing multiple checks.

db dump

Dumps the contents of the database. Generates a list of SQL instructions that represent the whole contents of the database. The resulting output is useful to later restore the database from a text file that serves as a backup.

db execute

Executes an SQL command on the database. Directly executes the given SQL command on the database

db fix_certs

Attempt to fix bad certs. Older monotone versions could sometimes associate certs with the wrong key. This fixes such certs if you have the correct key, and can optionally drop any certs that you don't have the correct key for. This should only be needed if you had such certs in your db when upgrading from 0.44 or earlier, or if you loaded such certs with 'mtn read'.

--drop-bad-certs

drop certs signed by keys we don't know about

db info

Shows information about the database.

--full / --concise

print detailed information

db init

Initializes a database. Creates a new database file and initializes it.

db load

Loads the contents of the database. Reads a list of SQL instructions that regenerate the contents of the database. This is supposed to be used in conjunction with the output generated by the 'dump' command.

db migrate

Migrates the database to a newer schema. Updates the database's internal schema to the most recent one. Needed to automatically resolve incompatibilities that may be introduced in newer versions of monotone.

db regenerate_caches

Regenerates the caches stored in the database.

db rosterify

Converts the database to the rosters format.

--drop-attr <arg>

when rosterifying, drop attrs entries with the given key

db set_epoch BRANCH EPOCH

Sets the branch's epoch.

db version

Shows the database's version.

local kill_certs SELECTOR CERTNAME [CERTVAL]

Deletes the specified certs from the local database. Deletes all certs which are on the given revision(s) and have the given name and if a value is specified then also the given value.

local kill_revision REVID

Kills a revision from the local database.

command group 'debug'

Commands that aid in program debugging.

asciik SELECTOR

Prints an ASCII representation of the revisions' graph.

fdiff SRCNAME DESTNAME SRCID DESTID

Differences 2 files and outputs the result.

--context

use context diff format

--diff-args <arg>

argument to pass external diff hook

--external

use external diff hook for generating diffs

--no-show-encloser / --show-encloser

do not show the function containing each block of changes

--reverse

reverse order of diff

--unified

use unified diff format

--with-header / --without-header

show the matching cset in the diff header

fload

Loads a file's contents into the database.

fmerge PARENT_FILEID LEFT_FILEID RIGHT_FILEID

Merges 3 files and outputs the result.

get_roster [REVID]

Dumps the roster associated with a given identifier. If no REVID is given, the workspace is used.

identify [PATH]

Calculates the identity of a file or stdin. If any PATH is given, calculates their identity; otherwise, the one from the standard input is calculated.

rcs_import RCSFILE...

Parses versions in RCS files. This command doesn't reconstruct or import revisions. You probably want to use cvs_import.

--branch [ -b ] <arg>

select branch cert for operation

command group 'informative'

Commands for information retrieval.

annotate PATH

Prints an annotated copy of a file. Calculates and prints an annotated copy of the given file from the specified REVISION.

--revision [ -r ] <arg>

select revision id for operation

--revs-only

annotate using full revision ids only

bisect bad

Marks the current revision or specified revisions as bad. Known bad revisions are removed from the set being searched.

--move-conflicting-paths / --no-move-conflicting-paths

move conflicting, unversioned paths into '_MTN/resolutions' before proceeding with any workspace change

--revision [ -r ] <arg>

select revision id for operation

bisect good

Marks the current revision or specified revisions as good. Known good revisions are removed from the set being searched.

--move-conflicting-paths / --no-move-conflicting-paths

move conflicting, unversioned paths into '_MTN/resolutions' before proceeding with any workspace change

--revision [ -r ] <arg>

select revision id for operation

bisect reset

Reset the current bisection search. Update the workspace back to the revision from which the bisection was started and remove all current search information, allowing a new search to be started.

bisect skip

Excludes the current revision or specified revisions from the search. Skipped revisions are removed from the set being searched. Revisions that cannot be tested for some reason should be skipped.

--move-conflicting-paths / --no-move-conflicting-paths

move conflicting, unversioned paths into '_MTN/resolutions' before proceeding with any workspace change

--revision [ -r ] <arg>

select revision id for operation

bisect status

Reports on the current status of the bisection search. Lists the total number of revisions in the search set, the number of revisions that have been determined to be good or bad, the number of revisions that have been skipped and the number of revisions remaining to be tested.

bisect update

Updates the workspace to the next revision to be tested by bisection. This command can be used if updates by good, bad or skip commands fail due to blocked paths or other problems.

--move-conflicting-paths / --no-move-conflicting-paths

move conflicting, unversioned paths into '_MTN/resolutions' before proceeding with any workspace change

cat FILENAME

Prints a file from the database. Fetches the given file FILENAME from the database and prints it to the standard output.

--revision [ -r ] <arg>

select revision id for operation

complete (revision|file|key) PARTIAL-ID

Completes a partial identifier.

di [PATH]...
diff [PATH]...

Shows current differences. Compares the current tree with the files in the repository and prints the differences on the standard output. If one revision is given, the diff between the workspace and that revision is shown. If two revisions are given, the diff between them is given. If no format is specified, unified is used by default.

--context

use context diff format

--depth <arg>

limit the number of levels of directories to descend

--diff-args <arg>

argument to pass external diff hook

--exclude <arg>

leave out anything described by its argument

--external

use external diff hook for generating diffs

--no-show-encloser / --show-encloser

do not show the function containing each block of changes

--reverse

reverse order of diff

--revision [ -r ] <arg>

select revision id for operation

--unified

use unified diff format

--with-header / --without-header

show the matching cset in the diff header

help command [ARGS...]

Displays help about commands and options.

--hidden / --no-hidden

show hidden commands and options

list branches [PATTERN]

Lists branches in the database that match a pattern.

--exclude <arg>

leave out anything described by its argument

list certs REVID

Lists certificates attached to a revision.

list changed [PATH...]

Lists files that have changed with respect to the current revision.

--depth <arg>

limit the number of levels of directories to descend

--exclude <arg>

leave out anything described by its argument

list databases
list dbs

Lists managed databases and their known workspaces.

list duplicates

Lists duplicate files in the specified revision. If no revision is specified, use the workspace.

--revision [ -r ] <arg>

select revision id for operation

list epochs [BRANCH [...]]

Lists the current epoch of branches that match a pattern.

list ignored [PATH]

Lists workspace files that are ignored in the current branch.

--depth <arg>

limit the number of levels of directories to descend

--exclude <arg>

leave out anything described by its argument

--recursive [ -R ] / --no-recursive

also operate on the contents of any listed directories

list keys [PATTERN]

Lists keys that match a pattern.

list known

Lists workspace files that belong to the current branch.

--depth <arg>

limit the number of levels of directories to descend

--exclude <arg>

leave out anything described by its argument

list missing

Lists files that belong to the branch but are not in the workspace.

--depth <arg>

limit the number of levels of directories to descend

--exclude <arg>

leave out anything described by its argument

list tags [PATTERN]

Lists all tags in the database.

--exclude <arg>

leave out anything described by its argument

list unknown [PATH]

Lists workspace files that are unknown in the current branch.

--depth <arg>

limit the number of levels of directories to descend

--exclude <arg>

leave out anything described by its argument

--recursive [ -R ] / --no-recursive

also operate on the contents of any listed directories

list vars [DOMAIN]

Lists variables in the whole database or a domain.

list workspaces

Lists known workspaces of a specified database.

log [PATH] ...

Prints selected history in forward or reverse order. This command prints selected history in forward or reverse order, filtering it by PATH if given.

--brief / --no-brief

print a brief version of the normal output

--depth <arg>

limit the number of levels of directories to descend

--diffs / --no-diffs

print diffs along with logs

--exclude <arg>

leave out anything described by its argument

--from <arg> / --clear-from

revision(s) to start logging at

--last <arg>

limit log output to the last number of entries

--next <arg>

limit log output to the next number of entries

--no-files / --files

exclude files when printing logs

--no-graph / --graph

do not use ASCII graph to display ancestry

--no-merges / --merges

exclude merges when printing logs

--revision [ -r ] <arg>

select revision id for operation

--to <arg> / --clear-to

revision(s) to stop logging at

manpage

Generate a manual page from monotone's command help.

--formatted / --plain

automatically run the output through nroff (default if the output is a terminal)

--hidden / --no-hidden

show hidden commands and options

show_conflicts REV REV

Shows what conflicts need resolution between two revisions. The conflicts are calculated based on the two revisions given in the REV parameters.

status [PATH]...

Shows workspace's status information.

--depth <arg>

limit the number of levels of directories to descend

--exclude <arg>

leave out anything described by its argument

version

Shows the program version.

--full / --concise

print detailed information

command group 'key_and_cert'

Commands to manage keys and certificates.

cert SELECTOR CERTNAME [CERTVAL]

Creates a certificate for a revision or set of revisions. Creates a certificate with the given name and value on each revision that matches the given selector

dropkey KEY_NAME_OR_HASH

Drops a public and/or private key.

genkey KEY_NAME

Generates an RSA key-pair.

--force-duplicate-key

force genkey to not error out when the named key already exists

passphrase KEY_NAME_OR_HASH

Changes the passphrase of a private RSA key.

ssh_agent_add

Adds a private key to ssh-agent.

ssh_agent_export [FILENAME]

Exports a private key for use with ssh-agent.

trusted REVISION NAME VALUE SIGNER1 [SIGNER2 [...]]

Tests whether a hypothetical certificate would be trusted. The current settings are used to run the test.

command group 'network'

Commands that access the network.

clone URI [DIRECTORY]
clone HOST[:PORTNUMBER] BRANCH [DIRECTORY]

Checks out a revision from a remote database into a directory. If a revision is given, that's the one that will be checked out. Otherwise, it will be the head of the branch supplied. If no directory is given, the branch name will be used as directory

--branch [ -b ] <arg>

select branch cert for operation

--revision [ -r ] <arg>

select revision id for operation

pull [URI]
pull [ADDRESS[:PORTNUMBER] [PATTERN ...]]

Pulls branches from a netsync server. This pulls all branches that match the pattern given in PATTERN from the netsync server at the address ADDRESS.

--dry-run / --no-dry-run

don't perform the operation, just show what would have happened

--exclude <arg>

leave out anything described by its argument

--set-default / --no-set-default

use the current netsync arguments and options as the future default

--update / --no-update

automatically update the workspace, if it was at a head and the command creates a new head

push [URI]
push [ADDRESS[:PORTNUMBER] [PATTERN ...]]

Pushes branches to a netsync server. This will push all branches that match the pattern given in PATTERN to the netsync server at the address ADDRESS.

--dry-run / --no-dry-run

don't perform the operation, just show what would have happened

--exclude <arg>

leave out anything described by its argument

--key-to-push <arg>

push the specified key even if it hasn't signed anything

--set-default / --no-set-default

use the current netsync arguments and options as the future default

serve

Serves the database to connecting clients.

--bind <arg>

address:port to listen on (default :4691)

--pid-file <arg> / --no-pid-file

record process id of server

sync [URI]
sync [ADDRESS[:PORTNUMBER] [PATTERN ...]]

Synchronizes branches with a netsync server. This synchronizes branches that match the pattern given in PATTERN with the netsync server at the address ADDRESS.

--dry-run / --no-dry-run

don't perform the operation, just show what would have happened

--exclude <arg>

leave out anything described by its argument

--key-to-push <arg>

push the specified key even if it hasn't signed anything

--set-default / --no-set-default

use the current netsync arguments and options as the future default

--update / --no-update

automatically update the workspace, if it was at a head and the command creates a new head

command group 'packet_io'

Commands for packet reading and writing.

privkey KEY_NAME_OR_HASH

Prints a private key packet.

pubkey KEY_NAME_OR_HASH

Prints a public key packet.

read [FILE1 [FILE2 [...]]]

Reads packets from files. If no files are provided, the standard input is used.

command group 'review'

Commands to review revisions.

approve REVISION

Approves a particular revision.

--branch [ -b ] <arg>

select branch cert for operation

--update / --no-update

automatically update the workspace, if it was at a head and the command creates a new head

comment REVISION [COMMENT]

Comments on a particular revision.

disapprove [PARENT-REVISION] CHILD-REVISION

Disapproves a particular revision or revision range.

--author <arg>

override author for commit

--branch [ -b ] <arg>

select branch cert for operation

--date <arg>

override date/time for commit

--message [ -m ] <arg>

set commit changelog message

--message-file <arg>

set filename containing commit changelog message

--update / --no-update

automatically update the workspace, if it was at a head and the command creates a new head

suspend REVISION

Suspends a particular revision.

--branch [ -b ] <arg>

select branch cert for operation

--update / --no-update

automatically update the workspace, if it was at a head and the command creates a new head

tag REVISION TAGNAME

Puts a symbolic tag certificate on a revision.

testresult REV (pass|fail|true|false|yes|no|1|0)

Notes the results of running a test on a revision.

command group 'tree'

Commands to manipulate the tree.

checkout [DIRECTORY]
co [DIRECTORY]

Checks out a revision from the database into a directory. If a revision is given, that's the one that will be checked out. Otherwise, it will be the head of the branch (given or implicit). If no directory is given, the branch name will be used as directory.

--branch [ -b ] <arg>

select branch cert for operation

--move-conflicting-paths / --no-move-conflicting-paths

move conflicting, unversioned paths into '_MTN/resolutions' before proceeding with any workspace change

--revision [ -r ] <arg>

select revision id for operation

conflicts clean

Delete any bookkeeping files related to conflict resolution.

conflicts resolve_first RESOLUTION

Set the resolution for the first unresolved single-file conflict.. Use 'mtn conflicts show_first' to see possible resolutions.

--conflicts-file <arg>

file in which to store conflicts

conflicts resolve_first_left RESOLUTION

Set the left resolution for the first unresolved two-file conflict.

--conflicts-file <arg>

file in which to store conflicts

conflicts resolve_first_right RESOLUTION

Set the right resolution for the first unresolved two-file conflict.

--conflicts-file <arg>

file in which to store conflicts

conflicts show_first

Show the first unresolved conflict in the conflicts file, and possible resolutions.

--conflicts-file <arg>

file in which to store conflicts

conflicts show_remaining

Show the remaining unresolved conflicts in the conflicts file.

--conflicts-file <arg>

file in which to store conflicts

conflicts store [LEFT_REVID RIGHT_REVID]

Store the conflicts from merging two revisions. If no arguments are given, LEFT_REVID and RIGHT_REVID default to the first two heads that would be chosen by the 'merge' command. If '--conflicts-file' is not given, '_MTN/conflicts' is used.

--branch [ -b ] <arg>

select branch cert for operation

--conflicts-file <arg>

file in which to store conflicts

explicit_merge LEFT-REVISION RIGHT-REVISION DEST-BRANCH

Merges two explicitly given revisions. The results of the merge are placed on the branch specified by DEST-BRANCH.

--author <arg>

override author for commit

--date <arg>

override date/time for commit

--message [ -m ] <arg>

set commit changelog message

--message-file <arg>

set filename containing commit changelog message

--resolve-conflicts / --no-resolve-conflicts

specify conflict resolutions in a file, instead of interactively

--resolve-conflicts-file <arg>

use file to resolve conflicts

--update / --no-update

automatically update the workspace, if it was at a head and the command creates a new head

heads

Shows unmerged head revisions of a branch.

--branch [ -b ] <arg>

select branch cert for operation

import DIRECTORY

Imports the contents of a directory into a branch.

--author <arg>

override author for commit

--branch [ -b ] <arg>

select branch cert for operation

--date <arg>

override date/time for commit

--dry-run / --no-dry-run

don't perform the operation, just show what would have happened

--exclude <arg>

leave out anything described by its argument

--message [ -m ] <arg>

set commit changelog message

--message-file <arg>

set filename containing commit changelog message

--no-respect-ignore / --respect-ignore

do not ignore any files

--revision [ -r ] <arg>

select revision id for operation

merge

Merges unmerged heads of a branch.

--author <arg>

override author for commit

--branch [ -b ] <arg>

select branch cert for operation

--date <arg>

override date/time for commit

--message [ -m ] <arg>

set commit changelog message

--message-file <arg>

set filename containing commit changelog message

--resolve-conflicts / --no-resolve-conflicts

specify conflict resolutions in a file, instead of interactively

--resolve-conflicts-file <arg>

use file to resolve conflicts

--update / --no-update

automatically update the workspace, if it was at a head and the command creates a new head

merge_into_dir SOURCE-BRANCH DEST-BRANCH DIR

Merges one branch into a subdirectory in another branch.

--author <arg>

override author for commit

--date <arg>

override date/time for commit

--message [ -m ] <arg>

set commit changelog message

--message-file <arg>

set filename containing commit changelog message

--resolve-conflicts / --no-resolve-conflicts

specify conflict resolutions in a file, instead of interactively

--resolve-conflicts-file <arg>

use file to resolve conflicts

--update / --no-update

automatically update the workspace, if it was at a head and the command creates a new head

merge_into_workspace OTHER-REVISION

Merges a revision into the current workspace's base revision. Merges OTHER-REVISION into the current workspace's base revision, and update the current workspace with the result. There can be no pending changes in the current workspace. Both OTHER-REVISION and the workspace's base revision will be recorded as parents on commit. The workspace's selected branch is not changed.

--move-conflicting-paths / --no-move-conflicting-paths

move conflicting, unversioned paths into '_MTN/resolutions' before proceeding with any workspace change

migrate_workspace [DIRECTORY]

Migrates a workspace directory's metadata to the latest format. If no directory is given, defaults to the current workspace.

propagate SOURCE-BRANCH DEST-BRANCH

Merges from one branch to another asymmetrically.

--author <arg>

override author for commit

--date <arg>

override date/time for commit

--message [ -m ] <arg>

set commit changelog message

--message-file <arg>

set filename containing commit changelog message

--resolve-conflicts / --no-resolve-conflicts

specify conflict resolutions in a file, instead of interactively

--resolve-conflicts-file <arg>

use file to resolve conflicts

refresh_inodeprints

Refreshes the inodeprint cache.

setup [DIRECTORY]

Sets up a new workspace directory. If no directory is specified, uses the current directory.

--branch [ -b ] <arg>

select branch cert for operation

command group 'variables'

Commands to manage persistent variables.

cleanup_workspace_list

Removes all invalid, registered workspace paths for the current database.

register_workspace [WORKSPACE_PATH]

Registers a new workspace for the current database. This command adds WORKSPACE_PATH to the list of `known-workspaces'.

set DOMAIN NAME VALUE

Sets a database variable. This command modifies (or adds if it did not exist before) the variable named NAME, stored in the database, and sets it to the given value in VALUE. The variable is placed in the domain DOMAIN.

unregister_workspace [WORKSPACE_PATH]

Unregisters an existing workspace for the current database. This command removes WORKSPACE_PATH to the list of `known-workspaces'.

unset DOMAIN NAME

Unsets a database variable. This command removes the variable NAME from domain DOMAIN, which was previously stored in the database.

command group 'vcs'

Commands for interaction with other version control systems.

cvs_import CVSROOT

Imports all versions in a CVS repository.

--branch [ -b ] <arg>

select branch cert for operation

git_export

Produces a git fast-export data stream on stdout.

--authors-file <arg>

file mapping author names from original to new values

--branches-file <arg>

file mapping branch names from original to new values

--export-marks <arg>

save the internal marks table after exporting revisions

--import-marks <arg>

load the internal marks table before exporting revisions

--log-certs / --no-log-certs

include standard cert values in commit logs

--log-revids / --no-log-revids

include revision ids in commit logs

--refs <arg>

include git refs for 'revs', 'roots' or 'leaves'

--use-one-changelog

use only one changelog cert for the git commit message

command group 'workspace'

Commands that deal with the workspace.

add [PATH]...

Adds files to the workspace.

--no-respect-ignore / --respect-ignore

do not ignore any files

--recursive [ -R ] / --no-recursive

also operate on the contents of any listed directories

--unknown / --no-unknown

perform the operations for unknown files from workspace

attr drop PATH [ATTR]

Removes attributes from a file. If no attribute is specified, this command removes all attributes attached to the file given in PATH. Otherwise only removes the attribute specified in ATTR.

attr get PATH [ATTR]

Gets the values of a file's attributes. If no attribute is specified, this command prints all attributes attached to the file given in PATH. Otherwise it only prints the attribute specified in ATTR.

attr set PATH ATTR VALUE

Sets an attribute on a file. Sets the attribute given on ATTR to the value specified in VALUE for the file mentioned in PATH.

ci [PATH]...
commit [PATH]...

Commits workspace changes to the database.

--author <arg>

override author for commit

--branch [ -b ] <arg>

select branch cert for operation

--date <arg>

override date/time for commit

--depth <arg>

limit the number of levels of directories to descend

--exclude <arg>

leave out anything described by its argument

--message [ -m ] <arg>

set commit changelog message

--message-file <arg>

set filename containing commit changelog message

drop [PATH]...
rm [PATH]...

Drops files from the workspace.

--bookkeep-only

only update monotone's internal bookkeeping, not the filesystem

--missing

perform the operations for files missing from workspace

--recursive [ -R ] / --no-recursive

also operate on the contents of any listed directories

mkdir [DIRECTORY...]

Creates directories and adds them to the workspace.

--no-respect-ignore / --respect-ignore

do not ignore any files

pivot_root NEW_ROOT PUT_OLD

Renames the root directory. After this command, the directory that currently has the name NEW_ROOT will be the root directory, and the directory that is currently the root directory will have name PUT_OLD. Use of '--bookkeep-only' is NOT recommended.

--bookkeep-only

only update monotone's internal bookkeeping, not the filesystem

--move-conflicting-paths / --no-move-conflicting-paths

move conflicting, unversioned paths into '_MTN/resolutions' before proceeding with any workspace change

pluck [PATH...]

Applies changes made at arbitrary places in history. This command takes changes made at any point in history, and edits your current workspace to include those changes. The end result is identical to 'mtn diff -r FROM -r TO | patch -p0', except that this command uses monotone's merger, and thus intelligently handles renames, conflicts, and so on. If one revision is given, applies the changes made in that revision compared to its parent. If two revisions are given, applies the changes made to get from the first revision to the second.

--depth <arg>

limit the number of levels of directories to descend

--exclude <arg>

leave out anything described by its argument

--move-conflicting-paths / --no-move-conflicting-paths

move conflicting, unversioned paths into '_MTN/resolutions' before proceeding with any workspace change

--revision [ -r ] <arg>

select revision id for operation

mv SRC DEST
mv SRC1 [SRC2 [...]] DEST_DIR
rename SRC DEST
rename SRC1 [SRC2 [...]] DEST_DIR

Renames entries in the workspace.

--bookkeep-only

only update monotone's internal bookkeeping, not the filesystem

revert [PATH]...

Reverts files and/or directories. In order to revert the entire workspace, specify '.' as the file name.

--depth <arg>

limit the number of levels of directories to descend

--exclude <arg>

leave out anything described by its argument

--missing

perform the operations for files missing from workspace

undrop PATH...

Reverses a mistaken 'drop'. If the file was deleted from the workspace, this is the same as 'revert'. Otherwise, it just removes the 'drop' from the manifest.

update

Updates the workspace. This command modifies your workspace to be based off of a different revision, preserving uncommitted changes as it does so. If a revision is given, update the workspace to that revision. If not, update the workspace to the head of the branch.

--branch [ -b ] <arg>

select branch cert for operation

--move-conflicting-paths / --no-move-conflicting-paths

move conflicting, unversioned paths into '_MTN/resolutions' before proceeding with any workspace change

--revision [ -r ] <arg>

select revision id for operation

RELATED TO mtn…

info mtn and the documentation on http://www.monotone.ca/docs

BUGS

Please report bugs to https://code.monotone.ca/p/monotone/issues/.

AUTHORS

monotone was written originally by Graydon Hoare <[email protected]> in 2003 and has since then received numerous contributions from many individuals. A complete list of authors can be found in AUTHORS.

Nowadays, monotone is maintained by a collective of enthusiastic programmers, known as the monotone development team.

COPYRIGHT

monotone and this man page is Copyright (c) 2003 - 2014 by the monotone development team.