1
1
mirror of https://github.com/primer/css.git synced 2024-12-01 04:21:12 +03:00
css/docs/lib/parse-doc-comments.js
2018-12-17 15:26:09 -08:00

29 lines
882 B
JavaScript

const each = require('./each')
const START = /<\!-- *%docs *\n/
const SPLIT = /\n *-->/
const END = /<\!-- *%enddocs *-->/
module.exports = function parseDocComments() {
return each((path, file) => {
const str = String(file.contents)
let parts = str.split(START)
if (parts.length > 1) {
// FIXME metadata should either be in frontmatter or %docs comment
if (str.match(/^---/)) {
throw new Error(`Whoops, can't parse doc comments *and* frontmatter!`)
}
// take the part between the start and end
const middle = parts[1].split(END)[0]
// split *that* on the split "marker"
parts = middle.split(SPLIT)
// the part before that is the "frontmatter"
// and everything after that is the actual docs
const [meta, docs] = parts
file.contents = Buffer.from(`---\n${meta}\n---\n${docs}`)
}
})
}