diff --git a/docsrc/gendocs.js b/docsrc/gendocs.js new file mode 100644 index 0000000000..03309cd65e --- /dev/null +++ b/docsrc/gendocs.js @@ -0,0 +1,109 @@ +/*global require,process,GLOBAL*/ +/*jslint nomen: true*/ + + +var CONSTANTS = { + DIAGRAM_WIDTH: 800, + DIAGRAM_HEIGHT: 500 + }; + +GLOBAL.window = GLOBAL.window || {}; // nomnoml expects window to be defined +(function () { + "use strict"; + + var fs = require("fs"), + mkdirp = require("mkdirp"), + path = require("path"), + glob = require("glob"), + showdown = require("github-flavored-markdown"), + split = require("split"), + stream = require("stream"), + nomnoml = require('nomnoml'), + Canvas = require('canvas'), + options = require("minimist")(process.argv.slice(2)); + + function renderNomnoml(source, target) { + var canvas = + new Canvas(CONSTANTS.DIAGRAM_WIDTH, CONSTANTS.DIAGRAM_HEIGHT); + nomnoml.draw(canvas, source, 1.0); + canvas.pngStream().pipe(fs.createWriteStream(target)); + } + + function nomnomlifier(outputDirectory, prefix) { + var transform = new stream.Transform({ objectMode: true }), + isBuilding = false, + counter = 1, + outputPath, + source = ""; + + transform._transform = function (chunk, encoding, done) { + if (isBuilding) { + if (chunk.trim().indexOf("```nomnoml") === 0) { + var outputFilename = prefix + '-' + counter + '.png'; + outputPath = path.join(outputDirectory, outputFilename); + this.push([ + "\n![Diagram ", + counter, + "](", + outputFilename, + ")\n\n" + ].join("")); + isBuilding = true; + source = ""; + } else { + // Otherwise, pass through + this.push(chunk); + } + } else { + if (chunk.trim() === "```") { + // End nomnoml + renderNomnoml(source, outputPath); + isBuilding = false; + } else { + source += chunk; + } + } + }; + + return transform; + } + + function concat() { + + } + + function gfmifier() { + var transform = new stream.Transform({ objectMode: true }), + markdown = ""; + transform._transform = function (chunk, encoding, done) { + markdown += chunk; + }; + transform._flush = function () { + this.push(markdown); + }; + return transform; + } + + options['in'] = options['in'] || options.i; + options.out = options.out || options.o; + + glob(options['in'] + "/**/*.md", {}, function (err, files) { + files.forEach(function (file) { + var destination = file.replace(options['in'], options.out) + .replace(/md$/, "html"), + destPath = path.dirname(destination), + prefix = path.basename(destination).replace(/\.html$/, ""); + + mkdirp(destPath, function (err) { + fs.createReadStream(file, { encoding: 'utf8' }) + .pipe(split()) + .pipe(nomnomlifier(destPath, prefix)) + .pipe(gfmifier()) + .pipe(fs.createWriteStream(destination, { + encoding: 'utf8' + })); + }); + }); + }); + +}()); diff --git a/docsrc/guide/index.md b/docsrc/guide/index.md new file mode 100644 index 0000000000..0f72139a24 --- /dev/null +++ b/docsrc/guide/index.md @@ -0,0 +1,3 @@ +# Hello, world! + +This is a placeholder for the developer guide. diff --git a/docsrc/index.html b/docsrc/index.html new file mode 100644 index 0000000000..23e92c21cb --- /dev/null +++ b/docsrc/index.html @@ -0,0 +1,33 @@ + + + + + + Open MCT Web Documentation + + + API + Developer Guide + Architecture Overview + + diff --git a/package.json b/package.json index 1216935f21..350bc7faa3 100644 --- a/package.json +++ b/package.json @@ -16,13 +16,19 @@ "karma-jasmine": "^0.1.5", "karma-phantomjs-launcher": "^0.1.4", "karma-requirejs": "^0.2.2", - "requirejs": "^2.1.17" + "requirejs": "^2.1.17", + "github-flavored-markdown": ">= 1.0.0", + "glob": ">= 3.0.0", + "split": "^1.0.0", + "mkdirp": "^0.5.1", + "nomnoml": "^0.0.3", + "canvas": "^1.2.7" }, "scripts": { "start": "node app.js", "test": "karma start --single-run", "jshint": "jshint platform example || exit 0", - "jsdoc": "jsdoc -c jsdoc.json -r -d docs" + "jsdoc": "jsdoc -c jsdoc.json -r -d docs/api" }, "repository": { "type": "git",