0.0.1 • Published 9 years ago
unlit v0.0.1
unlit
A quick a dirty utility to remove literature from markdown files with code annotations. Think as the reverse of docco. You write a markdown file and it extracts the code.
unlit README.md > index.jsThe Code
This is the source code of unlit itself.
Dependencies
Basically it uses gfm-code-blocks to get the code blocks from markdown:
var fs = require('fs')
var path = require('path')
var codeBlocks = require('gfm-code-blocks')Streaming
The stream/pipe stuff is from https://github.com/substack/stream-handbook#pipe:
var Readable = require('stream').Readable
var rs = Readable()Test if the given file name exists:
var filename = path.join(process.cwd(), process.argv[2])
try {
  var stats = fs.lstatSync(filename)
  if (stats.isDirectory()) {
    console.log('Te specified file ' + filename + ' its a directory.')
    process.exit()
  }
} catch (e) {
  console.log('File ' + filename + ' not found.', e)
  process.exit()
}Read the file and push to the stdout:
rs._read = function () {
  var content = fs.readFileSync(filename)
  codeBlocks(content.toString()).forEach(function (block) {
    if (block.lang === 'js') rs.push(block.code + '\n')
  })
  rs.push('\n')
  rs.push(null)
}
rs.pipe(process.stdout)License
MIT
0.0.1
9 years ago