forked from jashkenas/docco
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Cakefile
38 lines (33 loc) · 1.48 KB
/
Cakefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
{spawn, exec} = require 'child_process'
fs = require 'fs'
path = require 'path'
option '-p', '--prefix [DIR]', 'set the installation prefix for `cake install`'
option '-w', '--watch', 'continually build the docco library'
option '-l', '--layout [LAYOUT]', 'specify the layout for Docco\'s docs'
task 'build', 'build the docco library', (options) ->
coffee = spawn 'coffee', ['-c' + (if options.watch then 'w' else ''), '.']
coffee.stdout.on 'data', (data) -> console.log data.toString().trim()
coffee.stderr.on 'data', (data) -> console.log data.toString().trim()
task 'install', 'install the `docco` command into /usr/local (or --prefix)', (options) ->
base = options.prefix or '/usr/local'
lib = base + '/lib/docco'
exec([
'mkdir -p ' + lib + ' ' + base + '/bin'
'cp -rf bin README resources ' + lib
'ln -sf ' + lib + '/bin/docco ' + base + '/bin/docco'
].join(' && '), (err, stdout, stderr) ->
if err then console.error stderr
)
task 'doc', 'rebuild the Docco documentation', (options) ->
layout = options.layout or 'linear'
exec([
"bin/docco --layout #{layout} docco.litcoffee"
"sed \"s/docco.css/resources\\/#{layout}\\/docco.css/\" < docs/docco.html > index.html"
'rm -r docs'
].join(' && '), (err) ->
throw err if err
)
task 'loc', 'count the lines of code in Docco', ->
code = fs.readFileSync('docco.litcoffee').toString()
lines = code.split('\n').filter (line) -> /^ /.test line
console.log "Docco LOC: #{lines.length}"