Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 1 | .. _email_clients: |
| 2 | |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 3 | Email clients info for Linux |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 4 | ============================ |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 5 | |
Dan Carpenter | 7d19e91 | 2014-06-27 18:28:46 -0700 | [diff] [blame] | 6 | Git |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 7 | --- |
Dan Carpenter | 7d19e91 | 2014-06-27 18:28:46 -0700 | [diff] [blame] | 8 | |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 9 | These days most developers use ``git send-email`` instead of regular |
| 10 | email clients. The man page for this is quite good. On the receiving |
| 11 | end, maintainers use ``git am`` to apply the patches. |
| 12 | |
| 13 | If you are new to ``git`` then send your first patch to yourself. Save it |
| 14 | as raw text including all the headers. Run ``git am raw_email.txt`` and |
| 15 | then review the changelog with ``git log``. When that works then send |
Dan Carpenter | 7d19e91 | 2014-06-27 18:28:46 -0700 | [diff] [blame] | 16 | the patch to the appropriate mailing list(s). |
| 17 | |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 18 | General Preferences |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 19 | ------------------- |
| 20 | |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 21 | Patches for the Linux kernel are submitted via email, preferably as |
| 22 | inline text in the body of the email. Some maintainers accept |
| 23 | attachments, but then the attachments should have content-type |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 24 | ``text/plain``. However, attachments are generally frowned upon because |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 25 | it makes quoting portions of the patch more difficult in the patch |
| 26 | review process. |
| 27 | |
| 28 | Email clients that are used for Linux kernel patches should send the |
| 29 | patch text untouched. For example, they should not modify or delete tabs |
| 30 | or spaces, even at the beginning or end of lines. |
| 31 | |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 32 | Don't send patches with ``format=flowed``. This can cause unexpected |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 33 | and unwanted line breaks. |
| 34 | |
| 35 | Don't let your email client do automatic word wrapping for you. |
| 36 | This can also corrupt your patch. |
| 37 | |
| 38 | Email clients should not modify the character set encoding of the text. |
| 39 | Emailed patches should be in ASCII or UTF-8 encoding only. |
| 40 | If you configure your email client to send emails with UTF-8 encoding, |
| 41 | you avoid some possible charset problems. |
| 42 | |
| 43 | Email clients should generate and maintain References: or In-Reply-To: |
| 44 | headers so that mail threading is not broken. |
| 45 | |
| 46 | Copy-and-paste (or cut-and-paste) usually does not work for patches |
| 47 | because tabs are converted to spaces. Using xclipboard, xclip, and/or |
| 48 | xcutsel may work, but it's best to test this for yourself or just avoid |
| 49 | copy-and-paste. |
| 50 | |
| 51 | Don't use PGP/GPG signatures in mail that contains patches. |
| 52 | This breaks many scripts that read and apply the patches. |
| 53 | (This should be fixable.) |
| 54 | |
| 55 | It's a good idea to send a patch to yourself, save the received message, |
| 56 | and successfully apply it with 'patch' before sending patches to Linux |
| 57 | mailing lists. |
| 58 | |
| 59 | |
| 60 | Some email client (MUA) hints |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 61 | ----------------------------- |
| 62 | |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 63 | Here are some specific MUA configuration hints for editing and sending |
| 64 | patches for the Linux kernel. These are not meant to be complete |
| 65 | software package configuration summaries. |
| 66 | |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 67 | |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 68 | Legend: |
| 69 | |
| 70 | - TUI = text-based user interface |
| 71 | - GUI = graphical user interface |
| 72 | |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 73 | Alpine (TUI) |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 74 | ************ |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 75 | |
| 76 | Config options: |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 77 | |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 78 | In the :menuselection:`Sending Preferences` section: |
| 79 | |
| 80 | - :menuselection:`Do Not Send Flowed Text` must be ``enabled`` |
| 81 | - :menuselection:`Strip Whitespace Before Sending` must be ``disabled`` |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 82 | |
| 83 | When composing the message, the cursor should be placed where the patch |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 84 | should appear, and then pressing :kbd:`CTRL-R` let you specify the patch file |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 85 | to insert into the message. |
| 86 | |
Richard Leitner | 04a3302 | 2014-12-02 17:44:36 +0100 | [diff] [blame] | 87 | Claws Mail (GUI) |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 88 | **************** |
Richard Leitner | 04a3302 | 2014-12-02 17:44:36 +0100 | [diff] [blame] | 89 | |
| 90 | Works. Some people use this successfully for patches. |
| 91 | |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 92 | To insert a patch use :menuselection:`Message-->Insert` File (:kbd:`CTRL-I`) |
| 93 | or an external editor. |
Richard Leitner | 04a3302 | 2014-12-02 17:44:36 +0100 | [diff] [blame] | 94 | |
| 95 | If the inserted patch has to be edited in the Claws composition window |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 96 | "Auto wrapping" in |
| 97 | :menuselection:`Configuration-->Preferences-->Compose-->Wrapping` should be |
Richard Leitner | 04a3302 | 2014-12-02 17:44:36 +0100 | [diff] [blame] | 98 | disabled. |
| 99 | |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 100 | Evolution (GUI) |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 101 | *************** |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 102 | |
| 103 | Some people use this successfully for patches. |
| 104 | |
| 105 | When composing mail select: Preformat |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 106 | from :menuselection:`Format-->Paragraph Style-->Preformatted` (:kbd:`CTRL-7`) |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 107 | or the toolbar |
| 108 | |
| 109 | Then use: |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 110 | :menuselection:`Insert-->Text File...` (:kbd:`ALT-N x`) |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 111 | to insert the patch. |
| 112 | |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 113 | You can also ``diff -Nru old.c new.c | xclip``, select |
| 114 | :menuselection:`Preformat`, then paste with the middle button. |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 115 | |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 116 | Kmail (GUI) |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 117 | *********** |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 118 | |
| 119 | Some people use Kmail successfully for patches. |
| 120 | |
| 121 | The default setting of not composing in HTML is appropriate; do not |
| 122 | enable it. |
| 123 | |
| 124 | When composing an email, under options, uncheck "word wrap". The only |
| 125 | disadvantage is any text you type in the email will not be word-wrapped |
| 126 | so you will have to manually word wrap text before the patch. The easiest |
| 127 | way around this is to compose your email with word wrap enabled, then save |
| 128 | it as a draft. Once you pull it up again from your drafts it is now hard |
| 129 | word-wrapped and you can uncheck "word wrap" without losing the existing |
| 130 | wrapping. |
| 131 | |
| 132 | At the bottom of your email, put the commonly-used patch delimiter before |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 133 | inserting your patch: three hyphens (``---``). |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 134 | |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 135 | Then from the :menuselection:`Message` menu item, select insert file and |
| 136 | choose your patch. |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 137 | As an added bonus you can customise the message creation toolbar menu |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 138 | and put the :menuselection:`insert file` icon there. |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 139 | |
Xishi Qiu | d9a6ed1 | 2013-11-06 13:18:19 -0800 | [diff] [blame] | 140 | Make the composer window wide enough so that no lines wrap. As of |
Lasse Collin | 5d3687d | 2011-01-12 17:00:28 -0800 | [diff] [blame] | 141 | KMail 1.13.5 (KDE 4.5.4), KMail will apply word wrapping when sending |
| 142 | the email if the lines wrap in the composer window. Having word wrapping |
| 143 | disabled in the Options menu isn't enough. Thus, if your patch has very |
| 144 | long lines, you must make the composer window very wide before sending |
| 145 | the email. See: https://bugs.kde.org/show_bug.cgi?id=174034 |
| 146 | |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 147 | You can safely GPG sign attachments, but inlined text is preferred for |
| 148 | patches so do not GPG sign them. Signing patches that have been inserted |
| 149 | as inlined text will make them tricky to extract from their 7-bit encoding. |
| 150 | |
| 151 | If you absolutely must send patches as attachments instead of inlining |
| 152 | them as text, right click on the attachment and select properties, and |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 153 | highlight :menuselection:`Suggest automatic display` to make the attachment |
| 154 | inlined to make it more viewable. |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 155 | |
| 156 | When saving patches that are sent as inlined text, select the email that |
| 157 | contains the patch from the message list pane, right click and select |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 158 | :menuselection:`save as`. You can use the whole email unmodified as a patch |
| 159 | if it was properly composed. There is no option currently to save the email |
| 160 | when you are actually viewing it in its own window -- there has been a request |
| 161 | filed at kmail's bugzilla and hopefully this will be addressed. Emails are |
| 162 | saved as read-write for user only so you will have to chmod them to make them |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 163 | group and world readable if you copy them elsewhere. |
| 164 | |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 165 | Lotus Notes (GUI) |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 166 | ***************** |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 167 | |
| 168 | Run away from it. |
| 169 | |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 170 | Mutt (TUI) |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 171 | ********** |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 172 | |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 173 | Plenty of Linux developers use ``mutt``, so it must work pretty well. |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 174 | |
| 175 | Mutt doesn't come with an editor, so whatever editor you use should be |
| 176 | used in a way that there are no automatic linebreaks. Most editors have |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 177 | an :menuselection:`insert file` option that inserts the contents of a file |
| 178 | unaltered. |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 179 | |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 180 | To use ``vim`` with mutt:: |
| 181 | |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 182 | set editor="vi" |
| 183 | |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 184 | If using xclip, type the command:: |
| 185 | |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 186 | :set paste |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 187 | |
| 188 | before middle button or shift-insert or use:: |
| 189 | |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 190 | :r filename |
| 191 | |
| 192 | if you want to include the patch inline. |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 193 | (a)ttach works fine without ``set paste``. |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 194 | |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 195 | You can also generate patches with ``git format-patch`` and then use Mutt |
| 196 | to send them:: |
| 197 | |
Eddie Kovsky | 803cfe2 | 2015-11-05 23:23:01 -0700 | [diff] [blame] | 198 | $ mutt -H 0001-some-bug-fix.patch |
| 199 | |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 200 | Config options: |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 201 | |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 202 | It should work with default settings. |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 203 | However, it's a good idea to set the ``send_charset`` to:: |
| 204 | |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 205 | set send_charset="us-ascii:utf-8" |
| 206 | |
Eddie Kovsky | 91633a6 | 2015-11-05 23:25:35 -0700 | [diff] [blame] | 207 | Mutt is highly customizable. Here is a minimum configuration to start |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 208 | using Mutt to send patches through Gmail:: |
Eddie Kovsky | 91633a6 | 2015-11-05 23:25:35 -0700 | [diff] [blame] | 209 | |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 210 | # .muttrc |
| 211 | # ================ IMAP ==================== |
| 212 | set imap_user = 'yourusername@gmail.com' |
| 213 | set imap_pass = 'yourpassword' |
| 214 | set spoolfile = imaps://imap.gmail.com/INBOX |
| 215 | set folder = imaps://imap.gmail.com/ |
| 216 | set record="imaps://imap.gmail.com/[Gmail]/Sent Mail" |
| 217 | set postponed="imaps://imap.gmail.com/[Gmail]/Drafts" |
| 218 | set mbox="imaps://imap.gmail.com/[Gmail]/All Mail" |
Eddie Kovsky | 91633a6 | 2015-11-05 23:25:35 -0700 | [diff] [blame] | 219 | |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 220 | # ================ SMTP ==================== |
| 221 | set smtp_url = "smtp://username@smtp.gmail.com:587/" |
| 222 | set smtp_pass = $imap_pass |
| 223 | set ssl_force_tls = yes # Require encrypted connection |
Eddie Kovsky | 91633a6 | 2015-11-05 23:25:35 -0700 | [diff] [blame] | 224 | |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 225 | # ================ Composition ==================== |
| 226 | set editor = `echo \$EDITOR` |
| 227 | set edit_headers = yes # See the headers when editing |
| 228 | set charset = UTF-8 # value of $LANG; also fallback for send_charset |
| 229 | # Sender, email address, and sign-off line must match |
| 230 | unset use_domain # because joe@localhost is just embarrassing |
| 231 | set realname = "YOUR NAME" |
| 232 | set from = "username@gmail.com" |
| 233 | set use_from = yes |
Eddie Kovsky | 91633a6 | 2015-11-05 23:25:35 -0700 | [diff] [blame] | 234 | |
| 235 | The Mutt docs have lots more information: |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 236 | |
Eddie Kovsky | 91633a6 | 2015-11-05 23:25:35 -0700 | [diff] [blame] | 237 | http://dev.mutt.org/trac/wiki/UseCases/Gmail |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 238 | |
Eddie Kovsky | 91633a6 | 2015-11-05 23:25:35 -0700 | [diff] [blame] | 239 | http://dev.mutt.org/doc/manual.html |
| 240 | |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 241 | Pine (TUI) |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 242 | ********** |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 243 | |
| 244 | Pine has had some whitespace truncation issues in the past, but these |
| 245 | should all be fixed now. |
| 246 | |
| 247 | Use alpine (pine's successor) if you can. |
| 248 | |
| 249 | Config options: |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 250 | |
| 251 | - ``quell-flowed-text`` is needed for recent versions |
| 252 | - the ``no-strip-whitespace-before-send`` option is needed |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 253 | |
| 254 | |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 255 | Sylpheed (GUI) |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 256 | ************** |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 257 | |
| 258 | - Works well for inlining text (or using attachments). |
| 259 | - Allows use of an external editor. |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 260 | - Is slow on large folders. |
| 261 | - Won't do TLS SMTP auth over a non-SSL connection. |
| 262 | - Has a helpful ruler bar in the compose window. |
| 263 | - Adding addresses to address book doesn't understand the display name |
| 264 | properly. |
| 265 | |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 266 | Thunderbird (GUI) |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 267 | ***************** |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 268 | |
Rob Landley | e0e34e9 | 2011-01-12 17:00:29 -0800 | [diff] [blame] | 269 | Thunderbird is an Outlook clone that likes to mangle text, but there are ways |
| 270 | to coerce it into behaving. |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 271 | |
Giedrius Statkevičius | d50ca07 | 2015-03-09 03:53:45 +0200 | [diff] [blame] | 272 | - Allow use of an external editor: |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 273 | The easiest thing to do with Thunderbird and patches is to use an |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 274 | "external editor" extension and then just use your favorite ``$EDITOR`` |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 275 | for reading/merging patches into the body text. To do this, download |
| 276 | and install the extension, then add a button for it using |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 277 | :menuselection:`View-->Toolbars-->Customize...` and finally just click on it |
| 278 | when in the :menuselection:`Compose` dialog. |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 279 | |
Giedrius Statkevičius | d50ca07 | 2015-03-09 03:53:45 +0200 | [diff] [blame] | 280 | Please note that "external editor" requires that your editor must not |
Luis de Bethencourt | a02b4fc | 2015-09-29 14:15:33 +0100 | [diff] [blame] | 281 | fork, or in other words, the editor must not return before closing. |
Giedrius Statkevičius | d50ca07 | 2015-03-09 03:53:45 +0200 | [diff] [blame] | 282 | You may have to pass additional flags or change the settings of your |
| 283 | editor. Most notably if you are using gvim then you must pass the -f |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 284 | option to gvim by putting ``/usr/bin/gvim -f`` (if the binary is in |
| 285 | ``/usr/bin``) to the text editor field in :menuselection:`external editor` |
| 286 | settings. If you are using some other editor then please read its manual |
| 287 | to find out how to do this. |
Giedrius Statkevičius | d50ca07 | 2015-03-09 03:53:45 +0200 | [diff] [blame] | 288 | |
Rob Landley | e0e34e9 | 2011-01-12 17:00:29 -0800 | [diff] [blame] | 289 | To beat some sense out of the internal editor, do this: |
| 290 | |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 291 | - Edit your Thunderbird config settings so that it won't use ``format=flowed``. |
| 292 | Go to :menuselection:`edit-->preferences-->advanced-->config editor` to bring up |
| 293 | the thunderbird's registry editor. |
Rob Landley | e0e34e9 | 2011-01-12 17:00:29 -0800 | [diff] [blame] | 294 | |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 295 | - Set ``mailnews.send_plaintext_flowed`` to ``false`` |
Paul Mcquade | 6989b5b | 2011-08-13 12:34:54 -0700 | [diff] [blame] | 296 | |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 297 | - Set ``mailnews.wraplength`` from ``72`` to ``0`` |
Paul Mcquade | 6989b5b | 2011-08-13 12:34:54 -0700 | [diff] [blame] | 298 | |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 299 | - :menuselection:`View-->Message Body As-->Plain Text` |
Rob Landley | e0e34e9 | 2011-01-12 17:00:29 -0800 | [diff] [blame] | 300 | |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 301 | - :menuselection:`View-->Character Encoding-->Unicode (UTF-8)` |
Rob Landley | e0e34e9 | 2011-01-12 17:00:29 -0800 | [diff] [blame] | 302 | |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 303 | TkRat (GUI) |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 304 | *********** |
Randy Dunlap | a6cd6bf | 2007-10-16 23:29:49 -0700 | [diff] [blame] | 305 | |
| 306 | Works. Use "Insert file..." or external editor. |
| 307 | |
Tim Hockin | 1b6bcdb | 2008-11-06 12:53:33 -0800 | [diff] [blame] | 308 | Gmail (Web GUI) |
Mauro Carvalho Chehab | 06ad636 | 2016-09-21 07:49:18 -0300 | [diff] [blame] | 309 | *************** |
Tim Hockin | 1b6bcdb | 2008-11-06 12:53:33 -0800 | [diff] [blame] | 310 | |
Dave Young | 5ce9f07 | 2010-03-10 15:22:02 -0800 | [diff] [blame] | 311 | Does not work for sending patches. |
Tim Hockin | 1b6bcdb | 2008-11-06 12:53:33 -0800 | [diff] [blame] | 312 | |
Dave Young | 5ce9f07 | 2010-03-10 15:22:02 -0800 | [diff] [blame] | 313 | Gmail web client converts tabs to spaces automatically. |
Tim Hockin | 1b6bcdb | 2008-11-06 12:53:33 -0800 | [diff] [blame] | 314 | |
Dave Young | 5ce9f07 | 2010-03-10 15:22:02 -0800 | [diff] [blame] | 315 | At the same time it wraps lines every 78 chars with CRLF style line breaks |
| 316 | although tab2space problem can be solved with external editor. |
Tim Hockin | 1b6bcdb | 2008-11-06 12:53:33 -0800 | [diff] [blame] | 317 | |
Dave Young | 5ce9f07 | 2010-03-10 15:22:02 -0800 | [diff] [blame] | 318 | Another problem is that Gmail will base64-encode any message that has a |
| 319 | non-ASCII character. That includes things like European names. |