formd: a markdown formatting tool
npm install -g @seth-brown/formd
If the default location npm installs packages to isn't in your path, you may need to add it to your path. For example:
echo 'export PATH="$HOME/.node/bin:$PATH"' >> ~/.zshrc
Inline Markdown is difficult to read, but useful for writing and editing because the linked text and URLs are adjacent to the words you are writing. For example:
The quick brown [fox](http://en.wikipedia.org/wiki/Fox) jumped over the lazy [dog](http://en.wikipedia.org/wiki/Dog).
Referenced Markdown is awkward while writing because it requires jumping between links within the text and the reference section of the document. However, referenced Markdown is the superior syntax for reading because URLs do not breakup the flow of words or sentences. For example:
The quick brown [fox] jumped over the lazy [dog].
formd provides the best of both worlds by allowing users to quickly toggle Markdown formats between inline while writing and referenced while reading.
formd reads and writes to standard streams, so it can be adapted to a wide-range of user workflows.
formd is a command line tool, but its primary use case is with text editors or in conjunction with system tools like snipper expanders or app launchers. From the command line formd can be used as follows:
To generate referenced Markdown use the -r flag:
formd -r < <(echo "a line of text\na link with a [link]('www.foo.com')")
To generate inline Markdown use the -i flag:
cat my-markdown.md | formd -i
Usage with Text Editors
formd can be integrated with editors like Vim. The easiest option is to call it
directly from within a Vim buffer. For example:
:%! formd -r
An easier approach is to use a function to execute
formd and return the cursor
back to it's original position within the buffer.
" a function to execute `formd` and return the cursor back " to it's original position within the buffer. " This script assumes `formd` is in your path. function! Formd(option) :let save_view = winsaveview() :let flag = a:option :if flag == "-i" :%! formd -i :else :%! formd -r :endif :call winrestview(save_view) endfunction " formd mappings nmap <leader>fr :call Formd("-r")<CR> nmap <leader>fi :call Formd("-i")<CR>
Usage with App Launchers
formd can be invoked with app launchers like Alfred. Two Alfred workflows are provided in the repo at
system/alfred/. These workflows take the contents from the clipboard and covert them to either inline or reference markdown and then paste the converted text into the front most application.
- 1.0.0 Initial release
- 2.0.0 Ported library to Typescript/Node