Reed Esau 7fdb480cc1 Merge pull request #5 from mattly/bug/init_textwidth
Default b:max_textwidth to -1
2014-01-28 19:12:36 -08:00
2014-01-28 12:28:46 -02:00
2014-01-06 01:33:15 -07:00
2014-01-04 18:31:56 -07:00

vim-pencil

Rethinking Vim as a tool for writers



demo


Features

The pencil plugin aspires to make Vim as powerful a tool for writers as it is for coders by focusing narrowly on the handful of tweaks needed to smooth the path to writing prose.

  • For editing files in text, markdown, textile, and other prose-oriented file types
  • Agnostic on soft line wrap versus hard line breaks, supporting both
  • Auto-detects wrap mode via modeline and sampling
  • Adjusts navigation key mappings to suit the wrap mode
  • Creates undo points on common punctuation
  • When using hard line breaks, enables autoformat while inserting text
  • Buffer-scoped configuration (leaves your global settings alone)
  • Pure Vimscript with no dependencies

Need spell-check and other features? Vim is about customization. To complete your editing environment, learn to configure Vim and draw upon its rich ecosystem of plugins.

Why use Vim for writing?

With plenty of word processing apps available, including those that specifically cater to writers, why use a programmers editor like Vim for writing?

There are good reasons NOT to use Vim for writing:

  • Primitive in certain respects (no WYSIWYG or proportionally spaced characters, e.g.)
  • A modal editor with a steep learning curve
  • Time and effort to configure to your needs

But Vim offers a unique editing environment not matched by other writing tools:

  • Hands rest in a neutral home position, only rarely straying to reach for mouse, track pad, or arrow keys
  • Minimal chording, with many mnemonic-friendly commands
  • Sophisticated capabilities for navigating and manipulating text
  • Highly configurable to suit your needs, with many great plugins available

Installation

Install using Pathogen, Vundle, Neobundle, or your favorite Vim package manager.

For those new to Vim: before installing this plugin, you should first work through one of the many tutorials available to get comfortable with the basics of Vim.

Configuration

Hard line breaks or soft line wrap?

Coders will have the most experience with the former, and writers the latter. But whatever your background, chances are that you must contend with both conventions. This plugin doesn't force you to choose a side—you can configure each buffer independently.

In most cases you can set a default to suit your preference and let auto-detection figure out what to do. Add to your .vimrc:

" standard vim command to enable loading the plugin files 
" (and their indent support) for specific file types.
" It may already be in your .vimrc!
filetype plugin indent on

let g:pencil#wrapModeDefault = 'hard'   " or 'soft'

augroup pencil
  autocmd!
  autocmd FileType markdown call pencil#init()
  autocmd FileType textile call pencil#init()
  autocmd FileType text call pencil#init({'wrap': 'hard'})
augroup END

In the example above, for files of type markdown and textile, this plugin will auto-detect the line wrap approach, with hard as the default. But for files of type text, it will always initialize with hard line break mode.

Commands

Because auto-detect might not work as intended, you can invoke a command to set the behavior for the current buffer:

  • SoftPencil - enable soft line wrap mode
  • HardPencil - enable hard line break mode
  • DropPencil - removes navigation mappings and restores buffer to global settings
  • TogglePencil - if on, turns off; if off, enables with detection

Optionally, you can map to keys in your .vimrc:

nnoremap <silent> <leader>ps :SoftPencil<cr>
nnoremap <silent> <leader>ph :HardPencil<cr>
nnoremap <silent> <leader>pd :DropPencil<cr>
nnoremap <silent> <leader>pt :TogglePencil<cr>

Automatic formatting

This autoformat feature affects HardPencil mode only.

When in HardPencil mode, Vims autoformat feature will be enabled by default in Insert mode and can offer many of the same benefits as soft line wrap. But autoformat will cause havoc when editing anything but paragraphs of words, such as a code block or table. In these cases you will need to disable it, at least temporarily, via a command:

  • AutoPencil - enables autoformat
  • ManualPencil - disables autoformat
  • ShiftPencil - toggle to enable if disabled, etc.

Or optionally map to keys in your .vimrc:

nnoremap <silent> <leader>pa :AutoPencil<cr>
nnoremap <silent> <leader>pm :ManualPencil<cr>
nnoremap <silent> <leader>pp :ShiftPencil<cr>

To set the default behavior, add to your .vimrc:

let g:pencil#autoformat = 1      " 0=manual, 1=auto

You can override this default during initialization, as in:

augroup pencil
  autocmd!
  autocmd FileType text call pencil#init({'wrap': 'hard', 'autoformat': 0})
  ...
augroup END

...where by default, files of type text will use hard line endings, but with autoformat disabled.

Manual formatting

Note that you need not rely on autoformat exclusively and can manually reformat paragraphs with standard Vim commands:

  • gqip or gwip - format current paragraph
  • vipJ - unformat current paragraph
  • ggVGgq or :g/^/norm gqq - format all paragraphs in buffer
  • :%norm vipJ - unformat all paragraphs in buffer

Optionally, you can map these sequences to underutilized keys in your .vimrc:

nnoremap <silent> Q gwip
nnoremap <silent> K vipJ
nnoremap <silent> <leader>Q ggVGgq
nnoremap <silent> <leader>K :%norm vipJ<cr>

Default textwidth

You can configure the textwidth to be used in HardPencil mode when no textwidth is set globally, locally, or available via modeline. It defaults to 74, but you can change that value in your .vimrc:

let g:pencil#textwidth = 74

Sentence spacing

By default, when formatting only one space will be inserted after a period(.), exclamation point(!), or question mark(?). You can change this default:

let g:pencil#joinspaces = 0     " 0=one_space, 1=two_spaces

Cursor wrap

By default, h/l and the left/right cursor keys will move to the previous/next line after reaching first/last character in a line with a hard break. If you wish to retain the default Vim behavior, set the cursorwrap value to 0 in your .vimrc:

let g:pencil#cursorwrap = 1     " 0=disable, 1=enable

Auto-detecting wrap mode

If you didn't explicitly specify a wrap mode during initialization, pencil will attempt to detect it.

It will first look for a textwidth (or tw) specified in a modeline. Failing that, pencil will then sample lines from the start of the file.

Detect via modeline

Will the wrap mode be detected accurately? Maybe. But you can improve its chances by giving pencil an explicit hint.

At the bottom of this document is a odd-looking code:

<!-- vim: set tw=74 :-->

This is an optional modeline that tells Vim to run the following command upon loading the file into a buffer:

:set textwidth=74

It tells pencil to assume hard line breaks, regardless of whether or not soft line wrap is the default editing mode for files of type markdown.

You explicitly specify soft wrap mode by specifying a textwidth of 0:

<!-- vim: set tw=0 :-->

Note that if the modelines feature is disabled (such as for security reasons) the textwidth will still be set by this plugin.

Detect via sampling

If no modeline with a textwidth is found, pencil will sample the initial lines from the file, looking for those excessively-long.

There are two settings you can add to your .vimrc to tweak this behavior.

The maximum number of lines to sample from the start of the file:

let g:pencil#softDetectSample = 20

Set that value to 0 to disable detection via line sampling.

When the number of bytes on a sampled line per exceeds this next value, then pencil assumes soft line wrap.

let g:pencil#softDetectThreshold = 130

If no such lines found, pencil falls back to the default mentioned earlier:

let g:pencil#wrapModeDefault = 'hard'   " or 'soft'

See also

If you find this plugin useful, you may want to check out these others by @reedes:

Future development

If youve spotted a problem or have an idea on improving this plugin, please post it to the github project issue page.

<!-- vim: set tw=74 :-->
Description
Languages
Vim Script 100%