diff options
Diffstat (limited to 'man/repo-forall.1')
| -rw-r--r-- | man/repo-forall.1 | 128 |
1 files changed, 128 insertions, 0 deletions
diff --git a/man/repo-forall.1 b/man/repo-forall.1 new file mode 100644 index 00000000..eb2ad57b --- /dev/null +++ b/man/repo-forall.1 | |||
| @@ -0,0 +1,128 @@ | |||
| 1 | .\" DO NOT MODIFY THIS FILE! It was generated by help2man. | ||
| 2 | .TH REPO "1" "July 2021" "repo forall" "Repo Manual" | ||
| 3 | .SH NAME | ||
| 4 | repo \- repo forall - manual page for repo forall | ||
| 5 | .SH SYNOPSIS | ||
| 6 | .B repo | ||
| 7 | \fI\,forall \/\fR[\fI\,<project>\/\fR...] \fI\,-c <command> \/\fR[\fI\,<arg>\/\fR...] | ||
| 8 | .SH DESCRIPTION | ||
| 9 | Summary | ||
| 10 | .PP | ||
| 11 | Run a shell command in each project | ||
| 12 | .PP | ||
| 13 | repo forall \fB\-r\fR str1 [str2] ... \fB\-c\fR <command> [<arg>...] | ||
| 14 | .SH OPTIONS | ||
| 15 | .TP | ||
| 16 | \fB\-h\fR, \fB\-\-help\fR | ||
| 17 | show this help message and exit | ||
| 18 | .TP | ||
| 19 | \fB\-j\fR JOBS, \fB\-\-jobs\fR=\fI\,JOBS\/\fR | ||
| 20 | number of jobs to run in parallel (default: based on | ||
| 21 | number of CPU cores) | ||
| 22 | .TP | ||
| 23 | \fB\-r\fR, \fB\-\-regex\fR | ||
| 24 | execute the command only on projects matching regex or | ||
| 25 | wildcard expression | ||
| 26 | .TP | ||
| 27 | \fB\-i\fR, \fB\-\-inverse\-regex\fR | ||
| 28 | execute the command only on projects not matching | ||
| 29 | regex or wildcard expression | ||
| 30 | .TP | ||
| 31 | \fB\-g\fR GROUPS, \fB\-\-groups\fR=\fI\,GROUPS\/\fR | ||
| 32 | execute the command only on projects matching the | ||
| 33 | specified groups | ||
| 34 | .TP | ||
| 35 | \fB\-c\fR, \fB\-\-command\fR | ||
| 36 | command (and arguments) to execute | ||
| 37 | .TP | ||
| 38 | \fB\-e\fR, \fB\-\-abort\-on\-errors\fR | ||
| 39 | abort if a command exits unsuccessfully | ||
| 40 | .TP | ||
| 41 | \fB\-\-ignore\-missing\fR | ||
| 42 | silently skip & do not exit non\-zero due missing | ||
| 43 | checkouts | ||
| 44 | .TP | ||
| 45 | \fB\-\-interactive\fR | ||
| 46 | force interactive usage | ||
| 47 | .SS Logging options: | ||
| 48 | .TP | ||
| 49 | \fB\-v\fR, \fB\-\-verbose\fR | ||
| 50 | show all output | ||
| 51 | .TP | ||
| 52 | \fB\-q\fR, \fB\-\-quiet\fR | ||
| 53 | only show errors | ||
| 54 | .TP | ||
| 55 | \fB\-p\fR | ||
| 56 | show project headers before output | ||
| 57 | .PP | ||
| 58 | Run `repo help forall` to view the detailed manual. | ||
| 59 | .SH DETAILS | ||
| 60 | .PP | ||
| 61 | Executes the same shell command in each project. | ||
| 62 | .PP | ||
| 63 | The \fB\-r\fR option allows running the command only on projects matching regex or | ||
| 64 | wildcard expression. | ||
| 65 | .PP | ||
| 66 | By default, projects are processed non\-interactively in parallel. If you want to | ||
| 67 | run interactive commands, make sure to pass \fB\-\-interactive\fR to force \fB\-\-jobs\fR 1. | ||
| 68 | While the processing order of projects is not guaranteed, the order of project | ||
| 69 | output is stable. | ||
| 70 | .PP | ||
| 71 | Output Formatting | ||
| 72 | .PP | ||
| 73 | The \fB\-p\fR option causes 'repo forall' to bind pipes to the command's stdin, stdout | ||
| 74 | and stderr streams, and pipe all output into a continuous stream that is | ||
| 75 | displayed in a single pager session. Project headings are inserted before the | ||
| 76 | output of each command is displayed. If the command produces no output in a | ||
| 77 | project, no heading is displayed. | ||
| 78 | .PP | ||
| 79 | The formatting convention used by \fB\-p\fR is very suitable for some types of | ||
| 80 | searching, e.g. `repo forall \fB\-p\fR \fB\-c\fR git log \fB\-SFoo\fR` will print all commits that | ||
| 81 | add or remove references to Foo. | ||
| 82 | .PP | ||
| 83 | The \fB\-v\fR option causes 'repo forall' to display stderr messages if a command | ||
| 84 | produces output only on stderr. Normally the \fB\-p\fR option causes command output to | ||
| 85 | be suppressed until the command produces at least one byte of output on stdout. | ||
| 86 | .PP | ||
| 87 | Environment | ||
| 88 | .PP | ||
| 89 | pwd is the project's working directory. If the current client is a mirror | ||
| 90 | client, then pwd is the Git repository. | ||
| 91 | .PP | ||
| 92 | REPO_PROJECT is set to the unique name of the project. | ||
| 93 | .PP | ||
| 94 | REPO_PATH is the path relative the the root of the client. | ||
| 95 | .PP | ||
| 96 | REPO_REMOTE is the name of the remote system from the manifest. | ||
| 97 | .PP | ||
| 98 | REPO_LREV is the name of the revision from the manifest, translated to a local | ||
| 99 | tracking branch. If you need to pass the manifest revision to a locally executed | ||
| 100 | git command, use REPO_LREV. | ||
| 101 | .PP | ||
| 102 | REPO_RREV is the name of the revision from the manifest, exactly as written in | ||
| 103 | the manifest. | ||
| 104 | .PP | ||
| 105 | REPO_COUNT is the total number of projects being iterated. | ||
| 106 | .PP | ||
| 107 | REPO_I is the current (1\-based) iteration count. Can be used in conjunction with | ||
| 108 | REPO_COUNT to add a simple progress indicator to your command. | ||
| 109 | .PP | ||
| 110 | REPO__* are any extra environment variables, specified by the "annotation" | ||
| 111 | element under any project element. This can be useful for differentiating trees | ||
| 112 | based on user\-specific criteria, or simply annotating tree details. | ||
| 113 | .PP | ||
| 114 | shell positional arguments ($1, $2, .., $#) are set to any arguments following | ||
| 115 | <command>. | ||
| 116 | .PP | ||
| 117 | Example: to list projects: | ||
| 118 | .IP | ||
| 119 | repo forall \fB\-c\fR 'echo $REPO_PROJECT' | ||
| 120 | .PP | ||
| 121 | Notice that $REPO_PROJECT is quoted to ensure it is expanded in the context of | ||
| 122 | running <command> instead of in the calling shell. | ||
| 123 | .PP | ||
| 124 | Unless \fB\-p\fR is used, stdin, stdout, stderr are inherited from the terminal and are | ||
| 125 | not redirected. | ||
| 126 | .PP | ||
| 127 | If \fB\-e\fR is used, when a command exits unsuccessfully, 'repo forall' will abort | ||
| 128 | without iterating through the remaining projects. | ||
