forked from swagger-api/swagger-js
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Cakefile
56 lines (46 loc) · 1.89 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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
fs = require 'fs'
{spawn, exec} = require 'child_process'
mergeFiles =(inputFiles, outputFile, minify=false) ->
# Add directories and extensions to filenames
inputFiles = for f in inputFiles
"src/#{f}.coffee"
outputFile = "lib/#{outputFile}.coffee"
remaining = inputFiles.length
appContents = new Array
for inputFile, index in inputFiles then do (inputFile, index) ->
fs.readFile inputFile, 'utf8', (err, fileContents) ->
throw err if err
appContents[index]= fileContents
process() if --remaining is 0
process = ->
fs.writeFile outputFile, appContents.join('\n\n'), 'utf8', (err) ->
throw err if err
exec "coffee --compile #{outputFile}", (err, stdout, stderr) ->
throw err if err
# console.log stdout + stderr
fs.unlink outputFile, (err) ->
throw err if err
js = outputFile.replace /coffee$/, 'js'
console.log js
task 'bake', 'Compile and concatenate CoffeeScript files to JavaScript', ->
console.log ' : Compiling...'
coffee = spawn 'coffee', ['-c', '-o', 'lib', 'src']
coffee.stderr.on 'data', (data) ->
process.stderr.write data.toString()
coffee.stdout.on 'data', (data) ->
print data.toString()
coffee.on 'exit', (code) ->
callback?() if code is 0
task 'watch', 'Automatically recompile CoffeeScript files to JavaScript', ->
coffee = spawn 'coffee', ['-cw', '-o', 'lib', 'src']
coffee.stdout.on 'data', (data) -> console.log data.toString().trim()
task 'dev', "Open source files, run spec in browser, and watch for changes", ->
exec "$EDITOR ."
exec "open api-listing-spec.html"
exec "open execution-spec.html"
exec "open http-spec.html"
exec "open operation-spec.html"
exec "open request-spec.html"
exec "open model-spec.html"
coffee = spawn 'coffee', ['-cw', '-o', 'lib', 'src']
coffee.stdout.on 'data', (data) -> console.log data.toString().trim()