]>
Commit | Line | Data |
---|---|---|
215a7ad1 JH |
1 | git-send-email(1) |
2 | ================= | |
479cec96 RA |
3 | |
4 | NAME | |
5 | ---- | |
215a7ad1 | 6 | git-send-email - Send a collection of patches as emails |
479cec96 RA |
7 | |
8 | ||
9 | SYNOPSIS | |
10 | -------- | |
7791a1d9 | 11 | [verse] |
a2ce6082 TP |
12 | 'git send-email' [<options>] <file|directory>... |
13 | 'git send-email' [<options>] <format-patch options> | |
17b7a832 | 14 | 'git send-email' --dump-aliases |
479cec96 RA |
15 | |
16 | ||
479cec96 RA |
17 | DESCRIPTION |
18 | ----------- | |
19 | Takes the patches given on the command line and emails them out. | |
94af7c31 PB |
20 | Patches can be specified as files, directories (which will send all |
21 | files in the directory), or directly as a revision list. In the | |
22 | last case, any format accepted by linkgit:git-format-patch[1] can | |
a2ce6082 TP |
23 | be passed to git send-email, as well as options understood by |
24 | linkgit:git-format-patch[1]. | |
479cec96 | 25 | |
06ab60c0 | 26 | The header of the email is configurable via command-line options. If not |
479cec96 RA |
27 | specified on the command line, the user will be prompted with a ReadLine |
28 | enabled interface to provide the necessary information. | |
29 | ||
c4ba87a6 TZ |
30 | There are two formats accepted for patch files: |
31 | ||
32 | 1. mbox format files | |
33 | + | |
34 | This is what linkgit:git-format-patch[1] generates. Most headers and MIME | |
35 | formatting are ignored. | |
36 | ||
37 | 2. The original format used by Greg Kroah-Hartman's 'send_lots_of_email.pl' | |
ba170517 | 38 | script |
c4ba87a6 TZ |
39 | + |
40 | This format expects the first line of the file to contain the "Cc:" value | |
41 | and the "Subject:" of the message as the second line. | |
42 | ||
917f3e73 | 43 | |
df8baa42 JF |
44 | OPTIONS |
45 | ------- | |
917f3e73 MW |
46 | |
47 | Composing | |
48 | ~~~~~~~~~ | |
479cec96 | 49 | |
432b1282 | 50 | --annotate:: |
402596aa | 51 | Review and edit each patch you're about to send. Default is the value |
ae9f6311 TR |
52 | of `sendemail.annotate`. See the CONFIGURATION section for |
53 | `sendemail.multiEdit`. | |
432b1282 | 54 | |
b1c8a11c | 55 | --bcc=<address>,...:: |
3971a973 | 56 | Specify a "Bcc:" value for each email. Default is the value of |
ae9f6311 | 57 | `sendemail.bcc`. |
5ef1f8d4 | 58 | + |
b1c8a11c | 59 | This option may be specified multiple times. |
79ee555b | 60 | |
b1c8a11c | 61 | --cc=<address>,...:: |
da140f8b | 62 | Specify a starting "Cc:" value for each email. |
ae9f6311 | 63 | Default is the value of `sendemail.cc`. |
5ef1f8d4 | 64 | + |
b1c8a11c | 65 | This option may be specified multiple times. |
79ee555b | 66 | |
2718435b | 67 | --compose:: |
b4479f07 JN |
68 | Invoke a text editor (see GIT_EDITOR in linkgit:git-var[1]) |
69 | to edit an introductory message for the patch series. | |
beece9da | 70 | + |
bcf9626a | 71 | When `--compose` is used, git send-email will use the From, Subject, and |
01d38612 SB |
72 | In-Reply-To headers specified in the message. If the body of the message |
73 | (what you type after the headers and a blank line) only contains blank | |
06ab60c0 | 74 | (or Git: prefixed) lines, the summary won't be sent, but From, Subject, |
01d38612 | 75 | and In-Reply-To headers will be used unless they are removed. |
beece9da | 76 | + |
01d38612 | 77 | Missing From or In-Reply-To headers will be prompted for. |
3a78d078 | 78 | + |
ae9f6311 | 79 | See the CONFIGURATION section for `sendemail.multiEdit`. |
479cec96 | 80 | |
4c0fe0af | 81 | --from=<address>:: |
09caa24f | 82 | Specify the sender of the emails. If not specified on the command line, |
ae9f6311 TR |
83 | the value of the `sendemail.from` configuration option is used. If |
84 | neither the command-line option nor `sendemail.from` are set, then the | |
09caa24f TP |
85 | user will be prompted for the value. The default for the prompt will be |
86 | the value of GIT_AUTHOR_IDENT, or GIT_COMMITTER_IDENT if that is not | |
87 | set, as returned by "git var -l". | |
479cec96 | 88 | |
d11c943c CL |
89 | --reply-to=<address>:: |
90 | Specify the address where replies from recipients should go to. | |
91 | Use this if replies to messages should go to another address than what | |
92 | is specified with the --from parameter. | |
93 | ||
4c0fe0af | 94 | --in-reply-to=<identifier>:: |
db54c8e7 AO |
95 | Make the first mail (or all the mails with `--no-thread`) appear as a |
96 | reply to the given Message-Id, which avoids breaking threads to | |
97 | provide a new patch series. | |
98 | The second and subsequent emails will be sent as replies according to | |
2c7ee986 | 99 | the `--[no-]chain-reply-to` setting. |
db54c8e7 AO |
100 | + |
101 | So for example when `--thread` and `--no-chain-reply-to` are specified, the | |
102 | second and subsequent patches will be replies to the first one like in the | |
103 | illustration below where `[PATCH v2 0/3]` is in reply to `[PATCH 0/2]`: | |
104 | + | |
105 | [PATCH 0/2] Here is what I did... | |
106 | [PATCH 1/2] Clean up and tests | |
107 | [PATCH 2/2] Implementation | |
108 | [PATCH v2 0/3] Here is a reroll | |
109 | [PATCH v2 1/3] Clean up | |
110 | [PATCH v2 2/3] New tests | |
111 | [PATCH v2 3/3] Implementation | |
112 | + | |
113 | Only necessary if --compose is also set. If --compose | |
114 | is not set, this will be prompted for. | |
479cec96 | 115 | |
4c0fe0af | 116 | --subject=<string>:: |
917f3e73 MW |
117 | Specify the initial subject of the email thread. |
118 | Only necessary if --compose is also set. If --compose | |
119 | is not set, this will be prompted for. | |
a6d62cdd | 120 | |
b1c8a11c | 121 | --to=<address>,...:: |
917f3e73 MW |
122 | Specify the primary recipient of the emails generated. Generally, this |
123 | will be the upstream maintainer of the project involved. Default is the | |
ae9f6311 | 124 | value of the `sendemail.to` configuration value; if that is unspecified, |
6e74e075 | 125 | and --to-cmd is not specified, this will be prompted for. |
917f3e73 | 126 | + |
b1c8a11c | 127 | This option may be specified multiple times. |
917f3e73 | 128 | |
3cae7e5b TR |
129 | --8bit-encoding=<encoding>:: |
130 | When encountering a non-ASCII message or subject that does not | |
131 | declare its encoding, add headers/quoting to indicate it is | |
132 | encoded in <encoding>. Default is the value of the | |
133 | 'sendemail.assume8bitEncoding'; if that is unspecified, this | |
134 | will be prompted for if any non-ASCII files are encountered. | |
135 | + | |
136 | Note that no attempts whatsoever are made to validate the encoding. | |
137 | ||
62e00690 KM |
138 | --compose-encoding=<encoding>:: |
139 | Specify encoding of compose message. Default is the value of the | |
140 | 'sendemail.composeencoding'; if that is unspecified, UTF-8 is assumed. | |
141 | ||
7a36987f | 142 | --transfer-encoding=(7bit|8bit|quoted-printable|base64|auto):: |
8d814084 PB |
143 | Specify the transfer encoding to be used to send the message over SMTP. |
144 | 7bit will fail upon encountering a non-ASCII message. quoted-printable | |
145 | can be useful when the repository contains files that contain carriage | |
146 | returns, but makes the raw patch email file (as saved from a MUA) much | |
147 | harder to inspect manually. base64 is even more fool proof, but also | |
7a36987f | 148 | even more opaque. auto will use 8bit when possible, and quoted-printable |
149 | otherwise. | |
150 | + | |
151 | Default is the value of the `sendemail.transferEncoding` configuration | |
e67a228c | 152 | value; if that is unspecified, default to `auto`. |
8d814084 | 153 | |
ac1596a6 LH |
154 | --xmailer:: |
155 | --no-xmailer:: | |
156 | Add (or prevent adding) the "X-Mailer:" header. By default, | |
157 | the header is added, but it can be turned off by setting the | |
158 | `sendemail.xmailer` configuration variable to `false`. | |
917f3e73 MW |
159 | |
160 | Sending | |
161 | ~~~~~~~ | |
162 | ||
4c0fe0af | 163 | --envelope-sender=<address>:: |
917f3e73 MW |
164 | Specify the envelope sender used to send the emails. |
165 | This is useful if your default address is not the address that is | |
c89e3241 FC |
166 | subscribed to a list. In order to use the 'From' address, set the |
167 | value to "auto". If you use the sendmail binary, you must have | |
168 | suitable privileges for the -f parameter. Default is the value of the | |
ae9f6311 | 169 | `sendemail.envelopeSender` configuration variable; if that is |
917f3e73 | 170 | unspecified, choosing the envelope sender is left to your MTA. |
73811e66 | 171 | |
cd5b33fb GA |
172 | --sendmail-cmd=<command>:: |
173 | Specify a command to run to send the email. The command should | |
174 | be sendmail-like; specifically, it must support the `-i` option. | |
175 | The command will be executed in the shell if necessary. Default | |
176 | is the value of `sendemail.sendmailcmd`. If unspecified, and if | |
177 | --smtp-server is also unspecified, git-send-email will search | |
178 | for `sendmail` in `/usr/sbin`, `/usr/lib` and $PATH. | |
179 | ||
4c0fe0af | 180 | --smtp-encryption=<encryption>:: |
73811e66 MW |
181 | Specify the encryption to use, either 'ssl' or 'tls'. Any other |
182 | value reverts to plain SMTP. Default is the value of | |
ae9f6311 | 183 | `sendemail.smtpEncryption`. |
73811e66 | 184 | |
79ca070c BG |
185 | --smtp-domain=<FQDN>:: |
186 | Specifies the Fully Qualified Domain Name (FQDN) used in the | |
187 | HELO/EHLO command to the SMTP server. Some servers require the | |
188 | FQDN to match your IP address. If not set, git send-email attempts | |
69cf7bfd | 189 | to determine your FQDN automatically. Default is the value of |
ae9f6311 | 190 | `sendemail.smtpDomain`. |
79ca070c | 191 | |
0f2e68b5 JV |
192 | --smtp-auth=<mechanisms>:: |
193 | Whitespace-separated list of allowed SMTP-AUTH mechanisms. This setting | |
194 | forces using only the listed mechanisms. Example: | |
195 | + | |
196 | ------ | |
197 | $ git send-email --smtp-auth="PLAIN LOGIN GSSAPI" ... | |
198 | ------ | |
199 | + | |
200 | If at least one of the specified mechanisms matches the ones advertised by the | |
201 | SMTP server and if it is supported by the utilized SASL library, the mechanism | |
bcf9626a | 202 | is used for authentication. If neither 'sendemail.smtpAuth' nor `--smtp-auth` |
8dd9b3f8 JW |
203 | is specified, all mechanisms supported by the SASL library can be used. The |
204 | special value 'none' maybe specified to completely disable authentication | |
205 | independently of `--smtp-user` | |
0f2e68b5 | 206 | |
4c0fe0af | 207 | --smtp-pass[=<password>]:: |
73811e66 MW |
208 | Password for SMTP-AUTH. The argument is optional: If no |
209 | argument is specified, then the empty string is used as | |
ae9f6311 | 210 | the password. Default is the value of `sendemail.smtpPass`, |
bcf9626a | 211 | however `--smtp-pass` always overrides this value. |
73811e66 MW |
212 | + |
213 | Furthermore, passwords need not be specified in configuration files | |
214 | or on the command line. If a username has been specified (with | |
bcf9626a MM |
215 | `--smtp-user` or a `sendemail.smtpUser`), but no password has been |
216 | specified (with `--smtp-pass` or `sendemail.smtpPass`), then | |
4d31a44a | 217 | a password is obtained using 'git-credential'. |
34cc60ce | 218 | |
8dd9b3f8 JW |
219 | --no-smtp-auth:: |
220 | Disable SMTP authentication. Short hand for `--smtp-auth=none` | |
221 | ||
4c0fe0af | 222 | --smtp-server=<host>:: |
928a5590 | 223 | If set, specifies the outgoing SMTP server to use (e.g. |
cd5b33fb GA |
224 | `smtp.example.com` or a raw IP address). If unspecified, and if |
225 | `--sendmail-cmd` is also unspecified, the default is to search | |
226 | for `sendmail` in `/usr/sbin`, `/usr/lib` and $PATH if such a | |
227 | program is available, falling back to `localhost` otherwise. | |
228 | + | |
229 | For backward compatibility, this option can also specify a full pathname | |
230 | of a sendmail-like program instead; the program must support the `-i` | |
231 | option. This method does not support passing arguments or using plain | |
232 | command names. For those use cases, consider using `--sendmail-cmd` | |
233 | instead. | |
a6d62cdd | 234 | |
4c0fe0af | 235 | --smtp-server-port=<port>:: |
44b2476a | 236 | Specifies a port different from the default port (SMTP |
2da846e7 WL |
237 | servers typically listen to smtp port 25, but may also listen to |
238 | submission port 587, or the common SSL smtp port 465); | |
239 | symbolic port names (e.g. "submission" instead of 587) | |
dd602bf8 | 240 | are also accepted. The port can also be set with the |
ae9f6311 | 241 | `sendemail.smtpServerPort` configuration variable. |
44b2476a | 242 | |
052fbea2 PO |
243 | --smtp-server-option=<option>:: |
244 | If set, specifies the outgoing SMTP server option to use. | |
ae9f6311 | 245 | Default value can be specified by the `sendemail.smtpServerOption` |
052fbea2 PO |
246 | configuration option. |
247 | + | |
248 | The --smtp-server-option option must be repeated for each option you want | |
249 | to pass to the server. Likewise, different lines in the configuration files | |
250 | must be used for each option. | |
251 | ||
73811e66 | 252 | --smtp-ssl:: |
3971a973 | 253 | Legacy alias for '--smtp-encryption ssl'. |
73811e66 | 254 | |
35035bbf | 255 | --smtp-ssl-cert-path:: |
bcfe6f32 AW |
256 | Path to a store of trusted CA certificates for SMTP SSL/TLS |
257 | certificate validation (either a directory that has been processed | |
258 | by 'c_rehash', or a single file containing one or more PEM format | |
259 | certificates concatenated together: see verify(1) -CAfile and | |
260 | -CApath for more information on these). Set it to an empty string | |
261 | to disable certificate verification. Defaults to the value of the | |
ae9f6311 | 262 | `sendemail.smtpsslcertpath` configuration variable, if set, or the |
bcfe6f32 AW |
263 | backing SSL library's compiled-in default otherwise (which should |
264 | be the best choice on most platforms). | |
35035bbf | 265 | |
4c0fe0af | 266 | --smtp-user=<user>:: |
ae9f6311 | 267 | Username for SMTP-AUTH. Default is the value of `sendemail.smtpUser`; |
bcf9626a | 268 | if a username is not specified (with `--smtp-user` or `sendemail.smtpUser`), |
3971a973 | 269 | then authentication is not attempted. |
2363d746 | 270 | |
3ddf9228 ZJS |
271 | --smtp-debug=0|1:: |
272 | Enable (1) or disable (0) debug output. If enabled, SMTP | |
273 | commands and replies will be printed. Useful to debug TLS | |
274 | connection and authentication problems. | |
917f3e73 | 275 | |
5453b83b | 276 | --batch-size=<num>:: |
277 | Some email servers (e.g. smtp.163.com) limit the number emails to be | |
c30d4f1b | 278 | sent per session (connection) and this will lead to a failure when |
5453b83b | 279 | sending many messages. With this option, send-email will disconnect after |
280 | sending $<num> messages and wait for a few seconds (see --relogin-delay) | |
281 | and reconnect, to work around such a limit. You may want to | |
282 | use some form of credential helper to avoid having to retype | |
283 | your password every time this happens. Defaults to the | |
284 | `sendemail.smtpBatchSize` configuration variable. | |
285 | ||
286 | --relogin-delay=<int>:: | |
287 | Waiting $<int> seconds before reconnecting to SMTP server. Used together | |
288 | with --batch-size option. Defaults to the `sendemail.smtpReloginDelay` | |
289 | configuration variable. | |
290 | ||
917f3e73 MW |
291 | Automating |
292 | ~~~~~~~~~~ | |
293 | ||
564eba4b ÆAB |
294 | --no-[to|cc|bcc]:: |
295 | Clears any list of "To:", "Cc:", "Bcc:" addresses previously | |
296 | set via config. | |
297 | ||
3ff15040 ÆAB |
298 | --no-identity:: |
299 | Clears the previously read value of `sendemail.identity` set | |
300 | via config, if any. | |
301 | ||
6e74e075 JP |
302 | --to-cmd=<command>:: |
303 | Specify a command to execute once per patch file which | |
304 | should generate patch file specific "To:" entries. | |
305 | Output of this command must be single email address per line. | |
306 | Default is the value of 'sendemail.tocmd' configuration value. | |
307 | ||
4c0fe0af | 308 | --cc-cmd=<command>:: |
917f3e73 MW |
309 | Specify a command to execute once per patch file which |
310 | should generate patch file specific "Cc:" entries. | |
311 | Output of this command must be single email address per line. | |
ae9f6311 | 312 | Default is the value of `sendemail.ccCmd` configuration value. |
917f3e73 | 313 | |
0fd41f2d | 314 | --[no-]chain-reply-to:: |
917f3e73 MW |
315 | If this is set, each email will be sent as a reply to the previous |
316 | email sent. If disabled with "--no-chain-reply-to", all emails after | |
317 | the first will be sent as replies to the first email sent. When using | |
318 | this, it is recommended that the first file given be an overview of the | |
ae9f6311 | 319 | entire patch series. Disabled by default, but the `sendemail.chainReplyTo` |
41fe87fa | 320 | configuration variable can be used to enable it. |
917f3e73 | 321 | |
4c0fe0af | 322 | --identity=<identity>:: |
917f3e73 MW |
323 | A configuration identity. When given, causes values in the |
324 | 'sendemail.<identity>' subsection to take precedence over | |
325 | values in the 'sendemail' section. The default identity is | |
ae9f6311 | 326 | the value of `sendemail.identity`. |
917f3e73 MW |
327 | |
328 | --[no-]signed-off-by-cc:: | |
3abd4a67 | 329 | If this is set, add emails found in the `Signed-off-by` trailer or Cc: lines to the |
ae9f6311 | 330 | cc list. Default is the value of `sendemail.signedoffbycc` configuration |
917f3e73 | 331 | value; if that is unspecified, default to --signed-off-by-cc. |
2718435b | 332 | |
f515c904 MT |
333 | --[no-]cc-cover:: |
334 | If this is set, emails found in Cc: headers in the first patch of | |
335 | the series (typically the cover letter) are added to the cc list | |
336 | for each email set. Default is the value of 'sendemail.cccover' | |
337 | configuration value; if that is unspecified, default to --no-cc-cover. | |
338 | ||
339 | --[no-]to-cover:: | |
340 | If this is set, emails found in To: headers in the first patch of | |
341 | the series (typically the cover letter) are added to the to list | |
342 | for each email set. Default is the value of 'sendemail.tocover' | |
343 | configuration value; if that is unspecified, default to --no-to-cover. | |
344 | ||
4c0fe0af | 345 | --suppress-cc=<category>:: |
65648283 | 346 | Specify an additional category of recipients to suppress the |
3531e270 JS |
347 | auto-cc of: |
348 | + | |
349 | -- | |
af249bfe RV |
350 | - 'author' will avoid including the patch author. |
351 | - 'self' will avoid including the sender. | |
3531e270 JS |
352 | - 'cc' will avoid including anyone mentioned in Cc lines in the patch header |
353 | except for self (use 'self' for that). | |
cb8a9bd5 | 354 | - 'bodycc' will avoid including anyone mentioned in Cc lines in the |
3531e270 | 355 | patch body (commit message) except for self (use 'self' for that). |
3abd4a67 | 356 | - 'sob' will avoid including anyone mentioned in the Signed-off-by trailers except |
af249bfe | 357 | for self (use 'self' for that). |
ef0cc1df RV |
358 | - 'misc-by' will avoid including anyone mentioned in Acked-by, |
359 | Reviewed-by, Tested-by and other "-by" lines in the patch body, | |
360 | except Signed-off-by (use 'sob' for that). | |
3531e270 | 361 | - 'cccmd' will avoid running the --cc-cmd. |
ef0cc1df | 362 | - 'body' is equivalent to 'sob' + 'bodycc' + 'misc-by'. |
3531e270 JS |
363 | - 'all' will suppress all auto cc values. |
364 | -- | |
365 | + | |
ae9f6311 | 366 | Default is the value of `sendemail.suppresscc` configuration value; if |
3531e270 JS |
367 | that is unspecified, default to 'self' if --suppress-from is |
368 | specified, as well as 'body' if --no-signed-off-cc is specified. | |
65648283 | 369 | |
73811e66 MW |
370 | --[no-]suppress-from:: |
371 | If this is set, do not add the From: address to the cc: list. | |
ae9f6311 | 372 | Default is the value of `sendemail.suppressFrom` configuration |
73811e66 MW |
373 | value; if that is unspecified, default to --no-suppress-from. |
374 | ||
7ecbad91 | 375 | --[no-]thread:: |
f693b7e9 YD |
376 | If this is set, the In-Reply-To and References headers will be |
377 | added to each email sent. Whether each mail refers to the | |
378 | previous email (`deep` threading per 'git format-patch' | |
379 | wording) or to the first email (`shallow` threading) is | |
380 | governed by "--[no-]chain-reply-to". | |
381 | + | |
382 | If disabled with "--no-thread", those headers will not be added | |
383 | (unless specified with --in-reply-to). Default is the value of the | |
ae9f6311 | 384 | `sendemail.thread` configuration value; if that is unspecified, |
f693b7e9 YD |
385 | default to --thread. |
386 | + | |
387 | It is up to the user to ensure that no In-Reply-To header already | |
388 | exists when 'git send-email' is asked to add it (especially note that | |
389 | 'git format-patch' can be configured to do the threading itself). | |
390 | Failure to do so may not produce the expected result in the | |
391 | recipient's MUA. | |
e46f7a0e | 392 | |
917f3e73 MW |
393 | |
394 | Administering | |
395 | ~~~~~~~~~~~~~ | |
396 | ||
4c0fe0af | 397 | --confirm=<mode>:: |
c1f2aa45 JS |
398 | Confirm just before sending: |
399 | + | |
400 | -- | |
401 | - 'always' will always confirm before sending | |
402 | - 'never' will never confirm before sending | |
403 | - 'cc' will confirm before sending when send-email has automatically | |
404 | added addresses from the patch to the Cc list | |
405 | - 'compose' will confirm before sending the first message when using --compose. | |
406 | - 'auto' is equivalent to 'cc' + 'compose' | |
407 | -- | |
408 | + | |
ae9f6311 | 409 | Default is the value of `sendemail.confirm` configuration value; if that |
c1f2aa45 JS |
410 | is unspecified, default to 'auto' unless any of the suppress options |
411 | have been specified, in which case default to 'compose'. | |
412 | ||
917f3e73 MW |
413 | --dry-run:: |
414 | Do everything except actually send the emails. | |
415 | ||
432b1282 MW |
416 | --[no-]format-patch:: |
417 | When an argument may be understood either as a reference or as a file name, | |
bcf9626a MM |
418 | choose to understand it as a format-patch argument (`--format-patch`) |
419 | or as a file name (`--no-format-patch`). By default, when such a conflict | |
432b1282 MW |
420 | occurs, git send-email will fail. |
421 | ||
917f3e73 MW |
422 | --quiet:: |
423 | Make git-send-email less verbose. One line per email should be | |
424 | all that is output. | |
03044a98 | 425 | |
dbf5e1e9 MW |
426 | --[no-]validate:: |
427 | Perform sanity checks on patches. | |
7ecbad91 MW |
428 | Currently, validation means the following: |
429 | + | |
430 | -- | |
6489660b | 431 | * Invoke the sendemail-validate hook if present (see linkgit:githooks[5]). |
f2d06fb1 | 432 | * Warn of patches that contain lines longer than |
433 | 998 characters unless a suitable transfer encoding | |
434 | ('auto', 'base64', or 'quoted-printable') is used; | |
435 | this is due to SMTP limits as described by | |
fa29f36d | 436 | http://www.ietf.org/rfc/rfc5322.txt. |
7ecbad91 | 437 | -- |
dbf5e1e9 | 438 | + |
ae9f6311 | 439 | Default is the value of `sendemail.validate`; if this is not set, |
bcf9626a | 440 | default to `--validate`. |
7ecbad91 | 441 | |
1a3e302a AS |
442 | --force:: |
443 | Send emails even if safety checks would prevent it. | |
444 | ||
a6d62cdd | 445 | |
17b7a832 JK |
446 | Information |
447 | ~~~~~~~~~~~ | |
448 | ||
449 | --dump-aliases:: | |
450 | Instead of the normal operation, dump the shorthand alias names from | |
451 | the configured alias file(s), one per line in alphabetical order. Note, | |
452 | this only includes the alias name and not its expanded email addresses. | |
453 | See 'sendemail.aliasesfile' for more information about aliases. | |
454 | ||
455 | ||
fc095242 AK |
456 | CONFIGURATION |
457 | ------------- | |
917f3e73 | 458 | |
da0005b8 | 459 | sendemail.aliasesFile:: |
fc095242 | 460 | To avoid typing long email addresses, point this to one or more |
ae9f6311 | 461 | email aliases files. You must also supply `sendemail.aliasFileType`. |
fc095242 | 462 | |
da0005b8 NTND |
463 | sendemail.aliasFileType:: |
464 | Format of the file(s) specified in sendemail.aliasesFile. Must be | |
3169e06d AH |
465 | one of 'mutt', 'mailrc', 'pine', 'elm', or 'gnus', or 'sendmail'. |
466 | + | |
467 | What an alias file in each format looks like can be found in | |
468 | the documentation of the email program of the same name. The | |
469 | differences and limitations from the standard formats are | |
470 | described below: | |
471 | + | |
472 | -- | |
473 | sendmail;; | |
474 | * Quoted aliases and quoted addresses are not supported: lines that | |
475 | contain a `"` symbol are ignored. | |
5c3494ed ES |
476 | * Redirection to a file (`/path/name`) or pipe (`|command`) is not |
477 | supported. | |
478 | * File inclusion (`:include: /path/name`) is not supported. | |
3169e06d AH |
479 | * Warnings are printed on the standard error output for any |
480 | explicitly unsupported constructs, and any other lines that are not | |
481 | recognized by the parser. | |
482 | -- | |
fc095242 | 483 | |
da0005b8 | 484 | sendemail.multiEdit:: |
8fd5bb7f | 485 | If true (default), a single editor instance will be spawned to edit |
bcf9626a MM |
486 | files you have to edit (patches when `--annotate` is used, and the |
487 | summary when `--compose` is used). If false, files will be edited one | |
8fd5bb7f PH |
488 | after the other, spawning a new editor each time. |
489 | ||
c1f2aa45 JS |
490 | sendemail.confirm:: |
491 | Sets the default for whether to confirm before sending. Must be | |
bcf9626a | 492 | one of 'always', 'never', 'cc', 'compose', or 'auto'. See `--confirm` |
c1f2aa45 JS |
493 | in the previous section for the meaning of these values. |
494 | ||
76a8788c NTND |
495 | EXAMPLES |
496 | -------- | |
2b873e06 | 497 | Use gmail as the smtp server |
36c10e6d JN |
498 | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |
499 | To use 'git send-email' to send your patches through the GMail SMTP server, | |
500 | edit ~/.gitconfig to specify your account settings: | |
2b873e06 | 501 | |
1925fe0c MÅ |
502 | ---- |
503 | [sendemail] | |
504 | smtpEncryption = tls | |
505 | smtpServer = smtp.gmail.com | |
506 | smtpUser = yourname@gmail.com | |
507 | smtpServerPort = 587 | |
508 | ---- | |
2b873e06 | 509 | |
155067ab | 510 | If you have multi-factor authentication set up on your Gmail account, you will |
66409881 | 511 | need to generate an app-specific password for use with 'git send-email'. Visit |
4855f06f | 512 | https://security.google.com/settings/security/apppasswords to create it. |
66409881 | 513 | |
155067ab VV |
514 | If you do not have multi-factor authentication set up on your Gmail account, |
515 | you will need to allow less secure app access. Visit | |
516 | https://myaccount.google.com/lesssecureapps to enable it. | |
517 | ||
36c10e6d JN |
518 | Once your commits are ready to be sent to the mailing list, run the |
519 | following commands: | |
520 | ||
521 | $ git format-patch --cover-letter -M origin/master -o outgoing/ | |
522 | $ edit outgoing/0000-* | |
523 | $ git send-email outgoing/* | |
524 | ||
4855f06f MN |
525 | The first time you run it, you will be prompted for your credentials. Enter the |
526 | app-specific or your regular password as appropriate. If you have credential | |
527 | helper configured (see linkgit:git-credential[1]), the password will be saved in | |
528 | the credential store so you won't have to type it the next time. | |
529 | ||
9df8f734 CM |
530 | Note: the following core Perl modules that may be installed with your |
531 | distribution of Perl are required: | |
532 | MIME::Base64, MIME::QuotedPrint, Net::Domain and Net::SMTP. | |
533 | These additional Perl modules are also required: | |
534 | Authen::SASL and Mail::Address. | |
535 | ||
2b873e06 | 536 | |
36c10e6d JN |
537 | SEE ALSO |
538 | -------- | |
539 | linkgit:git-format-patch[1], linkgit:git-imap-send[1], mbox(5) | |
540 | ||
479cec96 RA |
541 | GIT |
542 | --- | |
9e1f0a85 | 543 | Part of the linkgit:git[1] suite |