Merge pull request #831 from jrblevin/fix-830
[markdown-mode.git] / CHANGES.md
blobd1fb3209e0b705229433682920f3dd5d98ef88f1
1 # Markdown Mode 2.7
3 *Under development*
5 *   New Features:
6     - Variable `markdown-follow-link-functions` extends
7       `markdown-follow-link-at-point` similarly to Org's
8       `org-open-at-point-functions`, allowing other libraries to
9       handle links specially. [GH-780][]
10     - Support media handler for images and drag and drop images [GH-804][]
11     - Add functions to move to the beginning and end of lines
12       (`markdown-beginning-of-line` and `markdown-end-of-line`), and the
13       variable `markdown-special-ctrl-a/e`, like Org mode.
14     - Trailing whitespace characters for line breaks are hidden when using
15       `markdown-hide-markup`
17 *   Bug fixes:
18     - Don't highlight superscript/subscript in math inline/block [GH-802][]
19     - Fix table alignment when a column has a seperator in code block [GH-817][]
20     - Fix the regexp in the download languages script [GH-827][]
22 *   Improvements:
23     - Apply url-unescape against URL in an inline link [GH-805][]
24     - Show mode toggle message only if it is called interactively
26   [gh-780]: https://github.com/jrblevin/markdown-mode/issues/780
27   [gh-802]: https://github.com/jrblevin/markdown-mode/issues/802
28   [gh-804]: https://github.com/jrblevin/markdown-mode/issues/804
29   [gh-805]: https://github.com/jrblevin/markdown-mode/issues/805
30   [gh-817]: https://github.com/jrblevin/markdown-mode/issues/817
31   [gh-827]: https://github.com/jrblevin/markdown-mode/issues/827
33 # Markdown Mode 2.6
35 *   **Breaking changes:**
36     - GNU Emacs 27.1 or later is required.
37     - Don't allow space between label and text in reference link same as CommonMark [GH-774][]
38     - Whitespace is required before the closing sequence of an atx header. [GH-778][]
40 *   New Features:
41     - Introduce `markdown-fontify-whole-heading-line` variable for highlighting
42       whole header line. [GH-705][] [GH-773][]
43     - Backslashes in escape sequences are now treated as markup. [GH-377][]
45 *   Improvements:
46     - `markdown` passes `buffer-file-name` as a parameter to
47       `markdown-command` when `markdown-command-needs-filename` is
48       `t` and `markdown-command` is a function.
49     - Support newer version Eldoc ships with Emacs 28.
50     - Don't spell-check against pandoc references. [GH-572][]
51     - Support tree-sitter-based major modes used by Emacs 29.
52     - Highlight "geo" URI scheme [GH-739][]
53     - `clear-image-cache` to make toggle inline image update.
54     - Highlight autolinks if a scheme is valid and it is not registered in markdown-uri-types
55       [GH-743][]
56     - Improve horizontal rule rendering in `markdown-view-mode` [GH-753][]
57     - Don't load major-mode if it isn't in `auto-mode-alist`[GH-761][]
58     - Improve `markdown-insert-table` prompt message [GH-771][]
59     - Consider `major-mode-remap-alist` to determine major-mode for code blocks [GH-787][]
60     - Set marker after footnote reference [GH-793][]
61     - Improve putting text attribute for indented blocks [GH-794][]
63 *   Bug fixes:
64     - Don't override table faces by link faces [GH-716][]
65     - Fix invalid italic fontification after bold markups[GH-731][]
66     - Fix `markdown-live-preview-mode` fails when `eww-auto-rename-buffer` is non-nil[GH-737][]
67     - Fix to mistake to handle the line as delimiter row[GH-747][]
68     - Fix wrong displaying horizontal rule in `markdown-view-mode` [GH-747][]
69     - HTML-escape title in `markdown-add-xhtml-header-and-footer` [markdown-xwidget-issue-9](https://github.com/cfclrk/markdown-xwidget/issues/9)
70     - Fix wrong inline link parsing that has link title[GH-762][]
71     - Don't treat backslashes as escapes inside literal blocks[GH-766][] [GH-768][]
72     - Fix `markdown-enter-key` doesn't delete empty checkbox list[GH-786][]
74   [gh-377]: https://github.com/jrblevin/markdown-mode/issues/377
75   [gh-572]: https://github.com/jrblevin/markdown-mode/issues/572
76   [gh-705]: https://github.com/jrblevin/markdown-mode/issues/705
77   [gh-716]: https://github.com/jrblevin/markdown-mode/issues/716
78   [gh-731]: https://github.com/jrblevin/markdown-mode/issues/731
79   [gh-737]: https://github.com/jrblevin/markdown-mode/issues/737
80   [gh-739]: https://github.com/jrblevin/markdown-mode/issues/739
81   [gh-743]: https://github.com/jrblevin/markdown-mode/issues/743
82   [gh-747]: https://github.com/jrblevin/markdown-mode/issues/747
83   [gh-753]: https://github.com/jrblevin/markdown-mode/issues/753
84   [gh-761]: https://github.com/jrblevin/markdown-mode/issues/761
85   [gh-762]: https://github.com/jrblevin/markdown-mode/issues/762
86   [gh-766]: https://github.com/jrblevin/markdown-mode/issues/766
87   [gh-768]: https://github.com/jrblevin/markdown-mode/pull/768
88   [gh-771]: https://github.com/jrblevin/markdown-mode/issues/771
89   [gh-773]: https://github.com/jrblevin/markdown-mode/issues/773
90   [gh-774]: https://github.com/jrblevin/markdown-mode/issues/774
91   [gh-778]: https://github.com/jrblevin/markdown-mode/issues/778
92   [gh-786]: https://github.com/jrblevin/markdown-mode/pull/786
93   [gh-787]: https://github.com/jrblevin/markdown-mode/issues/787
94   [gh-793]: https://github.com/jrblevin/markdown-mode/pull/793
95   [gh-794]: https://github.com/jrblevin/markdown-mode/issues/794
97 # Markdown Mode 2.5
99 *   **Breaking changes:**
100     -   `markdown-do` supports following link [GH-666][]
101         This changes behavior of `markdown-do` at table
103 *   New features:
104     -   Introduce `markdown-mouse-follow-link` variable [GH-290][]
105     -   Option to define a `markdown-link-make-text-function` function
106         to automatically define a default link text before prompting the user.
107     -   Option to inhibit the prompt for a tooltip text via
108         `markdown-disable-tooltip-prompt`.
109     -   Introduce `markdown-ordered-list-enumeration` variable [GH-587][]
110     -   Search wiki link under project
111     -   Add `markdown-insert-foldable-block` function [GH-598][]
112     -   Add `markdown-table-align-p` flag [GH-625][]
113         Control table alignment after table operation
114     -   Support highlighting syntax like Obsidian, Quilt. [GH-652][]
116 *   Improvements:
117     -   Correct indirect buffer's indentation in `markdown-edit-code-block` [GH-375][]
118     -   Cleanup test code
119     -   Strip query parameters from local file name at displaying inline images [GH-511][]
120     -   Improve forward/backward sentences which are wrapped markup characters [GH-517][]
121     -   Improve fontification for nested meta data [GH-476][]
122     -   `markdown-cycle` accepts universal-argument like org-cycle [GH-530][]
123     -   Improve mode check for derived modes [GH-532][]
124     -   Improve for file which contains many comments [GH-536][]
125     -   Improve for file which contains many pre blocks [GH-512][]
126     -   Enable flyspell check at yaml metadata[GH-560][]
127     -   Clean up Makefile
128     -   Support to display local image with percent encoding file path
129     -   Add ability to resize inline image display (`markdown-toggle-inline-images`) without Imagemagick installed in the computer (emulating Org Mode)
130     -   Support including braces around the language specification in GFM code blocks
131     -   Improve `markdown-insert-{bold,italic}` when region starts with spaces[GH-613][]
132     -   Disable buffer-read-only if possible when markdown-mode is called [GH-622][]
133     -   Generate the `defface` via a macro rather than a function.
134     -   Memoize `markdown--first-displayable` to avoid performance
135         problems.
136     -   Allow the use of `add-function` on
137         `markdown-table-at-point-p-function`.
138     -   Comment out redundant bindings and use the more standard `RET`
139         name for `C-m`.
140     -   Give `markdown-table-at-point-p-function` a non-nil default.
141         Simplify `markdown-table-at-point-p` accordingly.
142     -   Auto set `sh-shell` when `markdown-edit-code-block` enter indirect buffer with `sh-mode`
143     -   Add value check and avoid raising the exception at `markdown-edit-code-block` [GH-663][]
144     -   Add NonGNU ELPA badge to README and website
145     -   Support plus/negative(also Unicode minus sign) exponent in super script [GH-346][]
147 *   Bug fixes:
148     -   Fix issue with `nil` being returned from `markdown-imenu-create-nested-index` [GH-578][]
149     -   Fix remaining flyspell overlay in code block or comment issue [GH-311][]
150     -   Fix inline URL regular expression which starts/ends with spaces [GH-514][]
151     -   Fix GFM italic fontification for one character [GH-524][]
152     -   Fix `markdown-table-forward-cell` at last column issue [GH-522][]
153     -   Fix GFM bold fontification with underscore issue [GH-525][]
154     -   Fix wrong fontification words between strong markups [GH-534][]
155     -   Fix wrong italic fontification just after code block [GH-548][]
156     -   Fix too indended list face issue [GH-569][]
157     -   Fix creating imenu index issue when there is no level-1 header too[GH-571][]
158     -   Fix highlighting consecutive HTML comments[GH-584][]
159     -   Fix `markdown-follow-thing-at-point` failing on subdir search [GH-590][]
160     -   Fix `markdown-table-backward-cell` so it always goes back a single cell
161     -   Fix `markdown-table-align` to detect delimiters surrounded by spaces
162     -   Fix customization for `markdown-mouse-follow-link` and
163         `markdown-table-align-p`
164     -   Fix accessing locations beyond `point-max` in
165         `markdown-syntax-propertize`
166     -   Set `syntax-propertize-extend-region-functions` buffer-locally
167         instead of globally
168     -   Modify only the buffer-local part of
169         `syntax-propertize-extend-region-functions`.
170     -   Fix list highlighting issue in code block [GH-631][]
171     -   Fix exception when inserting code block at end of buffer [GH-634][]
172     -   Fix table operations when table column contains escaped vertical bars [GH-635][]
173     -   Fix issue that executing `markdown-table-sort-lines` via menu-bar with older Emacs(< 28) [GH-641][]
174     -   Fix wrong markdown table command issue in menu [GH-639][]
175     -   Fix table conversion issue [GH-639][]
176     -   Fix fill paragraph issue with setext heading [GH-638][]
177     -   Fix line break highlighting issue at end of buffer [GH-621][]
178     -   Fix URL highlighting which contains comma or parentheis [GH-649][]
179     -   Fix eldoc function issue with `markdown-toggle-url-hiding` [GH-674][]
180         Thanks to Ta Quang Trung for a patch
181     -   Fix `markdown-enable-math` exception issue [GH-676][]
182     -   Fix `markdown-marginalize-headers` rendering in tty mode [GH-677][]
183     -   Fix table and list fontification [GH-680][]
184     -   Fix invalid code block highlighting [GH-684][]
186   [gh-290]: https://github.com/jrblevin/markdown-mode/issues/290
187   [gh-311]: https://github.com/jrblevin/markdown-mode/issues/311
188   [gh-346]: https://github.com/jrblevin/markdown-mode/issues/346
189   [gh-375]: https://github.com/jrblevin/markdown-mode/issues/375
190   [gh-476]: https://github.com/jrblevin/markdown-mode/issues/476
191   [gh-511]: https://github.com/jrblevin/markdown-mode/issues/511
192   [gh-512]: https://github.com/jrblevin/markdown-mode/issues/512
193   [gh-514]: https://github.com/jrblevin/markdown-mode/issues/514
194   [gh-517]: https://github.com/jrblevin/markdown-mode/issues/517
195   [gh-522]: https://github.com/jrblevin/markdown-mode/issues/522
196   [gh-524]: https://github.com/jrblevin/markdown-mode/issues/524
197   [gh-525]: https://github.com/jrblevin/markdown-mode/issues/525
198   [gh-530]: https://github.com/jrblevin/markdown-mode/issues/530
199   [gh-532]: https://github.com/jrblevin/markdown-mode/issues/532
200   [gh-534]: https://github.com/jrblevin/markdown-mode/issues/534
201   [gh-536]: https://github.com/jrblevin/markdown-mode/issues/536
202   [gh-548]: https://github.com/jrblevin/markdown-mode/issues/548
203   [gh-553]: https://github.com/jrblevin/markdown-mode/issues/553
204   [gh-560]: https://github.com/jrblevin/markdown-mode/issues/560
205   [gh-569]: https://github.com/jrblevin/markdown-mode/issues/569
206   [gh-571]: https://github.com/jrblevin/markdown-mode/issues/571
207   [gh-584]: https://github.com/jrblevin/markdown-mode/issues/584
208   [gh-587]: https://github.com/jrblevin/markdown-mode/issues/587
209   [gh-590]: https://github.com/jrblevin/markdown-mode/pull/590
210   [gh-598]: https://github.com/jrblevin/markdown-mode/pull/598
211   [gh-613]: https://github.com/jrblevin/markdown-mode/issues/613
212   [gh-621]: https://github.com/jrblevin/markdown-mode/issues/621
213   [gh-622]: https://github.com/jrblevin/markdown-mode/issues/622
214   [gh-625]: https://github.com/jrblevin/markdown-mode/issues/625
215   [gh-631]: https://github.com/jrblevin/markdown-mode/issues/631
216   [gh-634]: https://github.com/jrblevin/markdown-mode/issues/634
217   [gh-635]: https://github.com/jrblevin/markdown-mode/issues/635
218   [gh-638]: https://github.com/jrblevin/markdown-mode/issues/638
219   [gh-639]: https://github.com/jrblevin/markdown-mode/issues/639
220   [gh-640]: https://github.com/jrblevin/markdown-mode/issues/640
221   [gh-641]: https://github.com/jrblevin/markdown-mode/issues/641
222   [gh-649]: https://github.com/jrblevin/markdown-mode/issues/649
223   [gh-652]: https://github.com/jrblevin/markdown-mode/issues/652
224   [gh-663]: https://github.com/jrblevin/markdown-mode/issues/663
225   [gh-666]: https://github.com/jrblevin/markdown-mode/issues/666
226   [gh-674]: https://github.com/jrblevin/markdown-mode/pull/674
227   [gh-676]: https://github.com/jrblevin/markdown-mode/pull/676
228   [gh-677]: https://github.com/jrblevin/markdown-mode/pull/677
229   [gh-680]: https://github.com/jrblevin/markdown-mode/pull/680
230   [gh-684]: https://github.com/jrblevin/markdown-mode/issues/684
232 # Markdown Mode 2.4
234 *May 30, 2020*
236 *   **Breaking changes:**
238     -   GNU Emacs 25.1 or later is required. And xemacs support has been dropped
239     -   Face variables, such as `markdown-italic-face` are now
240         obsolete.  Use face names directly in code and customizations.
241         The face names themselves are unaffected, so this shouldn't
242         affect most users.
243     -   Delete obsoleted aliases
244     -   Internal variables `markdown-font-lock-keywords-basic` and
245         `gfm-font-lock-keywords` are now obsolete.
246         `markdown-font-lock-keywords` is now used instead, but users
247         should use `font-lock-add-keywords` instead of modifying this
248         variable.
249     -   `markdown-mode` now adds entries to the beginning of
250         `auto-mode-alist` rather than the end. If you were relying on
251         the previous behavior in order to override these entries, you
252         should fix the problem by following best practice and ensuring
253         that your user configuration is loaded after the autoloads for
254         `markdown-mode` are evaluated. ([GH-331][], [GH-335][])
255     -   Point at the end of fenced code blocks is no-longer considered
256         part of the code block ([GH-#349][]).
257     -   Enable `markdown-fontify-code-blocks-natively` in `gfm-view-mode`. ([GH-#451][])
259 *   New features:
261     -   GFM task list item (checkbox) insertion with `C-c C-s [`, or
262         as a final fallback for `markdown-do` (`C-c C-d`).  Thanks to
263         Akinori Musha for a patch.  ([GH-229][])
264     -   Optionally move leading atx heading markup to the left margin
265         when `markdown-marginalize-headers` is non-`nil`.  Thanks to
266         Alexis Gallagher for a patch.  ([GH-272][], [GH-274][])
267     -   Added pipe table editing features.  Thanks to Dmitry Safronov
268         for a patch.  ([GH-171][], [GH-266][])
269     -   Font lock for HTML tags and attributes, with new faces
270         `markdown-html-tag-name-face`,
271         `markdown-html-tag-delimiter-face`,
272         `markdown-html-attr-name-face`, and
273         `markdown-html-attr-value-face`.  ([GH-249][])
274     -   Font lock for HTML entities, with a new face
275         `markdown-html-entity-face`.
276     -   Scale down large inline images using `markdown-max-image-size`,
277         a cons cell of the form `(max-width . max-height)`.
278     -   Added read-only viewing modes `markdown-view-mode` and
279         `gfm-view-mode` with keymaps similar to `view-mode` and
280         `help-mode`.  ([GH-296][])
281     -   Optionally add footnote definitions to the end of the imenu
282         index using `markdown-add-footnotes-to-imenu`.  ([GH-235][])
283     -   Add custom variables `markdown-xhtml-body-preamble` and
284         `markdown-xhtml-body-epilogue` for wrapping additional XHTML
285         tags around the output.  ([GH-280][], [GH-281][])
286     -   Add `markdown-unused-refs` command to list and clean up unused
287         references (available via `C-c C-c u`).  ([GH-322][])
288     -   Add `markdown-insert-table` (`C-c C-s t`) for interactive
289         table insertion.  ([GH-369][])
290     -   Add `markdown-kill-outline` and `markdown-kill-block`
291         functions.
292     -   Added `markdown-display-remote-images` for viewing remote
293         images.  Thanks to Sean Allread for the patch.  ([GH-378][])
294     -   `markdown-back-to-heading` can be used as command ([GH-415][])
296 *   Improvements:
298     -   Insert references before local variables.  Thanks to Philipp
299         Stephani for a patch.  ([GH-216][], [GH-262][])
300     -   Allow `markdown-command` and `markdown-open-command` to be
301         functions.  ([GH-255][], [GH-263][])
302     -   Save the buffer before running `markdown-open-command` and run
303         `markdown-open-command` asynchronously.  Thanks to Dmitry
304         Safronov for a patch.  ([GH-248][])
305     -   New user option `markdown-translate-filename-function` to translate
306         filenames when following file links.  ([GH-268][], [GH-277][])
307     -   Support double-backslash math delimiters.  ([GH-270][])
308     -   New user option `markdown-export-kill-buffer` to kill or preserve
309         HTML export output buffer.  ([GH-224][])
310     -   Add custom variables `markdown-edit-code-block-default-mode`
311         and `markdown-fontify-code-block-default-mode` to specify default
312         modes for indirect editing and fontification of code blocks.
313         ([GH-251][], [GH-303][])
314     -   Insert-and-indirect-edit GFM code blocks simultaneously by
315         giving a prefix argument to `C-c C-s C`.  ([GH-251][])
316     -   Improve package load time by deferring calls to
317         `char-displayable-p`.  ([GH-264][])
318     -   Only raise footnotes when markup hiding is on.
319         Footnote display properties may now be customized via
320         `markdown-footnote-display`.  ([GH-247][])
321     -   Customizable subscript and superscript display properties
322         via `markdown-sub-superscript-display`.
323     -   Several font-lock performance improvements.
324     -   Support horizontal rules consisting of underscores.
325     -   Change default character encoding to UTF-8.
326         ([GH-340][], [GH-350][])
327     -   Support more markdown extensions same as Vim
328     -   Complete link text from link labels at inserting link. ([GH-421][])
329     -   Improve regular expression for inline attributes. ([GH-406][])
330     -   Allow relative CSS stylesheets paths. ([GH-389][])
331     -   Improve regular expression matching for inline attributes. ([GH-389][])
332     -   If user set `display-buffer-alist` then use `display-buffer`. ([GH-413][])
333     -   Add custom variable for opening image. ([GH-383][])
334     -   Improve default `markdown-command` setting
335     -   Use markdown-command directly instead of 'sh -c' ([GH-319][])
336     -   Use explicitly numbered group as possible for easy reading regexp
337     -   Support list of strings of `markdown-command`
338     -   Apply `markdown-translate-filename-function` for `markdown-display-inline-images`
339         ([GH-422][])
340     -   Implement own `filter-buffer-substring-function` for `markdown-view-mode` and
341         `gfm-view-mode` ([GH-493][])
342     -   Improve triple backtick behavior with `electric-pair-mode`
343     -   Update code block language list
345 *   Bug fixes:
347     -   No longer treat code fragments that are delimited with three
348         backquotes on each side as the beginning of a code block.
349         ([GH-403][])
350     -   Fix infloop caused by incorrect detection of end of code
351         blocks ([GH-349][]).
352     -   Remove GFM checkbox overlays when switching major modes.
353         ([GH-238][], [GH-257][])
354     -   Don't test the value of the `composition` property to avoid
355         failing tests.  ([GH-246][], [GH-258][])
356     -   Fix types for `markdown-open-command`, `markdown-uri-types`,
357         and `markdown-hr-strings` defcustoms.  ([GH-254][], [GH-259][])
358     -   Don't insert trailing whitespace when inserting a blockquote.
359         ([GH-227][], [GH-260][])
360     -   Make wiki link test work even when `/tmp` contains an
361         inaccessible subdirectory.  ([GH-261][])
362     -   Fix `markdown-inline-code-face`'s `:inherit` attribute.
363         ([GH-252][])
364     -   Fix type of customizable `markdown-css-paths` variable.
365         ([GH-276][])
366     -   Don't set `markdown-code-face` background color at package
367         load time.  ([GH-273][])
368     -   Don't clobber user specified font-lock keywords when toggling
369         features.  ([GH-222][])
370     -   Fix font-lock for inline code inside italics and bold.
371         ([GH-275][])
372     -   Make code block language detection handle unspecified
373         or unknown code block languages.  ([GH-284][])
374     -   Fix precedence of inline code over inline links.
375     -   Improve error reporting for `markdown` and `markdown-open`.
376         ([GH-291][])
377     -   Fix M-RET binding for terminals. ([GH-317][])
378     -   Do not fail displaying inline images on empty links. ([GH-320][])
379     -   Fix off-by-one error in `markdown-inline-code-at-pos`.
380         ([GH-313][])
381     -   Fix bounds during inline comment syntax propertization. ([GH-327][])
382     -   Fix wrong metadata highlighting. ([GH-437][])
383     -   Fix wrong italic highlighting in HTML attributes. ([GH-410][])
384     -   Fix markdown-follow-thing-at-point issue for continuous links. ([GH-305][])
385     -   Fix wrong setting major-mode issue at following wiki link([GH-427][])
386     -   Fix not consider `markdown-list-indent-width` issue([GH-405][])
387     -   Fix URL open issue which contains end parentheses ([GH-408][])
388     -   Follow link even if it is in header([GH-430][])
389     -   Fix clean up list number issue([GH-392][])
390     -   Fix insert markup functions in consecutive case([GH-283][])
391     -   Fix hide markup issue in markdown/gfm-view-mode([GH-468][])
392     -   Fix bold regexp issue([GH-325][])
393     -   Fix italic and punctual character issue([GH-359][])
394     -   Fix table align issue when column contains escaped bar([GH-308][])
395     -   Fix nested block fill-paragraph issue([GH-366][])
396     -   Fix table transpose issue with wiki link
397     -   Fix indent-region for pre block([GH-228][])
398     -   Fix link highlight issue which contains escaped right bracket([GH-409][])
399     -   Fix math inline single/double highlight issue([GH-352][])
400     -   Fix markdown-table-forward-cell escaped vertical bar issue([GH-489][])
401     -   Fix markdown-table-backward-cell escaped vertical bar issue
402     -   Fix GFM italic markup issue([GH-448][])
404   [gh-171]: https://github.com/jrblevin/markdown-mode/issues/171
405   [gh-216]: https://github.com/jrblevin/markdown-mode/issues/216
406   [gh-222]: https://github.com/jrblevin/markdown-mode/issues/222
407   [gh-224]: https://github.com/jrblevin/markdown-mode/issues/224
408   [gh-227]: https://github.com/jrblevin/markdown-mode/issues/227
409   [gh-228]: https://github.com/jrblevin/markdown-mode/issues/228
410   [gh-229]: https://github.com/jrblevin/markdown-mode/pull/229
411   [gh-235]: https://github.com/jrblevin/markdown-mode/issues/235
412   [gh-238]: https://github.com/jrblevin/markdown-mode/issues/238
413   [gh-246]: https://github.com/jrblevin/markdown-mode/issues/246
414   [gh-247]: https://github.com/jrblevin/markdown-mode/issues/247
415   [gh-248]: https://github.com/jrblevin/markdown-mode/issues/248
416   [gh-249]: https://github.com/jrblevin/markdown-mode/issues/249
417   [gh-251]: https://github.com/jrblevin/markdown-mode/issues/251
418   [gh-252]: https://github.com/jrblevin/markdown-mode/pull/252
419   [gh-254]: https://github.com/jrblevin/markdown-mode/issues/254
420   [gh-255]: https://github.com/jrblevin/markdown-mode/issues/255
421   [gh-257]: https://github.com/jrblevin/markdown-mode/pull/257
422   [gh-258]: https://github.com/jrblevin/markdown-mode/pull/258
423   [gh-259]: https://github.com/jrblevin/markdown-mode/pull/259
424   [gh-260]: https://github.com/jrblevin/markdown-mode/pull/260
425   [gh-261]: https://github.com/jrblevin/markdown-mode/pull/261
426   [gh-262]: https://github.com/jrblevin/markdown-mode/pull/262
427   [gh-263]: https://github.com/jrblevin/markdown-mode/pull/263
428   [gh-264]: https://github.com/jrblevin/markdown-mode/pull/264
429   [gh-266]: https://github.com/jrblevin/markdown-mode/issues/266
430   [gh-268]: https://github.com/jrblevin/markdown-mode/issues/268
431   [gh-270]: https://github.com/jrblevin/markdown-mode/issues/270
432   [gh-272]: https://github.com/jrblevin/markdown-mode/issues/272
433   [gh-273]: https://github.com/jrblevin/markdown-mode/issues/273
434   [gh-274]: https://github.com/jrblevin/markdown-mode/pull/274
435   [gh-275]: https://github.com/jrblevin/markdown-mode/issues/275
436   [gh-276]: https://github.com/jrblevin/markdown-mode/issues/276
437   [gh-277]: https://github.com/jrblevin/markdown-mode/pull/277
438   [gh-280]: https://github.com/jrblevin/markdown-mode/issues/280
439   [gh-281]: https://github.com/jrblevin/markdown-mode/pull/281
440   [gh-283]: https://github.com/jrblevin/markdown-mode/issues/283
441   [gh-284]: https://github.com/jrblevin/markdown-mode/issues/284
442   [gh-291]: https://github.com/jrblevin/markdown-mode/issues/291
443   [gh-296]: https://github.com/jrblevin/markdown-mode/issues/296
444   [gh-303]: https://github.com/jrblevin/markdown-mode/pull/303
445   [gh-305]: https://github.com/jrblevin/markdown-mode/issues/305
446   [gh-308]: https://github.com/jrblevin/markdown-mode/issues/308
447   [gh-313]: https://github.com/jrblevin/markdown-mode/issues/313
448   [gh-317]: https://github.com/jrblevin/markdown-mode/pull/317
449   [gh-319]: https://github.com/jrblevin/markdown-mode/issues/319
450   [gh-320]: https://github.com/jrblevin/markdown-mode/pull/320
451   [gh-322]: https://github.com/jrblevin/markdown-mode/pull/322
452   [gh-325]: https://github.com/jrblevin/markdown-mode/issues/325
453   [gh-327]: https://github.com/jrblevin/markdown-mode/issues/327
454   [gh-331]: https://github.com/jrblevin/markdown-mode/issues/331
455   [gh-335]: https://github.com/jrblevin/markdown-mode/pull/335
456   [gh-340]: https://github.com/jrblevin/markdown-mode/issues/340
457   [gh-349]: https://github.com/jrblevin/markdown-mode/issues/349
458   [gh-350]: https://github.com/jrblevin/markdown-mode/pull/350
459   [gh-352]: https://github.com/jrblevin/markdown-mode/issues/352
460   [gh-359]: https://github.com/jrblevin/markdown-mode/issues/359
461   [gh-366]: https://github.com/jrblevin/markdown-mode/issues/366
462   [gh-369]: https://github.com/jrblevin/markdown-mode/pull/369
463   [gh-378]: https://github.com/jrblevin/markdown-mode/pull/378
464   [gh-383]: https://github.com/jrblevin/markdown-mode/issues/383
465   [gh-389]: https://github.com/jrblevin/markdown-mode/pull/389
466   [gh-392]: https://github.com/jrblevin/markdown-mode/pull/392
467   [gh-403]: https://github.com/jrblevin/markdown-mode/issues/403
468   [gh-405]: https://github.com/jrblevin/markdown-mode/issues/405
469   [gh-406]: https://github.com/jrblevin/markdown-mode/issues/406
470   [gh-408]: https://github.com/jrblevin/markdown-mode/issues/408
471   [gh-409]: https://github.com/jrblevin/markdown-mode/issues/409
472   [gh-410]: https://github.com/jrblevin/markdown-mode/issues/410
473   [gh-413]: https://github.com/jrblevin/markdown-mode/issues/413
474   [gh-415]: https://github.com/jrblevin/markdown-mode/issues/415
475   [gh-421]: https://github.com/jrblevin/markdown-mode/issues/421
476   [gh-422]: https://github.com/jrblevin/markdown-mode/issues/422
477   [gh-427]: https://github.com/jrblevin/markdown-mode/issues/427
478   [gh-428]: https://github.com/jrblevin/markdown-mode/issues/428
479   [gh-430]: https://github.com/jrblevin/markdown-mode/issues/430
480   [gh-437]: https://github.com/jrblevin/markdown-mode/issues/437
481   [gh-448]: https://github.com/jrblevin/markdown-mode/issues/448
482   [gh-451]: https://github.com/jrblevin/markdown-mode/issues/451
483   [gh-468]: https://github.com/jrblevin/markdown-mode/issues/468
484   [gh-489]: https://github.com/jrblevin/markdown-mode/issues/489
485   [gh-493]: https://github.com/jrblevin/markdown-mode/pull/493
487 # Markdown Mode 2.3
489 *August 31, 2017*
491 *   **Breaking changes:**
493     -   `markdown-mode` now requires Emacs 24.3 or later.
494     -   Markup insertion and replacement keybindings under <kbd>C-c
495         C-s</kbd> (_s_ for style) have been revised to make them
496         easier to remember.  Now, when the prefix <kbd>C-c C-s</kbd>
497         is pressed, a short minibuffer help prompt is presented as a
498         reminder of a few of the most frequently used keys.  The major
499         changes are that bold is now inserted with <kbd>b</kbd>
500         (previously <kbd>s</kbd>) and italic is now <kbd>i</kbd>
501         (previously <kbd>e</kbd>).  As a result, blockquote is now
502         <kbd>q</kbd> (previously <kbd>b</kbd>) and strikethrough
503         markup is inserted with <kbd>s</kbd> (previously
504         <kbd>d</kbd>).  Press <kbd>C-c C-s C-h</kbd> for a complete
505         list of markup insertion keybindings.  Heading insertion
506         commands are also now under <kbd>C-c C-s</kbd>.
507     -   Link insertion and editing has been consolidated into one
508         command, `markdown-insert-link`, bound to <kbd>C-c C-l</kbd>.
509         As such, the previous separate link insertion keybindings have
510         been removed: <kbd>C-c C-a l</kbd>, <kbd>C-c C-a L</kbd>,
511         <kbd>C-c C-a r</kbd>, and <kbd>C-c C-a u</kbd>.
512     -   Image insertion and editing has been consolidated into one
513         command, `markdown-insert-image`, bound to <kbd>C-c C-i</kbd>.
514         As such, the previous separate image insertion keybindings have
515         been removed: <kbd>C-c C-i i</kbd> and <kbd>C-c C-i I</kbd>.
516     -   Footnote and wiki link insertion have been moved to the
517         markup insertion prefix, as <kbd>C-c C-s f</kbd> and
518         <kbd>C-c C-s w</kbd>.
519     -   The list and outline editing commands have been removed from
520         the top-level positions (previously <kbd>M-LEFT</kbd>,
521         <kbd>M-RIGHT</kbd>, <kbd>M-UP</kbd>, <kbd>M-DOWN</kbd>)
522         and moved to major mode keybindings under <kbd>C-c</kbd> to
523         <kbd>C-c LEFT</kbd>, <kbd>C-c RIGHT</kbd>,
524         <kbd>C-c UP</kbd>, and <kbd>C-c DOWN</kbd>, respectively.
525         ([GH-164][])
526     -   The list and outline editing commands have also been unified
527         so that they all operate on entire subtrees of list items and
528         subtrees of atx headings, symmetrically.  Previously there were
529         separate commands for editing heading subtrees, but promoting
530         a single section is easy enough by directly inserting or
531         removing a hash mark or using the markup replacement commands.
532     -   Jumping between references and reference definitions via
533         `markdown-jump`, previously bound to <kbd>C-c C-l</kbd>, has
534         been moved to <kbd>C-c C-d</kbd> and rebranded as
535         `markdown-do`, which attempts to do something sensible with
536         the object at the point.
537     -   Rename internal `markdown-link-link` to `markdown-link-url`
538         for clarity.
539     -   The old inline image toggling command <kbd>C-c C-i C-t</kbd>
540         has been removed and replaced <kbd>C-c C-x C-i</kbd> in order
541         to allow for the new interactive image insertion command at
542         <kbd>C-c C-i</kbd>.  Toggling keybindings are currently being
543         grouped under <kbd>C-c C-x</kbd>.
544     -   `markdown-blockquote-face` is now applied to the entire
545         blockquote, including the leading `>`, so it can be used to
546         apply a background if desired.
547     -   In `markdown-regex-header`, groups 4 and 6 now include
548         whitespace surrounding hash marks in atx headings.
549     -   Font lock for `~~strikethrough~~` is now supported in
550         `markdown-mode` in addition to `gfm-mode`.
551     -   Introduced a new face for horizontal rules: `markdown-hr-face`.
552         Previously, `markdown-header-delimiter-face` was used.
553     -   Markdown Mode is now distributed under the GNU GPL version 3
554         or later.
555     -   Rename `markdown-fill-forward-paragraph-function` to
556         `markdown-fill-forward-paragraph`.
557     -   Rename `markdown-footnote-face` to `markdown-footnote-marker-face`.
558     -   Functions `markdown-insert-inline-link-dwim` and
559         `markdown-insert-reference-link-dwim` have been combined and
560         replaced with `markdown-insert-link`.
561     -   Functions `markdown-exdent-region` and `markdown-exdent-or-delete`
562         are now named `markdown-outdent-region` and
563         `markdown-outdent-or-delete`, respectively.
564     -   The non-interactive image insertion commands have been
565         refactored to mirror the corresponding link insertion
566         commands.  `markdown-insert-image` (for inline images) has
567         been renamed `markdown-insert-inline-image` and it now takes
568         three arguments (previously one optional argument).
569         `markdown-insert-reference-image` now takes four arguments
570         (previously none).
572 *   New features:
574     -   Markup hiding: Add a custom variable `markdown-hide-markup`,
575         which determines whether to hide or otherwise beautify
576         Markdown markup.  For example, for inline links the brackets,
577         URL, and title will be hidden and only the (clickable) link
578         text will remain.  The URL can be seen by hovering with the
579         mouse pointer and edited by deleting one of the invisible
580         brackets or parentheses.  This can be toggled interactively
581         using <kbd>C-c C-x C-m</kbd> (`markdown-toggle-markup-hiding`).
582         This setting supersedes URL hiding (below).  ([GH-130][])
583     -   Unicode bullets are used to replace ASCII list item markers
584         for unordered lists when markup hiding is enabled.  The list
585         of characters used, in order of list level, can be specified
586         by setting the variable `markdown-list-item-bullets`.
587         ([GH-130][])
588     -   When markup hiding is enabled, the characters used for
589         replacing certain markup can be changed by customizing the
590         corresponding variables:
591         `markdown-blockquote-display-char`,
592         `markdown-hr-display-char`, and
593         `markdown-definition-display-char`.
594     -   URL and reference label hiding: URLs for inline links and
595         labels for reference links can now be hidden if desired.  This is
596         configurable via `markdown-hide-urls`.  URLs will appear as
597         `[link](∞)` instead of
598         `[link](http://perhaps.a/very/long/url/)`.  To change the
599         placeholder character used, set `markdown-url-compose-char`.
600         This feature can be toggled using <kbd>C-c C-x C-l</kbd>
601         (`markdown-toggle-url-hiding`).  If full markup hiding (above)
602         is enabled, then URL hiding has no additional effect.
603     -   Native code block font-lock: Add a custom variable
604         `markdown-fontify-code-blocks-natively`, which determines
605         whether to fontify code in code blocks using the native major
606         mode.  This only works for fenced code blocks where the
607         language is specified where we can automatically determine the
608         appropriate mode to use.  The language to mode mapping may be
609         customized by setting the variable `markdown-code-lang-modes`.
610         ([GH-123][], [GH-185][])
611     -   When the [`edit-indirect`](https://github.com/Fanael/edit-indirect/)
612         package is installed, <kbd>C-c '</kbd> (`markdown-edit-code-block`)
613         can be used to edit a code block in an indirect buffer in the native
614         major mode.  Press <kbd>C-c C-c</kbd> to commit changes and return
615         or <kbd>C-c C-k</kbd> to cancel.
616     -   Add command <kbd>C-c C-x C-f</kbd> for toggling native font lock
617         for code blocks (`markdown-toggle-fontify-code-blocks-natively`).
618     -   Add "page" movement, marking, and narrowing commands, where a
619         "page" in Markdown is defined to be a top-level subtree:
620         `markdown-forward-page` (<kbd>C-x ]</kbd>),
621         `markdown-backward-page` (<kbd>C-x [</kbd>),
622         `markdown-mark-page` (<kbd>C-x C-p</kbd>), and
623         `markdown-narrow-to-page` (<kbd>C-x n p</kbd>).  ([GH-191][])
624     -   Add subtree marking and narrowing functions:
625         `markdown-mark-subtree` (<kbd>C-c C-M-h</kbd>) and
626         `markdown-narrow-to-subtree` (<kbd>C-x n s</kbd>).
627         ([GH-191][])
628     -   Add syntax-aware Markdown paragraph movement commands:
629         <kbd>M-{</kbd> (`markdown-backward-paragraph`) and
630         <kbd>M-}</kbd> (`markdown-forward-paragraph`).  To mark a
631         paragraph, use <kbd>M-h</kbd> (`markdown-mark-paragraph`).
632         These move at a more granular level than the block movement
633         commands.  ([GH-191][])
634     -   The previous block movement and marking commands are now at
635         <kbd>C-M-{</kbd>, <kbd>C-M-}</kbd>, and <kbd>C-c M-h</kbd>.
636         In terms of lists, paragraph movement commands now stop at
637         each list item while block commands move over entire lists.
638         ([GH-191][])
639     -   Add `subtree` as a possible value for
640         `markdown-reference-location` and
641         `markdown-footnote-location`.
642     -   Ask flyspell to ignore words in URLs, code fragments,
643         comments, and reference labels.
644     -   Make inline links, reference links, angle bracket URLs, and
645         plain URLs clickable.
646     -   Add an additional keybinding for toggling inline image
647         display, <kbd>C-c C-x C-i</kbd>.
648     -   Add a keybinding for toggling LaTeX math (_e_quation) support:
649         <kbd>C-c C-x C-e</kbd>.
650     -   Support Leanpub blocks (asides, info blocks, warnings, etc.).
651         These are simple extensions of the usual blockquote syntax.
652     -   Font lock, with markup hiding, for subscripts (e.g., `H~2~0`)
653         and superscripts (e.g., `334^10^`).  Thanks to Syohei Yoshida
654         for a patch on which this is based.  ([GH-134][])
655     -   Add basic font-lock support for inline attribute lists or
656         inline identifiers used by Pandoc, Python Markdown, PHP
657         Markdown Extra, Leanpub, etc.
658     -   Add basic font-lock support for Leanpub section identifiers and
659         page breaks.
660     -   Add basic font-lock support for common file inclusion syntax:
661         `<<(file)`, `<<[title](file)`, `<<[file]`, and `<<{file}`.
662     -   Add font lock support for Pandoc inline footnotes. ([GH-81][])
663     -   Raise footnote markers and inline footnote text, and
664         optionally hide markup.
665     -   Filling with now respects Pandoc line blocks.  ([GH-144][])
666     -   Add interactive link editing and insertion command
667         `markdown-insert-link`.  ([GH-199][])
668     -   Added <kbd>C-c C-d</kbd>, `markdown-do`, which is a
669         replacement for <kbd>C-c C-l</kbd>, `markdown-jump`.  In
670         addition to jumping between reference/footnote labels and
671         definitions, it also toggles GFM checkboxes.
672     -   Outline movement keys <kbd>C-c C-p</kbd>, <kbd>C-c C-n</kbd>,
673         <kbd>C-c C-f</kbd>, <kbd>C-c C-b</kbd>, and <kbd>C-c C-u</kbd>
674         now move between list items, when the point is in a list,
675         and move between headings otherwise.
676     -   New customization option `markdown-spaces-after-code-fence` to
677         control the number of spaces inserted after a code fence (` ``` `).
678         Thanks to Philipp Stephani for a patch.  ([GH-232][])
679     -   New customization option `markdown-gfm-uppercase-checkbox` which,
680         when non-nil, uses `[X]` to complete task list items instead of
681         `[x]`.  Thanks to Paul Rankin for a patch.  ([GH-236][])
682     -   Add prefix-specific prompts for styles (`C-c C-s`) and toggles
683         (`C-c C-x`).  These may be disabled if desired by setting
684         `markdown-enable-prefix-prompts` to `nil`.
686 *   Improvements:
688     -   Document customizable variables added in version 2.2 with
689         `:package-version` tags.
690     -   Better consistency of function names: predicate functions
691         ending in `-p` shouldn't modify match data.
692     -   Generalize rebinding of paragraph movement commands in case users
693         have customized `{forward,backward,mark}-paragraph` bindings.
694     -   Adjust point so that it is left at beginning of setext
695         headings in heading navigation commands.
696     -   Prevent inline link matching in code blocks.
697     -   When inserting a new reference definition, don't add blank
698         line after existing reference definitions.
699     -   `markdown-toggle-inline-images` now displays the status in the
700         minibuffer.
701     -   Increased default heading scaling range slightly, to make
702         level differences more pronounced when markup is hidden.
703     -   Reuse existing windows, when possible, rather than splitting
704         again in preferred direction. ([GH-129][])
705     -   Update known languages in `markdown-gfm-recognized-languages`.
706     -   Filling with `fill-region` now leaves code blocks unmodified.
707         ([GH-192][])
708     -   Avoid error when live-previewing a buffer that's not visiting
709         a file.  Thanks to Tianxiang Xiong for a patch.
710         ([GH-200][], [GH-201][])
711     -   Adaptive filling for Leanpub blocks.
712     -   Set variable `comment-use-syntax`.  ([GH-213][])
713     -   Support `electric-quote-inhibit-functions` for inhibiting
714         electric quoting in code spans and blocks.  Thanks to Philipp
715         Stephani for patches to both Emacs and Markdown Mode.
716         ([GH-220][])
717     -   Stop inhibiting line breaks inside links when filling.
718         ([GH-173][])
720 *   Bug fixes:
722     -   Fix spurious bold/italic faces in inline code. ([GH-172][])
723     -   Fix defun movement at end of buffer. ([GH-197][])
724     -   Fix bug with adjacent bold font-locking in a list
725         item. ([GH-176][])
726     -   Prevent matching italics, bold, and inline code in comments.
727     -   Prevent matching italics and bold in URLs.
728     -   Prevent matching links in inline code or comment spans.
729     -   Avoid infinite loop when promoting or demoting last section in
730         a buffer.
731     -   Fix font lock for subsequent inline links after a malformed
732         inline link.  ([GH-209][])
733     -   Prevent clobbering match data in
734         `markdown-font-lock-extend-region-function`.  Thanks to
735         Philipp Stephani for a patch.  ([GH-221][])
736     -   Fix incorrect indentation of inserted GFM code blocks in lists.
737         Thanks to Philipp Stephani for a patch. ([GH-215][])
738     -   Fix an issue with font lock for headings with code blocks immediately
739         afterwards, without whitespace. ([GH-234][])
741   [gh-81]:  https://github.com/jrblevin/markdown-mode/issues/81
742   [gh-123]: https://github.com/jrblevin/markdown-mode/issues/123
743   [gh-130]: https://github.com/jrblevin/markdown-mode/issues/130
744   [gh-134]: https://github.com/jrblevin/markdown-mode/issues/134
745   [gh-144]: https://github.com/jrblevin/markdown-mode/issues/144
746   [gh-164]: https://github.com/jrblevin/markdown-mode/issues/164
747   [gh-172]: https://github.com/jrblevin/markdown-mode/issues/172
748   [gh-173]: https://github.com/jrblevin/markdown-mode/issues/173
749   [gh-176]: https://github.com/jrblevin/markdown-mode/issues/176
750   [gh-185]: https://github.com/jrblevin/markdown-mode/issues/185
751   [gh-191]: https://github.com/jrblevin/markdown-mode/issues/191
752   [gh-192]: https://github.com/jrblevin/markdown-mode/issues/192
753   [gh-197]: https://github.com/jrblevin/markdown-mode/issues/197
754   [gh-199]: https://github.com/jrblevin/markdown-mode/issues/199
755   [gh-200]: https://github.com/jrblevin/markdown-mode/issues/200
756   [gh-201]: https://github.com/jrblevin/markdown-mode/issues/201
757   [gh-209]: https://github.com/jrblevin/markdown-mode/issues/209
758   [gh-213]: https://github.com/jrblevin/markdown-mode/issues/213
759   [gh-215]: https://github.com/jrblevin/markdown-mode/issues/215
760   [gh-220]: https://github.com/jrblevin/markdown-mode/pull/220
761   [gh-221]: https://github.com/jrblevin/markdown-mode/pull/221
762   [gh-232]: https://github.com/jrblevin/markdown-mode/pull/232
763   [gh-234]: https://github.com/jrblevin/markdown-mode/issues/234
764   [gh-236]: https://github.com/jrblevin/markdown-mode/pull/236
766 # Markdown Mode 2.2
768 *May 26, 2017*
770 Version 2.2 is a major new stable release and all users are encouraged
771 to upgrade.  Thanks to everyone who submitted bug reports, feature
772 suggestions, and especially patches.
774 *   **Breaking changes:**
776     -   Now use <kbd>C-c C-j</kbd> for inserting list items, like
777         AUCTeX and similar to other programming modes.  Since <kbd>C-c
778         C-j</kbd> was used for `markdown-jump` (for moving between
779         reference link/footnote markers and their definitions), it has
780         been changed to <kbd>C-c C-l</kbd> (think "leap" or "loop"
781         instead of jump).  It's also close to <kbd>C-c C-o</kbd> (used
782         for opening links).  ([GH-26][])
783     -   Insertion of `kbd` tags with <kbd>C-c C-s k</kbd> or
784         `markdown-insert-kbd`.
785     -   Add YAML metadata parsing.  Also allow multiple Pandoc
786         metadata, with tests.  Thanks to Danny McClanahan and Syohei
787         Yoshida.  ([GH-66][], [GH-91][], [GH-155][], [GH-156][],
788         [GH-157][])
789     -   Change the behavior of <kbd>C-c C-o</kbd>
790         (`markdown-follow-link-at-point`) so that if a link is a
791         complete URL, it will open in a browser.  Otherwise, open it
792         with `find-file` after stripping anchors and/or query strings.
793         ([GH-132][])
794     -   Make font lock for missing wiki links optional and disabled by
795         default.  Add new custom variable
796         `markdown-wiki-link-fontify-missing` to control this behavior.
797     -   The _function_ `markdown-enable-math` has been made obsolete
798         and renamed to `markdown-toggle-math`.  When called without an
799         argument, the result is to toggle this extension rather than
800         enable it.
802 *   New features:
804     -   Filling for definition list items. ([GH-13][])
805     -   Added option `markdown-gfm-downcase-languages` to use
806         lowercase language name in GFM code blocks.
807         ([GH-71][], [GH-73][])
808     -   Customizable live preview window split direction via
809         `markdown-split-window-direction`.  ([GH-129][], [GH-188][])
810     -   Variable-height headings via
811         `markdown-header-scaling`. ([GH-121][])
812     -   Implement inline image previews via
813         `markdown-toggle-inline-images` and <kbd>C-c C-i C-t</kbd>.
814         Thanks to Syohei Yoshida.  ([GH-122][], [GH-128][])
815     -   Added `markdown-wiki-link-search-subdirectories` to enable
816         searching for wiki link files in subdirectories. ([GH-174][])
817     -   Added option to automatically continue lists when `RET` is
818         pressed.  `markdown-indent-on-enter` now has three settings.
819         ([GH-179][])
820     -   Match fenced code blocks with language and info strings.
821         ([GH-184][])
822     -   Add smart Markdown block navigation commands <kbd>M-{</kbd>
823         and <kbd>M-}</kbd>.  These replace the
824         regular-expression-based "paragraph" movement commands
825         provided by Emacs, which do not recognize Markdown syntax
826         (e.g., headings inside of code blocks).  Also use
827         <kbd>M-h</kbd> for marking a block and <kbd>C-x n b</kbd> to
828         narrow to a block.
829     -   Add `markdown-nested-imenu-heading-index` as a customizable
830         option.  It may be disabled to instead generate a flat imenu
831         index.
832     -   Basic font lock and filling for definition lists.  As a side
833         effect, list item navigation and movement should also work.
834     -   Add command for toggling GFM task list items via
835         <kbd>C-c C-c C-x</kbd> (`markdown-toggle-gfm-checkbox`).
836     -   Ability to toggle wiki link support via a new custom variable
837         `markdown-enable-wiki-links`.  This may be set in a file local
838         variable.  Also added function `markdown-toggle-wiki-links`
839         and a menu item.
841 *   Improvements:
843     -   Menubar reorganization.  Grouped related actions together,
844         added missing commands, and added several toggle options to
845         the menu. ([GH-147][])
846     -   Use `toggle` menu style for macOS compatibility.
847     -   Remove autoload for `.text` files.  Thanks to Steve Purcell.
848         ([GH-118][])
849     -   Set own `adaptive-fill-regexp` so that `fill-paragraph` works
850         for list items.  Thanks to Syohei Yoshida for the patch.
851         ([GH-79][], [GH-80][])
852     -   Suppress minibuffer output when generated HTML is small.
853         Thanks to Syohei Yoshida.  ([GH-83][], [GH-86][])
854     -   Use GitHub fetcher for `markdown-mode` on MELPA.  ([GH-84][])
855     -   Improve fenced code block parsing.  Thanks to Danny McClanahan.
856         ([GH-85][], [GH-95][])
857     -   Markdown Mode is now automatically tested against Emacs
858         24.1-24.5 and 25.1-25.2.  ([GH-99][])
859     -   Make live-preview mode follow min or max point.  Thanks to
860         Danny McClanahan.  ([GH-102][])
861     -   Improved font-lock performance. ([GH-119][])
862     -   Maintain cursor position when indenting instead of moving to
863         the beginning of the line.  Thanks to Isaac Hodes.
864         ([GH-125][])
865     -   Add used language names to front of list of known languages.
866         ([GH-135][])
867     -   Support basic TOML metadata.  Thanks to Jorge Israel Peña.
868         ([GH-137][])
869     -   Prohibit setext heading text from starting with hyphens,
870         spaces or tabs, so that there is no ambiguity between setext
871         headings and in-progress lists.  ([GH-139][], [GH-143][])
872     -   Ignore heading lines in `fill-paragraph`.  Thanks to Syohei
873         Yoshida.  ([GH-159][], [GH-162][])
874     -   Improve matching of multiple math blocks with non-math text in
875         between.  Thanks to Dave Kleinschmidt for a patch.
876         ([GH-168][])
877     -   Prevent `fill-paragraph` from filling lines in code blocks.
878         ([GH-169][])
879     -   Fix font lock for links with URLs containing parentheses.
880         ([GH-170][])
881     -   `fill-paragraph` now respects paragraph boundaries within
882         blockquotes.  ([GH-186][])
883     -   Set mark when calling `markdown-up-heading`.
884     -   Improved font locking after empty GFM code block insertion.
885     -   Fix spurious italics from underscores in URLs.
886     -   Respect `font-lock-mode` being nil.  Only call
887         `font-lock-refresh-defaults` if `font-lock-mode` is non-nil to
888         prevent it from being turned on when disabled by user.  Thanks
889         to Tom May for the patch.
890     -   Fix list item insertion on ordered lists with hash marks
891         (Pandoc "fancy lists").
892     -   Treat polymode blocks as code blocks when parsing the buffer.
893     -   Require whitespace atx heading hashmarks, as required by the
894         original atx specification (but not enforced by Markdown.pl).
895         The benefit is that it prevents false positives for #hashtags
896         and things like "Engine #1" when lines wrap.
897     -   Complete heading markup when point is on an setext heading and
898         `markdown-insert-header-dwim` is invoked
899         (<kbd>C-c C-t h</kbd>).
900     -   Better point position after inserting asymmetric atx headings.
902 *   Bug fixes:
904     -   Fix `scripts/get-recognized-gfm-languages.el`, which skipped
905         languages with spaces.  ([GH-72][], [GH-82][])
906     -   `README.md` specified Arch (AUR) package (`emacs-goodies-el`),
907         which did not exist.  ([GH-74][])
908     -   Don't accidentally override user entries in `auto-mode-alist`.
909         ([GH-127][])
910     -   Fix `markdown-cycle` issue with heading-like strings in code
911         blocks.  Thanks to Syohei Yoshida.  ([GH-75][], [GH-76][])
912     -   Fix moving same level heading over code block issue.  Thanks
913         to Syohei Yoshida.  ([GH-77][], [GH-78][])
914     -   Don't insert empty title strings for links.  Thanks to
915         Sebastian Wiesner for the patch.  ([GH-89][])
916     -   Fix possible infinite loop in `markdown-cleanup-list-numbers`.
917         Thanks to Danny McClanahan.  ([GH-98][], [GH-100][])
918     -   Fix an args-out-of-range error due to the syntax-propertize
919         function returning point which is larger than `point-max`.
920         Thanks to Syohei Yoshida. ([GH-142][])
921     -   Respect narrowed region in `markdown-find-previous-prop`.
922         Thanks to Vitalie Spinu.  ([GH-109][])
923     -   Move point at least 1 char in
924         `markdown-match-propertized-text` to avoid possible infinite
925         loop in font-lock.  Thanks to Vitalie Spinu.  ([GH-110][])
926     -   Fix issues where buffers could be marked as modified when no
927         modifications were made.  ([GH-115][], [GH-116][], [GH-146][])
928     -   Fix an issue where comments of the form `<!-- > comment -->`
929         were not correctly identified.  ([GH-117][])
930     -   Prevent spurious bold fontification.  Thanks to Kévin Le
931         Gouguec.  ([GH-124][])
932     -   Keep metadata visible when cycling visibility.  ([GH-136][])
933     -   `markdown-syntax-propertize-extend-region` should not
934         overwrite match-data, which caused issues with
935         `replace-regexp`, etc.  ([GH-104][], [GH-105][])
936     -   Don't list heading-like lines in code blocks or metadata in
937         imenu.  Thanks to Syohei Yoshida.  ([GH-145][], [GH-154][])
938     -   Fix an issue where fill paragraph wouldn't work following
939         unclosed left square brackets.  ([GH-148][], [GH-161][])
940     -   Fix default language presented when inserting GFM code blocks.
941         Thanks to Conal Elliot for a patch.  ([GH-152][])
942     -   Backspace now always deletes characters if a region is
943         specified.  Thanks to Syohei Yoshida.
944         ([GH-166][], [GH-167][])
945     -   Fix `markdown-header-face` inherit from nil error, e.g., when
946         exporting HTML from an Org mode file containing a Markdown
947         source block.  Thanks to Moogen Tian for a patch.
948         ([GH-190][], [GH-193][])
949     -   Inserting a reference link no longer causes an "args out of
950         range" commit error when the existing reference label is a
951         single commit character.
952     -   Fix to honor location setting when inserting reference
953         definitions.
954     -   Fixed an issue where, if there is special markup at the end of
955         the buffer, deleting a character backward would cause the
956         font-lock faces to disappear.
957     -   Fix incorrect matching of italic text due to underscores in
958         math mode.  Thanks also to Dave Kleinschmidt.
959     -   Fix italic highlighting issue when each line or both lines are list.
960     -   Handle false positive italics across list items.
962   [gh-13]: https://github.com/jrblevin/markdown-mode/issues/13
963   [gh-26]: https://github.com/jrblevin/markdown-mode/issues/26
964   [gh-66]: https://github.com/jrblevin/markdown-mode/issues/66
965   [gh-71]: https://github.com/jrblevin/markdown-mode/issues/71
966   [gh-72]: https://github.com/jrblevin/markdown-mode/issues/72
967   [gh-73]: https://github.com/jrblevin/markdown-mode/issues/73
968   [gh-74]: https://github.com/jrblevin/markdown-mode/issues/74
969   [gh-75]: https://github.com/jrblevin/markdown-mode/issues/75
970   [gh-76]: https://github.com/jrblevin/markdown-mode/pull/76
971   [gh-77]: https://github.com/jrblevin/markdown-mode/pull/77
972   [gh-78]: https://github.com/jrblevin/markdown-mode/pull/78
973   [gh-79]: https://github.com/jrblevin/markdown-mode/issues/79
974   [gh-80]: https://github.com/jrblevin/markdown-mode/pull/80
975   [gh-82]: https://github.com/jrblevin/markdown-mode/pull/82
976   [gh-83]: https://github.com/jrblevin/markdown-mode/issues/83
977   [gh-84]: https://github.com/jrblevin/markdown-mode/issues/84
978   [gh-86]: https://github.com/jrblevin/markdown-mode/pull/86
979   [gh-85]: https://github.com/jrblevin/markdown-mode/issues/85
980   [gh-89]: https://github.com/jrblevin/markdown-mode/pull/89
981   [gh-91]: https://github.com/jrblevin/markdown-mode/pull/91
982   [gh-95]: https://github.com/jrblevin/markdown-mode/pull/95
983   [gh-98]: https://github.com/jrblevin/markdown-mode/issues/98
984   [gh-99]: https://github.com/jrblevin/markdown-mode/pull/99
985   [gh-100]: https://github.com/jrblevin/markdown-mode/pull/100
986   [gh-102]: https://github.com/jrblevin/markdown-mode/pull/102
987   [gh-104]: https://github.com/jrblevin/markdown-mode/issues/104
988   [gh-105]: https://github.com/jrblevin/markdown-mode/pull/105
989   [gh-109]: https://github.com/jrblevin/markdown-mode/pull/109
990   [gh-110]: https://github.com/jrblevin/markdown-mode/pull/110
991   [gh-115]: https://github.com/jrblevin/markdown-mode/issues/115
992   [gh-116]: https://github.com/jrblevin/markdown-mode/pull/116
993   [gh-117]: https://github.com/jrblevin/markdown-mode/issues/117
994   [gh-118]: https://github.com/jrblevin/markdown-mode/pull/118
995   [gh-119]: https://github.com/jrblevin/markdown-mode/issues/119
996   [gh-121]: https://github.com/jrblevin/markdown-mode/issues/121
997   [gh-122]: https://github.com/jrblevin/markdown-mode/issues/122
998   [gh-124]: https://github.com/jrblevin/markdown-mode/issues/124
999   [gh-125]: https://github.com/jrblevin/markdown-mode/pull/125
1000   [gh-127]: https://github.com/jrblevin/markdown-mode/issues/127
1001   [gh-128]: https://github.com/jrblevin/markdown-mode/pull/128
1002   [gh-129]: https://github.com/jrblevin/markdown-mode/issues/129
1003   [gh-132]: https://github.com/jrblevin/markdown-mode/pull/132
1004   [gh-135]: https://github.com/jrblevin/markdown-mode/issues/135
1005   [gh-136]: https://github.com/jrblevin/markdown-mode/issues/136
1006   [gh-137]: https://github.com/jrblevin/markdown-mode/issues/137
1007   [gh-139]: https://github.com/jrblevin/markdown-mode/issues/139
1008   [gh-142]: https://github.com/jrblevin/markdown-mode/pull/142
1009   [gh-143]: https://github.com/jrblevin/markdown-mode/issues/143
1010   [gh-145]: https://github.com/jrblevin/markdown-mode/issues/145
1011   [gh-154]: https://github.com/jrblevin/markdown-mode/pull/154
1012   [gh-146]: https://github.com/jrblevin/markdown-mode/pull/146
1013   [gh-147]: https://github.com/jrblevin/markdown-mode/issues/147
1014   [gh-148]: https://github.com/jrblevin/markdown-mode/issues/148
1015   [gh-152]: https://github.com/jrblevin/markdown-mode/issues/152
1016   [gh-155]: https://github.com/jrblevin/markdown-mode/issues/155
1017   [gh-156]: https://github.com/jrblevin/markdown-mode/issues/156
1018   [gh-157]: https://github.com/jrblevin/markdown-mode/pull/157
1019   [gh-159]: https://github.com/jrblevin/markdown-mode/issues/159
1020   [gh-161]: https://github.com/jrblevin/markdown-mode/issues/161
1021   [gh-162]: https://github.com/jrblevin/markdown-mode/pull/162
1022   [gh-166]: https://github.com/jrblevin/markdown-mode/issues/166
1023   [gh-167]: https://github.com/jrblevin/markdown-mode/pull/167
1024   [gh-168]: https://github.com/jrblevin/markdown-mode/pull/168
1025   [gh-169]: https://github.com/jrblevin/markdown-mode/issues/169
1026   [gh-170]: https://github.com/jrblevin/markdown-mode/issues/170
1027   [gh-174]: https://github.com/jrblevin/markdown-mode/issues/174
1028   [gh-179]: https://github.com/jrblevin/markdown-mode/issues/179
1029   [gh-184]: https://github.com/jrblevin/markdown-mode/issues/184
1030   [gh-186]: https://github.com/jrblevin/markdown-mode/issues/186
1031   [gh-188]: https://github.com/jrblevin/markdown-mode/pull/188
1032   [gh-190]: https://github.com/jrblevin/markdown-mode/pull/190
1033   [gh-193]: https://github.com/jrblevin/markdown-mode/issues/193
1035 # Markdown Mode 2.1
1037 *January 9, 2016*
1039 Version 2.1 is a major new stable release and all users are encouraged
1040 to upgrade.  The many new features and bug fixes included are
1041 described below.
1043 Markdown Mode is developed and tested primarily for compatibility with
1044 GNU Emacs versions 24.3 and later.  It requires `cl-lib` version 0.5
1045 or later.  This library has been bundled with GNU Emacs since version
1046 24.3.  Users of GNU Emacs 24.1 and 24.2 can install `cl-lib` using
1047 `M-x package-install RET cl-lib`.
1049 This release of Markdown Mode contains patches written by many
1050 individuals including Masayuki Ataka, Jonas Bernoulli, Roger Bolsius,
1051 Daniel Brotsky, Julien Danjou, Samuel Freilich, David Glasser, Marijn
1052 Haverbeke, Antonis Kanouras, Keshav Kini, Vasily Korytov, Danny
1053 McClanahan, Matt McClure, Howard Melman, Makoto Motohashi, Jon
1054 Mountjoy, Pierre Neidhardt, Spanti Nicola, Paul W. Rankin, Christophe
1055 Rhodes, Tim Visher, and Syohei Yoshida.  Many others also submitted
1056 bug reports. Thanks to everyone for your contributions.
1058 *   **Breaking changes:**
1060     -   In GFM Mode, `visual-line-mode` is no longer enabled by
1061         default.  A `gfm-mode-hook` was added, which could be used to
1062         keep `visual-line-mode` on by default in `gfm-mode`.
1063         ([GH-31][])
1065 *   New features:
1067     -   Add automatically updating live preview functionality
1068         (<kbd>C-c C-c l</kbd>) via the native `eww` browser.
1069         ([GH-36][], [GH-53][], [GH-57][], [GH-58][], [GH-63][])
1070     -   Use `autoload` to enable `markdown-mode` in `auto-mode-alist`
1071         for files with `.text`, `.markdown`, and `.md` extensions.
1072     -   Use Travis CI for automated build testing.
1073     -   ATX heading subtree promotion and demotion via
1074         <kbd>M-S-LEFT</kbd>, and <kbd>M-S-RIGHT</kbd>.
1075     -   ATX heading subtree moving up and down via <kbd>M-S-UP</kbd>
1076         and <kbd>M-S-DOWN</kbd>.
1077     -   Convert inline links to reference links when
1078         `markdown-insert-reference-link-dwim` is used when the point
1079         is at an inline link.
1080     -   Allow linking to multiple stylesheets in `markdown-css-paths`
1081         list.  Use stylesheets for both preview and export. Previous
1082         `markdown-css-path` (singular) is now deprecated.
1083     -   Customizable default unordered list marker via
1084         `markdown-unordered-list-item-prefix`.
1085     -   Add asymmetric ATX heading adornment option
1086         `markdown-asymmetric-header`.
1087     -   Font lock for `<kbd>` tags.
1088     -   Support GFM-style code blocks in `markdown-mode` (as well as
1089         `gfm-mode`).  ([GH-2][])
1090     -   New function `markdown-electric-backquote` will prompt for a
1091         language name for GFM code blocks.  This can be disabled by
1092         customizing the variable
1093         `markdown-gfm-use-electric-backquote`.  ([GH-9][])
1094     -   Completion of programming language names for GFM code blocks.
1095         A list of pre-defined languages is included, but this can be
1096         augmented by setting `markdown-gfm-additional-languages`.
1097         ([GH-38][], [GH-54][], [GH-59][], [GH-60][], [GH-64][])
1098     -   Strikethrough support in `gfm-mode`.
1099     -   Support for GFM toggling checkboxes `mouse-1` or
1100         <kbd>RET</kbd>.  This is controlled by a new custom variable,
1101         `markdown-make-gfm-checkboxes-buttons`.  Thanks to Howard
1102         Melman for a patch.  ([GH-7][])
1103     -   Font lock and filling for Pandoc "fancy lists," which use `#`
1104         as the list marker.  ([GH-3][])
1105     -   Basic support for filling of definition lists.  ([GH-20][])
1106     -   Support [Ikiwiki](http://ikiwiki.info/)-style search for wiki links that allows
1107         links relative to parent directories.  Enable this by setting
1108         `markdown-wiki-link-search-parent-directories`.
1109         ([GH-8][], [GH-21][])
1111 *   Improvements:
1113     -   General font lock improvements for comments, code blocks,
1114         blockquotes, headings, horizontal rules, bold, and italics.
1115         ([GH-67][], [GH-68][])
1116     -   Separate highlighting for Markdown markup characters
1117         (asterisks, underscores, backquotes, etc.) to aid in
1118         readability.
1119     -   Font lock for bold, italics, and LaTeX math work inside block
1120         elements such as headings and blockquotes.  ([GH-39][])
1121     -   Display a link to the GitHub repository in the MELPA
1122         description.  ([GH-37][])
1124 *   Bug fixes:
1126     -   Fix bug in `markdown-complete-region/buffer` where level-two
1127         Setext headings could be confused with horizontal rules.
1128         Includes a unit test.  Thanks to Gunnar Franke for the report.
1129     -   Fix filling when a decimal number appears at column zero,
1130         which could be confused with an ordered list item.
1131     -   Fix buffer-wide markup completion.
1132     -   Fix font-lock for GFM code blocks without language keywords.
1133     -   Improved Setext header insertion to support wide characters.
1134     -   Fix expensive `paragraph-separate` regular expression.
1135     -   Make `comment-auto-fill-only-comments` a buffer-local
1136         variable, which allows for better default filling behavior in
1137         cases where the global variable is non-`nil`.
1138     -   Fix Emacs 23 compatibility by checking for
1139         `font-lock-refresh-defaults` before calling it.
1140     -   Handle reference definitions when filling paragraphs.
1141     -   Improve filling of list items with indentation.
1142     -   Properly handle footnotes when filling.
1143     -   Fix issues with markdown-footnote-kill and related functions.
1144     -   Improve font lock for fenced code blocks.
1145     -   Avoid avoid overwriting source file when exporting if source
1146         file has `.html` extension.
1147     -   Fix and improve ordered list behavior to preserve digit
1148         spacing and avoid an infinite loop in certain cases.  Adjust
1149         ordered list whitespace when marker digit count increases.
1150     -   Improve reference definition regular expression to avoid
1151         matching multiple reference links in one line.
1152     -   Allow spaces in fenced code language identifiers.  ([GH-22][])
1153     -   Improve font lock for preformatted blocks and fenced code
1154         blocks.
1155     -   Fix out-of-order HTML output.  ([GH-14][])
1156     -   Add console-friendly backspace and tab bindings.  ([GH-15][])
1157     -   Better treatment of files without extensions for wiki links.
1158         When files have no extensions, don't append a lone period.
1159         ([GH-23][])
1160     -   Call `looking-back` with two arguments for compatibility with
1161         Emacs 25.1.
1162     -   Make `(beginning-of-defun -1)` go to next title when point is
1163         at beginning of defun.  ([GH-34][])
1164     -   Ignore headings in code blocks for font lock, movement, and
1165         visibility cycling.
1166         ([GH-27][], [GH-33][], [GH-35][], [GH-40][], [GH-41][])
1167     -   Don't highlight wiki links in code blocks.  ([GH-17][])
1168     -   Don't move to links in code blocks with <kbd>C-c C-p</kbd> and
1169         <kbd>C-c C-n</kbd>.
1170     -   Fix hanging indentation for list items and single-line
1171         preformatted blocks.  ([GH-16][], [GH-28][], [GH-30][])
1172     -   Better rejection of false positives for italics with respect
1173         to other inline elements (inline code and bold).
1174     -   Predicate functions should not modify match data.
1175     -   Use correct list marker from previous list level when using
1176         <kbd>C-u M-RET</kbd> to insert a dedented list item.  Prevent
1177         an infinite loop in some cases.  ([GH-4][])
1178     -   Reduce lag when scrolling or inserting text into large files.
1179         ([GH-30][], [GH-101][])
1180     -   Avoid confusing tramp errors with malformed wiki links.
1181         ([GH-65][])
1183   [gh-2]: https://github.com/jrblevin/markdown-mode/pull/2
1184   [gh-3]: https://github.com/jrblevin/markdown-mode/pull/3
1185   [gh-4]: https://github.com/jrblevin/markdown-mode/issues/4
1186   [gh-7]: https://github.com/jrblevin/markdown-mode/issues/7
1187   [gh-8]: https://github.com/jrblevin/markdown-mode/issues/8
1188   [gh-9]: https://github.com/jrblevin/markdown-mode/issues/9
1189   [gh-14]: https://github.com/jrblevin/markdown-mode/issues/14
1190   [gh-15]: https://github.com/jrblevin/markdown-mode/issues/15
1191   [gh-16]: https://github.com/jrblevin/markdown-mode/issues/16
1192   [gh-17]: https://github.com/jrblevin/markdown-mode/issues/17
1193   [gh-18]: https://github.com/jrblevin/markdown-mode/issues/18
1194   [gh-20]: https://github.com/jrblevin/markdown-mode/issues/20
1195   [gh-21]: https://github.com/jrblevin/markdown-mode/issues/21
1196   [gh-22]: https://github.com/jrblevin/markdown-mode/issues/22
1197   [gh-23]: https://github.com/jrblevin/markdown-mode/issues/23
1198   [gh-27]: https://github.com/jrblevin/markdown-mode/issues/27
1199   [gh-28]: https://github.com/jrblevin/markdown-mode/issues/28
1200   [gh-30]: https://github.com/jrblevin/markdown-mode/issues/30
1201   [gh-31]: https://github.com/jrblevin/markdown-mode/issues/31
1202   [gh-32]: https://github.com/jrblevin/markdown-mode/pull/32
1203   [gh-33]: https://github.com/jrblevin/markdown-mode/issues/33
1204   [gh-34]: https://github.com/jrblevin/markdown-mode/pull/34
1205   [gh-35]: https://github.com/jrblevin/markdown-mode/pull/35
1206   [gh-36]: https://github.com/jrblevin/markdown-mode/pull/36
1207   [gh-37]: https://github.com/jrblevin/markdown-mode/issues/37
1208   [gh-38]: https://github.com/jrblevin/markdown-mode/issues/38
1209   [gh-39]: https://github.com/jrblevin/markdown-mode/issues/39
1210   [gh-40]: https://github.com/jrblevin/markdown-mode/pull/40
1211   [gh-41]: https://github.com/jrblevin/markdown-mode/pull/41
1212   [gh-53]: https://github.com/jrblevin/markdown-mode/pull/53
1213   [gh-54]: https://github.com/jrblevin/markdown-mode/pull/54
1214   [gh-57]: https://github.com/jrblevin/markdown-mode/pull/57
1215   [gh-58]: https://github.com/jrblevin/markdown-mode/pull/58
1216   [gh-59]: https://github.com/jrblevin/markdown-mode/pull/59
1217   [gh-60]: https://github.com/jrblevin/markdown-mode/pull/60
1218   [gh-63]: https://github.com/jrblevin/markdown-mode/pull/63
1219   [gh-64]: https://github.com/jrblevin/markdown-mode/pull/64
1220   [gh-65]: https://github.com/jrblevin/markdown-mode/pull/65
1221   [gh-67]: https://github.com/jrblevin/markdown-mode/pull/67
1222   [gh-68]: https://github.com/jrblevin/markdown-mode/pull/68
1223   [gh-101]: https://github.com/jrblevin/markdown-mode/issues/101
1225 # Markdown Mode 2.0
1227 *March 24, 2013*
1229 Version 2.0 is a major new stable release with many new features,
1230 including some changes to keybindings for element insertion and
1231 outline navigation.  In summary, Markdown Mode now has improved
1232 keybindings, smarter markup insertion commands, a general markup
1233 removal command, markup completion (normalization), markup promotion
1234 and demotion, list and region editing, many syntax highlighting
1235 improvements, new and improved movement commands, and generalized link
1236 following and movement.
1238 *   **Breaking changes:**
1240     -    Physical style element insertion commands prefixed by
1241          <kbd>C-c C-p</kbd> have been removed in favor of their
1242          logical style counterparts prefixed by <kbd>C-c C-s</kbd>.
1243     -    Shift is now the preferred way to distinguish keybindings for
1244          two related elements.  For example, you can insert an inline
1245          link with <kbd>C-c C-a l</kbd> or a reference link with
1246          <kbd>C-c C-a L</kbd>.  The latter keybinding is new and
1247          preferred over <kbd>C-c C-a r</kbd>, which is deprecated.
1248     -    Footnote keybindings have been moved away from the
1249          <kbd>C-c C-f n</kbd> prefix.
1250     -    Several other new keybindings have been introduced and are
1251          described in more detail below.
1252     -    Removed wiki link following with `RET` and
1253          `markdown-follow-wiki-link-on-enter` setting.  Use the
1254          unified following (open link) command <kbd>C-c C-o</kbd>
1255          instead.
1257 *   New features:
1259     -    Fast heading insertion with a single command which
1260          automatically calculates the type (atx or setext) and level.
1261          Prefix with <kbd>C-u</kbd> to promote the heading by one
1262          level or <kbd>C-u C-u</kbd> to demote the heading by one
1263          level.  Headings with a specific level or type can still be
1264          inserted quickly with specific keybindings.
1265     -    Easily kill an element (e.g., a link or reference definition)
1266          at the point with <kbd>C-c C-k</kbd> and store the most
1267          important part in the kill ring (e.g., the link text or URL).
1268     -    Markup completion (<kbd>C-c C-]</kbd>) normalizes the markup
1269          for an element (e.g., it balances hash marks and removing
1270          extra whitespace for atx headings).
1271     -    Markup promotion and demotion via <kbd>C-c C--</kbd> and
1272          <kbd>C-c C-=</kbd>, respectively.  The sequences
1273          <kbd>M-UP</kbd> and <kbd>M-DOWN</kbd> may
1274          also be used.
1275     -    List editing: move list items up and down with
1276          <kbd>M-UP</kbd> and <kbd>M-DOWN</kbd>.
1277          Indent and exdent list items with <kbd>M-LEFT</kbd>
1278          and <kbd>M-RIGHT</kbd>.
1279     -    Region editing: indent and exdent regions, with tab stops
1280          determined by context, using <kbd>C-c <</kbd> and
1281          <kbd>C-c ></kbd> (as in `python-mode`).
1282     -    Smart list item insertion with <kbd>M-RET</kbd>, with
1283          indentation and marker determined by the surrounding context.
1284          Prefix with <kbd>C-u</kbd> to decrease the indentation by one
1285          level or <kbd>C-u C-u</kbd> to increase the indentation one
1286          level.
1287     -    Quickly jump between reference definitions and
1288          reference-style links and between footnote markers and
1289          footnote text with <kbd>C-c C-j</kbd>.  Create undefined
1290          references when jumping from a reference link.  When jumping
1291          back, present a buffer with buttons for selecting which link
1292          to jump to.
1293     -    Revised outline navigation commands, following `org-mode`.
1294          This frees up the sexp navigation keys <kbd>C-M-f</kbd> and
1295          <kbd>C-M-b</kbd> which can be useful in Markdown documents
1296          which have many matching delimiters, as well as the defun
1297          navigation keys <kbd>C-M-a</kbd> and <kbd>C-M-e</kbd>.
1298     -    Previous/next section movement with <kbd>C-M-a</kbd> and
1299          <kbd>C-M-e</kbd> (in Emacs parlance, this is movement by
1300          defun).  Mark the current section with <kbd>C-M-h</kbd>.
1301     -    Previous/next paragraph movement via <kbd>M-{</kbd> and
1302          <kbd>M-}</kbd>.
1303     -    Previous/next block movement with <kbd>C-u M-{</kbd> and
1304          <kbd>C-u M-}</kbd>.
1305     -    Customizable reference link location via
1306          `markdown-reference-location`.
1307     -    Font lock for title strings in inline links.
1308     -    Subtle syntax highlighting for hard line breaks.
1309     -    In GFM Mode, change italic font lock behavior to match GFM
1310          specification regarding underscores in words.
1311     -    Insertion command (<kbd>C-c C-s P</kbd>) for GFM quoted code
1312          blocks.
1313     -    Syntax highlighting for MultiMarkdown metadata and Pandoc
1314          title blocks.
1315     -    Added before and after export hooks
1316          `markdown-before-export-hook` and
1317          `markdown-after-export-hook`.
1318     -    Added a library of regression tests which currently contains
1319          160 unit tests.
1321 *   Improvements:
1323     -    ATX heading insertion will use current line as heading text
1324          if not blank and there is no active region.
1325     -    Setext heading insertion will prompt for heading title when
1326          there is no active region.
1327     -    When the point is at a heading, the heading insertion
1328          commands will replace the heading at point with a heading of
1329          the requested level and type.
1330     -    When there is no active region, the bold, italic, code, link,
1331          and image insertion commands will operate on the word at
1332          point, if any, so that you don't have to have an active
1333          selection for simple modifications.
1334     -    Repeating the bold, italic, or code insertion commands when
1335          the point is at an element of the corresponding type will
1336          remove the markup.
1337     -    Indentation of preformatted text and blockquotes will be
1338          adjusted automatically in contexts where more indentation is
1339          required, as in nested lists.  (For example, in Markdown, a
1340          preformatted text block inside a first-level list item must
1341          have eight spaces of indentation.)
1342     -    Improved reference link insertion with label completion:
1343            + Use word at point as link text, if possible, when there
1344              is no active region.
1345            + Tab completion of reference labels from the set of
1346              currently defined references.
1347            + Reference link insertion no longer prompts for a URL or
1348              title if the label is already defined.
1349            + If no URL is given, create an empty reference definition
1350              and move the point there.
1351     -    Basic reference-style image markup insertion.
1352     -    Multiple horizontal rule styles, `markdown-hr-strings`,
1353          customizable as a list of strings, which can be cycled
1354          through.
1355     -    New URL insertion command for inserting plain URLs delimited
1356          by angle brackets (<kbd>C-c C-a u</kbd>).  Works on URL at
1357          point, if any, when there is no active region.
1358     -    Generally improved insertion commands with respect to
1359          insertion of surrounding whitespace and point position after
1360          insertion (e.g., ensuring blank lines before and after newly
1361          inserted headings and horizontal rules).
1362     -    Unified link following: open links in a browser and wiki
1363          links in a new buffer with the same keybinding (<kbd>C-c
1364          C-o</kbd>).  This supersedes the separate wiki link following
1365          command (<kbd>C-c C-w</kbd>).
1366     -    Generalized link movement and following: move between and
1367          open all link types (inline, reference, wiki, angle URIs)
1368          using the same key bindings (<kbd>M-n</kbd> and
1369          <kbd>M-p</kbd>).  Previously, these commands only moved
1370          between wiki links, but with the above following enhancement,
1371          moving between hyperlinks of all types is more useful.
1372     -    Syntax highlighting for GFM quoted code blocks with an
1373          optional language keyword.
1374     -    Dynamic loading and unloading for math support with
1375          refontification.
1376     -    Allow underscores and colons in equation labels in math mode.
1377     -    Syntax highlighting improvements: faster identification of
1378          preformatted blocks.  Markdown Mode adheres to the four space
1379          rule for nested list items: in a list item of level _n_,
1380          preformatted text must be indented at least 4(_n_ + 1)
1381          spaces.
1382     -    More inclusive blockquote regular expression highlights
1383          blockquotes with leading indentation, when appropriate.
1384     -    Regular expression optimization for URI matching.
1385     -    Numerous other improvements for more accurate syntax
1386          highlighting.
1387     -    Respect hard line breaks when filling paragraphs.
1388     -    Add indentation positions: preceding list markers and pre
1389          block position.
1390     -    Use button-map for navigating undefined references, so that
1391          references can be navigated via the keyboard by pressing
1392          <kbd>TAB</kbd> and <kbd>S-TAB</kbd>.
1393     -    Use newer `use-region-p` when possible to check for active
1394          region, with fallbacks for older Emacsen and Xemacs.
1395     -    Clean up whitespace after deleting footnote text.
1396     -    Use adaptive filling for list items and blockquotes.
1397     -    Treat all list items (any marker type) the same way with respect
1398          to filling.
1399     -    Retain the `>` prefix when filling blockquotes.
1400     -    Fill list items inside of blockquotes.
1401     -    Numerous other internal improvements to make the code base
1402          more robust.
1404 *   Bug fixes:
1406     -    Fix bug in heading visibility cycling introduced in version
1407          1.9 where the level of headings was being calculated
1408          incorrectly.
1409     -    Fix problems inserting ATX headings at end of buffer.
1410     -    Support small Setext headings (with fewer than three
1411          characters).
1412     -    Several improvements to inline code syntax highlighting.
1413     -    Fix some edge cases regarding escaping, spaces, etc. for bold
1414          and italic font lock.
1415     -    Prohibit newlines and tabs immediately after opening bold and
1416          italic delimiters.  This fixes a bug where italics would not
1417          be highlighted following a horizontal rule
1418     -    Improved multi-line font lock performance for large files.
1419     -    Improved multi-line font lock at beginning of buffer.
1420     -    List items with any of the three markers are filled in the
1421          same way (previously list items starting with `+` were not
1422          filled with hanging indentation).
1423     -    Fix end detection for empty list items.  Don't skip over the
1424          whitespace following the marker on the same line.
1425          Previously, empty list items were not being detected properly
1426          by `markdown-cur-list-item-bounds` as a result of this.
1427     -    Don't exclude `[^]`, which is a valid reference tag (but
1428          let's please stick to alphanumeric characters).
1429     -    No longer highlight escaped wiki links.
1430     -    Fix line number buttons for reference checking and make all
1431          buttons clickable.
1432     -    Fix killing of footnotes with no text.
1433     -    Fix escaping in `markdown-xhtml-standalone-regexp`.
1434     -    Fix a font-lock edge case involving footnote markers
1435          preceding inline links.
1436     -    More accurate font-lock for ATX headings in edge cases.
1437     -    Fix killing of footnotes from footnote text.
1439 --- ---
1441 # Markdown Mode 1.9
1443 *January 1, 2013*
1445 Version 1.9 is a major new stable release with important bug fixes.
1447 *   New features:
1449     -    Support for setext-style headers in `outline-mode`.  Thanks
1450          to Shigeru Fukaya.
1451     -    Font lock for tilde-fenced code blocks.
1452     -    Reference link insertion (<kbd>C-c C-a r</kbd>).
1453     -    Support two forms of aliased wiki links:
1454          `[[link text|PageName]]` and `[[PageName|link text]]`
1455          (`markdown-wiki-link-alias-first`).
1456     -    Footnote support: font lock and insertion, deletion, and
1457          navigation functions for footnotes (prefixed by
1458          <kbd>C-c C-f</kbd>; following for wiki links is now
1459          <kbd>C-c C-w</kbd>).  Thanks to Joost Kremers.
1460     -    Improved preview and export commands.  Thanks to Donald
1461          Ephraim Curtis.
1462     -    `imenu` support.  Thanks to Akinori Musha.
1463     -    Added autoload token for `gfm-mode`.  Thanks to Max Penet and
1464          Peter Eisentraut for the suggestion.
1465     -    Optional character set declaration in XHTML output.  Thanks
1466          to François Gannaz for the suggestion.
1467     -    Smart unindentation when pressing delete at the beginning of
1468          a line.  Thanks to Zhenlei Jia.
1469     -    Optional prefix argument to <kbd>C-c C-w</kbd> for opening
1470          wiki links in another window.
1471     -    Open inline and reference links and inline URIs in browser
1472          (<kbd>C-c C-o</kbd>).  Thanks to Peter Jones.
1473     -    Open files in a standalone previewer or editor
1474          (<kbd>C-c C-c o</kbd>).
1475     -    Clean up numbered/ordered lists (<kbd>C-c C-c n</kbd>).
1476          Thanks to Donald Ephraim Curtis.
1477     -    Save Markdown output to kill ring (copy to clipboard)
1478          (<kbd>C-c C-c w</kbd>).  Thanks to Donald Ephraim Curtis.
1480 *   Improvements:
1482     -    Improve `markdown-mode-hook` docstring.  Thanks to Shigeru
1483          Fukaya for the more precise description.
1484     -    Don't require Common Lisp extensions at run time.  Thanks to
1485          Shigeru Fukaya.
1486     -    Prefer `visual-line-mode`, the replacement for
1487          `longlines-mode`, when in `gfm-mode`.  Thanks to Christopher
1488          J. Madsen.
1489     -    Proper GitHub wiki link handling in `gfm-mode`.  Thanks to
1490          Kevin Porter.
1491     -    XEmacs compatibility:
1492         -    Avoid malformed list errors during font definitions.
1493         -    Handle replace-regexp-in-string.
1494         -    Use text properties instead of overlays.
1495         -    Fall back to `set-buffer-modified-p` when
1496             `restore-buffer-modified-p` is unavailable.
1497         -    Many additional fixes.  Thanks to Michael Sperber.
1498     -    Handle wiki links in buffers not associated with a file.
1499     -    Update autoload documentation to support byte compilation.
1500     -    Option to use `-` instead of `_` for wiki links in
1501          `gfm-mode`.
1502     -    Add two tab stops to possible indentation positions following
1503          list items.
1505 *   Bug fixes:
1507     -    Fixed a bug which caused unusual behavior in functions
1508          performing search, replace, and/or matching operations.
1509          Thanks to Christopher J. Madsen for the patch.
1510     -    Fixed a bug which caused an incompatibility with
1511          `orgtbl-mode`.  Thanks to Vegard Vesterheim for the report
1512          and to Carsten Dominik for a patch.
1513     -    Fixed a bug where reference links at the beginning of a line
1514          would be mistaken for reference definitions.
1515     -    Improved font lock for headers.
1516     -    Improved font lock for reference definitions.  Thanks to Ian
1517          Yang.
1518     -    Avoid byte compiler warning about `region-exists-p` in GNU
1519          Emacs.
1520     -    Additional key bindings for cross-platform header cycling
1521          compatibility.
1522     -    Fix problem with externally modified files on disk where the
1523          user would get stuck in a loop answering "really edit the
1524          buffer?"  Thanks to Bryan Fink for a detailed report.
1525     -    Font lock fix for URLs with underscores.
1526     -    Escape shell commands to handle filenames with spaces, etc.
1527          Thanks to Marcin Kasperski for a patch.
1528     -    Use `:slant` instead of unsupported `:italic` in font spec.
1529     -    Fix typo in `paragraph-fill` regexp.
1531 # Markdown Mode 1.8.1
1533 *August 15, 2011*
1535 Version 1.8.1 is a bugfix version which addresses some minor issues in
1536 version 1.8.
1538 *   New features:
1540     -    Wiki link features now support aliased or piped wiki links of
1541          the form `[[PageName|link text]]`.
1543 *   Bug fixes:
1545     -    Fixed an issue, reported by Werner Dittmann, where the
1546          default indentation position would be skipped over when
1547          `auto-fill-mode` was on.  This meant that when writing a
1548          normal paragraph, for example, the line would wrap to column
1549          4 instead of column 1.
1550     -    Require the `cl` package for `multiple-value-bind`.  Thanks
1551          to Werner Dittman for noticing this.
1552     -    Remove a leftover debug print message which would announce
1553          "ENTER" in the minibuffer when the enter key was pressed.
1555 # Markdown Mode 1.8
1557 *August 12, 2011*
1559 *   New features:
1561     -   Add support for following wiki links in a buffer, either with
1562         <kbd>C-c C-f</kbd> or, optionally, <kbd>RET</kbd>, when the
1563         point is at a wiki link.
1564     -   Support Markdown processors which do not accept input from
1565         stdin (i.e, Python-Markdown) by adding the
1566         `markdown-command-needs-filename` custom option.  Thanks to
1567         Jeremiah Dodds for a patch.
1568     -   GitHub-Flavored Markdown mode (`gfm-mode`) turns on
1569         `longlines-mode` and `auto-fill-mode`.  Thanks to Edward
1570         O'Connor for the patch.
1571     -   Add outline-mode-like keybindings for fast outline navigation
1572         of atx-style headers (see the updated documentation for
1573         details).
1574     -   Arbitrary content may to be added to the `<head>` block during
1575         HTML output to allow for flexible local customizations.  See
1576         `markdown-xhtml-header-content`.
1577     -   New HTML export options: export to a file with
1578         <kbd>C-c C-c e</kbd> or export to a file and view with
1579         <kbd>C-c C-c v</kbd>.
1580     -   Support Markdown processors which produce standalone output
1581         (i.e., complete HTML documents).  If this is detected, by
1582         matching `markdown-xhtml-standalone-regexp` in the first five
1583         lines of output, then omit the `markdown-mode` header and
1584         footer.  Thanks to Philippe Ivaldi for this and the previous
1585         HTML-output-related patches.
1586     -   Customizable wiki link following behavior using
1587         `markdown-follow-wiki-link-on-enter`.
1588     -   Quick navigation to the previous and next wiki links using
1589         <kbd>M-p</kbd> and <kbd>M-n</kbd>.
1590     -   Wiki links to non-existent files (missing links) are
1591         highlighted differently.  Based on functionality from
1592         `wiki-mode` by Alex Schroeder.  Thanks to Eric Merritt for
1593         patches.
1595 *   Improvements:
1597     -   Improve syntax highlighting of preformatted text blocks to
1598         better distinguish them from list items with hanging
1599         indentation and nested list items.
1600     -   Match italic and bold text and inline code fragments across
1601         line breaks, within a single block, but prevent them from
1602         matching across blocks.
1603     -   Generally improve multi-line font lock by extending the search
1604         region to include full blocks.
1605     -   Make indentation work when the previous line is not indented.
1606     -   Set tab width to 4, the natural tab width for Markdown
1607         documents.
1608     -   Stop announcing "TAB" in the minibuffer when tab is pressed.
1609     -   Use `html-mode` for viewing Markdown output.
1610     -   Ensure Markdown output buffer is always raised, even when the
1611         output is short.
1612     -   Make sure horizontal rules inserted by <kbd>C-c -</kbd>
1613         (`markdown-insert-hr`) are surrounded by blank lines.
1614     -   Added an `autoload` cookie.  Thanks to Peter S. Galbraith for
1615         the patch.
1616     -   Support a customizable horizontal rule string
1617         `markdown-hr-string`.  This replaces the previous but less
1618         flexible custom option `markdown-hr-length`, which has been
1619         removed.
1620     -   Followed wiki links are opened using `markdown-mode`.
1622 *   Bug fixes:
1624     -   Fixed an issue, reported by Joost Kremners, where for
1625         multi-line lists, the position of the list marker was not
1626         being added to the list of possible indentation levels.
1627     -   Avoid a problem where indentation positions were getting
1628         skipped over when tab cycling.
1629     -   Fixed an issue when column 0 is the natural automatic
1630         indentation stop.
1631     -   Prevent infinite loops in blockquote (<kbd>C-c C-s b</kbd>)
1632         and preformatted (<kbd>C-c C-s p</kbd>) block insertion while
1633         at the beginning or end of the buffer.
1635 # Markdown Mode 1.7
1637 *October 1, 2009*
1639   * New features:
1641     -    Support filling of list items.
1642     -    Allow customization of font-lock faces (thanks to intrigeri
1643          for the patch).
1644     -    Automatic indentation when pressing enter or tab (with
1645          cycling upon subsequent tab presses) (thanks to Bryan Kyle).
1646     -    Generate real XHTML for previewing (thanks to Hilko Bengen
1647          for the patch).  This fixes [Debian bug #490865](http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=490865).  The CSS
1648          stylesheet for XHTML output is customizable via
1649          `markdown-css-path` (thanks to Ankit Solanki for the patch).
1650     -    Better URL matching (protocols are customizable through
1651          `markdown-uri-types`).
1652     -    LaTeX syntax highlighting can be enabled or disabled using
1653          the customize system (`markdown-enable-math`).
1654     -    Support for HTML comments (font lock, `comment-dwim`, etc.).
1655     -    Support filling of definition lists (thanks to Peter Williams
1656          for the patch).
1658 *   Improvements:
1660     -    Add support level 5 and 6 atx-style headers (thanks to Alec
1661          Resnick for the report).
1662     -    Fill-paragraph no longer breaks lines inside of square
1663          brackets (thanks to Peter Williams for the patch).
1665 *   Bug fixes:
1667     -    Fixed several font lock issues.
1668     -    Fixed a bug where pressing enter did nothing in
1669          longlines-mode (thanks to Ankit Solanki for the patch).
1670     -    Fixed a problem where Emacs snapshot would hang during
1671          `markdown-enter` and `markdown-cycle` (thanks to Alec Resnick
1672          for the report).
1673     -    Fixed an issue with auto-fill-mode and markdown-mode's
1674          indentation (thanks to Joost Kremers for the report and
1675          analysis).
1677 # Markdown Mode 1.6
1679 *June 4, 2008*
1681 *   **Breaking changes:**
1683     -    Rename `blockquote-region` to `markdown-blockquote-region` in
1684          accordance with the Emacs major mode coding conventions.
1685     -    Several new keybindings.
1686     -    Reverted to using colors instead of bold, italic, and
1687          fixed-width faces.
1689 *   New features:
1691     -    Implemented org-mode style visibility cycling.
1692     -    Support outline minor mode.
1693     -    Undefined reference checking (via `C-c C-c c`, using code by
1694          Dmitry Dzhus).
1695     -    Wiki links: syntax highlighting and element insertion
1696          (`C-c C-a w`).
1697     -    Allow syntax highlighting faces to be customized.
1698     -    Insertion of preformatted text sections (`C-c C-s p`).
1699     -    Font locking for inline URIs and email addresses.
1700     -    Markdown mode menu (thanks to Greg Bognar for the initial
1701          code).
1703 *   Improvements:
1705     -    Markdown customize group moved to `wp` (word processing).
1706     -    Derive from `text-mode` instead of `fundamental-mode`.
1707     -    Properly prefix regex definitions and `wrap-or-insert`
1708          function.
1710 *   Bug fixes:
1712     -    Highlight wrapped inline link definitions (thanks to Blake
1713          Winton).
1714     -    Fix adjacent wiki link font lock bug.
1715     -    Support escaping of backticks.
1716     -    Many other small font lock tweaks.
1717     -    Don't check for `transient-mark-mode` in
1718          `markdown-blockquote-region`.  This fixes Debian bug #456592
1719          (thanks to Daniel Burrows for the report).
1720     -    Apply Greg Bognar's fix for `markdown` with an active region.
1721     -    Don't use the kill ring to store wrapped text.
1723 # Markdown Mode 1.5
1725 *October 11, 2007*
1727 Version 1.5 is a major revision compared to previous releases.  The
1728 functionality has not changed very much, all of the keybindings are
1729 the same, but it is internally quite different.
1731 Most of the changes involve syntax highlighting.  The regular
1732 expressions have been significantly improved and the corresponding
1733 font lock faces have been tweaked (hopefully for the better, but feel
1734 free to customize them).  Various other small bugs have been fixed and
1735 the documentation and website have been updated.
1737 The two changes in functionality, both of which are optional, are
1738 syntax highlighting for embedded mathematics via LaTeX-like
1739 expressions, and highlighting for bracketed wiki links.
1741  [itex]: http://golem.ph.utexas.edu/~distler/blog/itex2MMLcommands.html
1743 # Markdown Mode 1.4
1745 *June 29, 2007*
1747 Version 1.4 includes a small fix to the regular expression syntax to
1748 fix the Emacs 21 "Invalid escape character syntax." error.  Thanks to
1749 Edward O'Connor for the fix.
1751 # Markdown Mode 1.3
1753 *June 5, 2007*
1755 Version 1.3 provides syntax highlighting, insertion commands for all
1756 basic HTML elements, and preview commands for viewing the resulting
1757 HTML in a new buffer of an external browser.
1759 # Markdown Mode 1.2
1761 *May 25, 2007*
1763 Version 1.2 adds element insertion commands and keys for links,
1764 horizontal rules, headers, inline code, and bold and italic text.
1766 Added element insertion commands and keys for links, horizontal rules, headers, inline code, and bold and italic text.
1768 # Markdown Mode 1.1
1770 *May 24, 2007*
1772 Version 1.1 is the initial release of Markdown Mode for Emacs, a major
1773 mode to edit Markdown files in Emacs.  This version provides basic
1774 syntax highlighting and element insertion commands for Markdown files.