| git-notes(1) |
| ============ |
| |
| NAME |
| ---- |
| git-notes - Add or inspect object notes |
| |
| SYNOPSIS |
| -------- |
| [verse] |
| 'git notes' [list [<object>]] |
| 'git notes' add [-f] [--allow-empty] [-F <file> | -m <msg> | (-c | -C) <object>] [<object>] |
| 'git notes' copy [-f] ( --stdin | <from-object> <to-object> ) |
| 'git notes' append [--allow-empty] [-F <file> | -m <msg> | (-c | -C) <object>] [<object>] |
| 'git notes' edit [--allow-empty] [<object>] |
| 'git notes' show [<object>] |
| 'git notes' merge [-v | -q] [-s <strategy> ] <notes-ref> |
| 'git notes' merge --commit [-v | -q] |
| 'git notes' merge --abort [-v | -q] |
| 'git notes' remove [--ignore-missing] [--stdin] [<object>...] |
| 'git notes' prune [-n | -v] |
| 'git notes' get-ref |
| |
| |
| DESCRIPTION |
| ----------- |
| Adds, removes, or reads notes attached to objects, without touching |
| the objects themselves. |
| |
| By default, notes are saved to and read from `refs/notes/commits`, but |
| this default can be overridden. See the OPTIONS, CONFIGURATION, and |
| ENVIRONMENT sections below. If this ref does not exist, it will be |
| quietly created when it is first needed to store a note. |
| |
| A typical use of notes is to supplement a commit message without |
| changing the commit itself. Notes can be shown by 'git log' along with |
| the original commit message. To distinguish these notes from the |
| message stored in the commit object, the notes are indented like the |
| message, after an unindented line saying "Notes (<refname>):" (or |
| "Notes:" for `refs/notes/commits`). |
| |
| Notes can also be added to patches prepared with `git format-patch` by |
| using the `--notes` option. Such notes are added as a patch commentary |
| after a three dash separator line. |
| |
| To change which notes are shown by 'git log', see the |
| "notes.displayRef" configuration in linkgit:git-log[1]. |
| |
| See the "notes.rewrite.<command>" configuration for a way to carry |
| notes across commands that rewrite commits. |
| |
| |
| SUBCOMMANDS |
| ----------- |
| |
| list:: |
| List the notes object for a given object. If no object is |
| given, show a list of all note objects and the objects they |
| annotate (in the format "<note object> <annotated object>"). |
| This is the default subcommand if no subcommand is given. |
| |
| add:: |
| Add notes for a given object (defaults to HEAD). Abort if the |
| object already has notes (use `-f` to overwrite existing notes). |
| However, if you're using `add` interactively (using an editor |
| to supply the notes contents), then - instead of aborting - |
| the existing notes will be opened in the editor (like the `edit` |
| subcommand). |
| |
| copy:: |
| Copy the notes for the first object onto the second object. |
| Abort if the second object already has notes, or if the first |
| object has none (use -f to overwrite existing notes to the |
| second object). This subcommand is equivalent to: |
| `git notes add [-f] -C $(git notes list <from-object>) <to-object>` |
| + |
| In `--stdin` mode, take lines in the format |
| + |
| ---------- |
| <from-object> SP <to-object> [ SP <rest> ] LF |
| ---------- |
| + |
| on standard input, and copy the notes from each <from-object> to its |
| corresponding <to-object>. (The optional `<rest>` is ignored so that |
| the command can read the input given to the `post-rewrite` hook.) |
| |
| append:: |
| Append to the notes of an existing object (defaults to HEAD). |
| Creates a new notes object if needed. |
| |
| edit:: |
| Edit the notes for a given object (defaults to HEAD). |
| |
| show:: |
| Show the notes for a given object (defaults to HEAD). |
| |
| merge:: |
| Merge the given notes ref into the current notes ref. |
| This will try to merge the changes made by the given |
| notes ref (called "remote") since the merge-base (if |
| any) into the current notes ref (called "local"). |
| + |
| If conflicts arise and a strategy for automatically resolving |
| conflicting notes (see the "NOTES MERGE STRATEGIES" section) is not given, |
| the "manual" resolver is used. This resolver checks out the |
| conflicting notes in a special worktree (`.git/NOTES_MERGE_WORKTREE`), |
| and instructs the user to manually resolve the conflicts there. |
| When done, the user can either finalize the merge with |
| 'git notes merge --commit', or abort the merge with |
| 'git notes merge --abort'. |
| |
| remove:: |
| Remove the notes for given objects (defaults to HEAD). When |
| giving zero or one object from the command line, this is |
| equivalent to specifying an empty note message to |
| the `edit` subcommand. |
| |
| prune:: |
| Remove all notes for non-existing/unreachable objects. |
| |
| get-ref:: |
| Print the current notes ref. This provides an easy way to |
| retrieve the current notes ref (e.g. from scripts). |
| |
| OPTIONS |
| ------- |
| -f:: |
| --force:: |
| When adding notes to an object that already has notes, |
| overwrite the existing notes (instead of aborting). |
| |
| -m <msg>:: |
| --message=<msg>:: |
| Use the given note message (instead of prompting). |
| If multiple `-m` options are given, their values |
| are concatenated as separate paragraphs. |
| Lines starting with `#` and empty lines other than a |
| single line between paragraphs will be stripped out. |
| |
| -F <file>:: |
| --file=<file>:: |
| Take the note message from the given file. Use '-' to |
| read the note message from the standard input. |
| Lines starting with `#` and empty lines other than a |
| single line between paragraphs will be stripped out. |
| |
| -C <object>:: |
| --reuse-message=<object>:: |
| Take the given blob object (for example, another note) as the |
| note message. (Use `git notes copy <object>` instead to |
| copy notes between objects.) |
| |
| -c <object>:: |
| --reedit-message=<object>:: |
| Like '-C', but with '-c' the editor is invoked, so that |
| the user can further edit the note message. |
| |
| --allow-empty:: |
| Allow an empty note object to be stored. The default behavior is |
| to automatically remove empty notes. |
| |
| --ref <ref>:: |
| Manipulate the notes tree in <ref>. This overrides |
| 'GIT_NOTES_REF' and the "core.notesRef" configuration. The ref |
| specifies the full refname when it begins with `refs/notes/`; when it |
| begins with `notes/`, `refs/` and otherwise `refs/notes/` is prefixed |
| to form a full name of the ref. |
| |
| --ignore-missing:: |
| Do not consider it an error to request removing notes from an |
| object that does not have notes attached to it. |
| |
| --stdin:: |
| Also read the object names to remove notes from from the standard |
| input (there is no reason you cannot combine this with object |
| names from the command line). |
| |
| -n:: |
| --dry-run:: |
| Do not remove anything; just report the object names whose notes |
| would be removed. |
| |
| -s <strategy>:: |
| --strategy=<strategy>:: |
| When merging notes, resolve notes conflicts using the given |
| strategy. The following strategies are recognized: "manual" |
| (default), "ours", "theirs", "union" and "cat_sort_uniq". |
| This option overrides the "notes.mergeStrategy" configuration setting. |
| See the "NOTES MERGE STRATEGIES" section below for more |
| information on each notes merge strategy. |
| |
| --commit:: |
| Finalize an in-progress 'git notes merge'. Use this option |
| when you have resolved the conflicts that 'git notes merge' |
| stored in .git/NOTES_MERGE_WORKTREE. This amends the partial |
| merge commit created by 'git notes merge' (stored in |
| .git/NOTES_MERGE_PARTIAL) by adding the notes in |
| .git/NOTES_MERGE_WORKTREE. The notes ref stored in the |
| .git/NOTES_MERGE_REF symref is updated to the resulting commit. |
| |
| --abort:: |
| Abort/reset a in-progress 'git notes merge', i.e. a notes merge |
| with conflicts. This simply removes all files related to the |
| notes merge. |
| |
| -q:: |
| --quiet:: |
| When merging notes, operate quietly. |
| |
| -v:: |
| --verbose:: |
| When merging notes, be more verbose. |
| When pruning notes, report all object names whose notes are |
| removed. |
| |
| |
| DISCUSSION |
| ---------- |
| |
| Commit notes are blobs containing extra information about an object |
| (usually information to supplement a commit's message). These blobs |
| are taken from notes refs. A notes ref is usually a branch which |
| contains "files" whose paths are the object names for the objects |
| they describe, with some directory separators included for performance |
| reasons footnote:[Permitted pathnames have the form |
| 'ab'`/`'cd'`/`'ef'`/`'...'`/`'abcdef...': a sequence of directory |
| names of two hexadecimal digits each followed by a filename with the |
| rest of the object ID.]. |
| |
| Every notes change creates a new commit at the specified notes ref. |
| You can therefore inspect the history of the notes by invoking, e.g., |
| `git log -p notes/commits`. Currently the commit message only records |
| which operation triggered the update, and the commit authorship is |
| determined according to the usual rules (see linkgit:git-commit[1]). |
| These details may change in the future. |
| |
| It is also permitted for a notes ref to point directly to a tree |
| object, in which case the history of the notes can be read with |
| `git log -p -g <refname>`. |
| |
| |
| NOTES MERGE STRATEGIES |
| ---------------------- |
| |
| The default notes merge strategy is "manual", which checks out |
| conflicting notes in a special work tree for resolving notes conflicts |
| (`.git/NOTES_MERGE_WORKTREE`), and instructs the user to resolve the |
| conflicts in that work tree. |
| When done, the user can either finalize the merge with |
| 'git notes merge --commit', or abort the merge with |
| 'git notes merge --abort'. |
| |
| Users may select an automated merge strategy from among the following using |
| either -s/--strategy option or configuring notes.mergeStrategy accordingly: |
| |
| "ours" automatically resolves conflicting notes in favor of the local |
| version (i.e. the current notes ref). |
| |
| "theirs" automatically resolves notes conflicts in favor of the remote |
| version (i.e. the given notes ref being merged into the current notes |
| ref). |
| |
| "union" automatically resolves notes conflicts by concatenating the |
| local and remote versions. |
| |
| "cat_sort_uniq" is similar to "union", but in addition to concatenating |
| the local and remote versions, this strategy also sorts the resulting |
| lines, and removes duplicate lines from the result. This is equivalent |
| to applying the "cat | sort | uniq" shell pipeline to the local and |
| remote versions. This strategy is useful if the notes follow a line-based |
| format where one wants to avoid duplicated lines in the merge result. |
| Note that if either the local or remote version contain duplicate lines |
| prior to the merge, these will also be removed by this notes merge |
| strategy. |
| |
| |
| EXAMPLES |
| -------- |
| |
| You can use notes to add annotations with information that was not |
| available at the time a commit was written. |
| |
| ------------ |
| $ git notes add -m 'Tested-by: Johannes Sixt <j6t@kdbg.org>' 72a144e2 |
| $ git show -s 72a144e |
| [...] |
| Signed-off-by: Junio C Hamano <gitster@pobox.com> |
| |
| Notes: |
| Tested-by: Johannes Sixt <j6t@kdbg.org> |
| ------------ |
| |
| In principle, a note is a regular Git blob, and any kind of |
| (non-)format is accepted. You can binary-safely create notes from |
| arbitrary files using 'git hash-object': |
| |
| ------------ |
| $ cc *.c |
| $ blob=$(git hash-object -w a.out) |
| $ git notes --ref=built add --allow-empty -C "$blob" HEAD |
| ------------ |
| |
| (You cannot simply use `git notes --ref=built add -F a.out HEAD` |
| because that is not binary-safe.) |
| Of course, it doesn't make much sense to display non-text-format notes |
| with 'git log', so if you use such notes, you'll probably need to write |
| some special-purpose tools to do something useful with them. |
| |
| |
| CONFIGURATION |
| ------------- |
| |
| core.notesRef:: |
| Notes ref to read and manipulate instead of |
| `refs/notes/commits`. Must be an unabbreviated ref name. |
| This setting can be overridden through the environment and |
| command line. |
| |
| notes.mergeStrategy:: |
| Which merge strategy to choose by default when resolving notes |
| conflicts. Must be one of `manual`, `ours`, `theirs`, `union`, or |
| `cat_sort_uniq`. Defaults to `manual`. See "NOTES MERGE STRATEGIES" |
| section above for more information on each strategy. |
| + |
| This setting can be overridden by passing the `--strategy` option. |
| |
| notes.<name>.mergeStrategy:: |
| Which merge strategy to choose when doing a notes merge into |
| refs/notes/<name>. This overrides the more general |
| "notes.mergeStrategy". See the "NOTES MERGE STRATEGIES" section above |
| for more information on each available strategy. |
| |
| notes.displayRef:: |
| Which ref (or refs, if a glob or specified more than once), in |
| addition to the default set by `core.notesRef` or |
| 'GIT_NOTES_REF', to read notes from when showing commit |
| messages with the 'git log' family of commands. |
| This setting can be overridden on the command line or by the |
| 'GIT_NOTES_DISPLAY_REF' environment variable. |
| See linkgit:git-log[1]. |
| |
| notes.rewrite.<command>:: |
| When rewriting commits with <command> (currently `amend` or |
| `rebase`), if this variable is `false`, git will not copy |
| notes from the original to the rewritten commit. Defaults to |
| `true`. See also "`notes.rewriteRef`" below. |
| + |
| This setting can be overridden by the 'GIT_NOTES_REWRITE_REF' |
| environment variable. |
| |
| notes.rewriteMode:: |
| When copying notes during a rewrite, what to do if the target |
| commit already has a note. Must be one of `overwrite`, |
| `concatenate`, `cat_sort_uniq`, or `ignore`. Defaults to |
| `concatenate`. |
| + |
| This setting can be overridden with the `GIT_NOTES_REWRITE_MODE` |
| environment variable. |
| |
| notes.rewriteRef:: |
| When copying notes during a rewrite, specifies the (fully |
| qualified) ref whose notes should be copied. May be a glob, |
| in which case notes in all matching refs will be copied. You |
| may also specify this configuration several times. |
| + |
| Does not have a default value; you must configure this variable to |
| enable note rewriting. |
| + |
| Can be overridden with the 'GIT_NOTES_REWRITE_REF' environment variable. |
| |
| |
| ENVIRONMENT |
| ----------- |
| |
| 'GIT_NOTES_REF':: |
| Which ref to manipulate notes from, instead of `refs/notes/commits`. |
| This overrides the `core.notesRef` setting. |
| |
| 'GIT_NOTES_DISPLAY_REF':: |
| Colon-delimited list of refs or globs indicating which refs, |
| in addition to the default from `core.notesRef` or |
| 'GIT_NOTES_REF', to read notes from when showing commit |
| messages. |
| This overrides the `notes.displayRef` setting. |
| + |
| A warning will be issued for refs that do not exist, but a glob that |
| does not match any refs is silently ignored. |
| |
| 'GIT_NOTES_REWRITE_MODE':: |
| When copying notes during a rewrite, what to do if the target |
| commit already has a note. |
| Must be one of `overwrite`, `concatenate`, `cat_sort_uniq`, or `ignore`. |
| This overrides the `core.rewriteMode` setting. |
| |
| 'GIT_NOTES_REWRITE_REF':: |
| When rewriting commits, which notes to copy from the original |
| to the rewritten commit. Must be a colon-delimited list of |
| refs or globs. |
| + |
| If not set in the environment, the list of notes to copy depends |
| on the `notes.rewrite.<command>` and `notes.rewriteRef` settings. |
| |
| GIT |
| --- |
| Part of the linkgit:git[1] suite |