Markdown Vim Mode
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

198 lines
6.1 KiB

10 years ago
10 years ago
10 years ago
10 years ago
  1. # Vim Markdown
  2. [![Build Status](https://travis-ci.org/plasticboy/vim-markdown.svg)](https://travis-ci.org/plasticboy/vim-markdown)
  3. Syntax highlighting, matching rules and mappings for [the original Markdown](http://daringfireball.net/projects/markdown/) and extensions.
  4. 1. [Installation](#installation)
  5. 1. [Options](#options)
  6. 1. [Mappings](#mappings)
  7. 1. [Commands](#commands)
  8. 1. [Credits](#credits)
  9. 1. [License](#license)
  10. ## Installation
  11. If you use [Vundle](https://github.com/gmarik/vundle), add the following line to your `~/.vimrc`:
  12. ```vim
  13. Plugin 'godlygeek/tabular'
  14. Plugin 'plasticboy/vim-markdown'
  15. ```
  16. The `tabular` plugin must come *before* `vim-markdown`.
  17. Then run inside Vim:
  18. ```vim
  19. :so ~/.vimrc
  20. :PluginInstall
  21. ```
  22. If you use [Pathogen](https://github.com/tpope/vim-pathogen), do this:
  23. ```sh
  24. cd ~/.vim/bundle
  25. git clone https://github.com/plasticboy/vim-markdown.git
  26. ```
  27. To install without Pathogen using the Debian [vim-addon-manager](http://packages.qa.debian.org/v/vim-addon-manager.html), do this:
  28. ```sh
  29. git clone https://github.com/plasticboy/vim-markdown.git
  30. cd vim-markdown
  31. sudo make install
  32. vim-addon-manager install markdown
  33. ```
  34. If you are not using any package manager, download the [tarball](https://github.com/plasticboy/vim-markdown/archive/master.tar.gz) and do this:
  35. ```sh
  36. cd ~/.vim
  37. tar --strip=1 -zxf vim-markdown-master.tar.gz
  38. ```
  39. ## Options
  40. ### Disable Folding
  41. Add the following line to your `.vimrc` to disable the folding configuration:
  42. ```vim
  43. let g:vim_markdown_folding_disabled=1
  44. ```
  45. This option only controls Vim Markdown specific folding configuration.
  46. To enable/disable folding use Vim's standard folding configuration.
  47. ```vim
  48. set [no]foldenable
  49. ```
  50. ### Disable Default Key Mappings
  51. Add the following line to your `.vimrc` to disable default key mappings:
  52. ```vim
  53. let g:vim_markdown_no_default_key_mappings=1
  54. ```
  55. You can also map them by yourself with `<Plug>` mappings.
  56. ### Syntax extensions
  57. The following options control which syntax extensions will be turned on. They are off by default.
  58. #### LaTeX math
  59. Used as `$x^2$`, `$$x^2$$`, escapable as `\$x\$` and `\$\$x\$\$`.
  60. ```vim
  61. let g:vim_markdown_math=1
  62. ```
  63. #### YAML frontmatter
  64. Highlight YAML frontmatter as used by Jekyll:
  65. ```vim
  66. let g:vim_markdown_frontmatter=1
  67. ```
  68. ## Mappings
  69. The following work on normal and visual modes:
  70. - `gx`: open the link under the cursor in the same browser as the standard `gx` command. `<Plug>Markdown_OpenUrlUnderCursor`
  71. The standard `gx` is extended by allowing you to put your cursor anywhere inside a link.
  72. For example, all the following cursor positions will work:
  73. [Example](http://example.com)
  74. ^ ^ ^^ ^ ^
  75. 1 2 34 5 6
  76. <http://example.com>
  77. ^ ^ ^
  78. 1 2 3
  79. Known limitation: does not work for links that span multiple lines.
  80. - `]]`: go to next header. `<Plug>Markdown_MoveToNextHeader`
  81. - `[[`: go to previous header. Contrast with `]c`. `<Plug>Markdown_MoveToPreviousHeader`
  82. - `][`: go to next sibling header if any. `<Plug>Markdown_MoveToNextSiblingHeader`
  83. - `[]`: go to previous sibling header if any. `<Plug>Markdown_MoveToPreviousSiblingHeader`
  84. - `]c`: go to Current header. `<Plug>Markdown_MoveToCurHeader`
  85. - `]u`: go to parent header (Up). `<Plug>Markdown_MoveToParentHeader`
  86. This plugin follows the recommended Vim plugin mapping interface, so to change the map `]u` to `asdf`, add to your `.vimrc`:
  87. map asdf <Plug>Markdown_MoveToParentHeader
  88. To disable a map use:
  89. map <Plug> <Plug>Markdown_MoveToParentHeader
  90. ## Commands
  91. - `:HeaderDecrease`:
  92. Decrease level of all headers in buffer: `h2` to `h1`, `h3` to `h2`, etc.
  93. If range is given, only operate in the range.
  94. If an `h1` would be decreased, abort.
  95. For simplicity of implementation, Setex headers are converted to Atx.
  96. - `:HeaderIncrease`: Analogous to `:HeaderDecrease`, but increase levels instead.
  97. - `:SetexToAtx`:
  98. Convert all Setex style headers in buffer to Atx.
  99. If a range is given, e.g. hit `:` from visual mode, only operate on the range.
  100. - `:TableFormat`: Format the table under the cursor [like this](http://www.cirosantilli.com/markdown-styleguide/#tables).
  101. Requires [Tabular](https://github.com/godlygeek/tabular).
  102. The input table *must* already have a separator line as the second line of the table.
  103. That line only needs to contain the correct pipes `|`, nothing else is required.
  104. - `:Toc`: create a quickfix vertical window navigable table of contents with the headers.
  105. Hit `<Enter>` on a line to jump to the corresponding line of the markdown file.
  106. - `:Toch`: Same as `:Toc` but in an horizontal window.
  107. - `:Toct`: Same as `:Toc` but in a new tab.
  108. - `:Tocv`: Same as `:Toc` for symmetry with `:Toch` and `Tocv`.
  109. ## Credits
  110. The main contributors of vim-markdown are:
  111. - **Ben Williams** (A.K.A. **plasticboy**). The original developer of vim-markdown. [Homepage](http://plasticboy.com/).
  112. If you feel that your name should be on this list, please make a pull request listing your contributions.
  113. ## License
  114. The MIT License (MIT)
  115. Copyright (c) 2012 Benjamin D. Williams
  116. Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
  117. The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
  118. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.