Mailspring/app/build/tasks/docs-build-task.js

178 lines
5.4 KiB
JavaScript
Raw Normal View History

2017-01-28 03:42:53 +08:00
const path = require('path');
const rimraf = require('rimraf');
const fs = require('fs-plus');
var fs_extra = require('fs-extra');
const donna = require('donna');
const joanna = require('joanna');
const tello = require('tello');
module.exports = function(grunt) {
2017-09-27 02:33:08 +08:00
let { cp, mkdir, rm } = grunt.config('taskHelpers');
2017-01-28 03:42:53 +08:00
let getClassesToInclude = function() {
let modulesPath = path.resolve(__dirname, '..', '..', 'internal_packages');
let classes = {};
fs.traverseTreeSync(modulesPath, function(modulePath) {
// Don't traverse inside dependencies
2017-09-27 02:33:08 +08:00
if (modulePath.match(/node_modules/g)) {
return false;
}
2017-01-28 03:42:53 +08:00
// Don't traverse blacklisted packages (that have docs, but we don't want to include)
2017-09-27 02:33:08 +08:00
if (path.basename(modulePath) !== 'package.json') {
return true;
}
if (!fs.isFileSync(modulePath)) {
return true;
}
2017-01-28 03:42:53 +08:00
let apiPath = path.join(path.dirname(modulePath), 'api.json');
if (fs.isFileSync(apiPath)) {
Object.assign(classes, grunt.file.readJSON(apiPath).classes);
2017-01-28 03:42:53 +08:00
}
return true;
});
return classes;
};
let sortClasses = function(classes) {
let sortedClasses = {};
for (let className of Array.from(Object.keys(classes).sort())) {
sortedClasses[className] = classes[className];
}
return sortedClasses;
};
return grunt.registerTask('docs-build', 'Builds the API docs in src', function() {
2017-09-27 02:33:08 +08:00
grunt.log.writeln('Time to build the docs!');
2017-01-28 03:42:53 +08:00
let done = this.async();
let classDocsOutputDir = grunt.config.get('classDocsOutputDir');
let cjsxOutputDir = path.join(classDocsOutputDir, 'temp-cjsx');
return rimraf(cjsxOutputDir, function() {
let api;
fs.mkdir(cjsxOutputDir);
let srcPath = path.resolve(__dirname, '..', '..', 'src');
2017-09-27 02:33:08 +08:00
const blacklist = ['/K2/', 'legacy-edgehill-api', 'edgehill-api'];
2017-01-28 03:42:53 +08:00
let in_blacklist = function(file) {
for (var i = 0; i < blacklist.length; i++) {
if (file.indexOf(blacklist[i]) >= 0) {
return true;
}
}
return false;
};
fs.traverseTreeSync(srcPath, function(file) {
if (in_blacklist(file)) {
2017-09-27 02:33:08 +08:00
console.log('Skipping ' + file);
2017-01-28 03:42:53 +08:00
// Skip K2
2017-09-27 02:33:08 +08:00
} else if (path.extname(file) === '.jsx') {
console.log('Transforming ' + file);
2017-01-28 03:42:53 +08:00
let fileStr = grunt.file.read(file);
2017-09-27 02:33:08 +08:00
let transformed = require('babel-core').transform(fileStr, {
plugins: ['transform-react-jsx', 'transform-class-properties'],
presets: ['react', 'electron'],
2017-01-28 03:42:53 +08:00
});
2017-09-27 02:33:08 +08:00
grunt.file.write(
path.join(cjsxOutputDir, path.basename(file).slice(0, -3 || undefined) + 'js'),
transformed.code
);
} else if (path.extname(file) === '.es6') {
2017-09-27 02:33:08 +08:00
console.log(file);
2017-01-28 03:42:53 +08:00
let fileStr = grunt.file.read(file);
2017-09-27 02:33:08 +08:00
let transformed = require('babel-core').transform(fileStr, {
plugins: ['transform-class-properties', 'transform-function-bind'],
presets: ['react', 'electron'],
2017-01-28 03:42:53 +08:00
});
if (transformed.code.indexOf('class ') > 0) {
2017-09-27 02:33:08 +08:00
grunt.log.writeln('Found class in file: ' + file);
2017-01-28 03:42:53 +08:00
2017-09-27 02:33:08 +08:00
grunt.file.write(
path.join(cjsxOutputDir, path.basename(file).slice(0, -3 || undefined) + 'js'),
transformed.code
);
2017-01-28 03:42:53 +08:00
}
} else if (path.extname(file) === '.js') {
2017-01-28 03:42:53 +08:00
let dest_path = path.join(cjsxOutputDir, path.basename(file));
2017-09-27 02:33:08 +08:00
console.log('Copying ' + file + ' to ' + dest_path);
2017-01-28 03:42:53 +08:00
fs_extra.copySync(file, dest_path);
}
return true;
});
2017-09-27 02:33:08 +08:00
grunt.log.ok('Done transforming, starting donna extraction');
grunt.log.writeln('cjsxOutputDir: ' + cjsxOutputDir);
2017-01-28 03:42:53 +08:00
let metadata = donna.generateMetadata([cjsxOutputDir]);
grunt.log.ok('---- Done with Donna (cjsx metadata)----');
// DEBUG
// Use to check individual files
2017-09-27 02:33:08 +08:00
var js_files = [];
2017-01-28 03:42:53 +08:00
fs.traverseTreeSync(cjsxOutputDir, function(file) {
if (path.extname(file) === '.js') {
2017-09-27 02:33:08 +08:00
console.log('testing joanna on ' + file);
let meta = joanna([file]);
console.log('testing tello on ' + file);
tello.digest(meta);
console.log('passed');
2017-01-28 03:42:53 +08:00
}
});
fs.traverseTreeSync(cjsxOutputDir, function(file) {
if (path.extname(file) === '.js') {
2017-09-27 02:33:08 +08:00
js_files.push(file.toString());
2017-01-28 03:42:53 +08:00
}
});
console.log(js_files);
grunt.log.ok('---- Starting Jonna (jsx metadata)----');
let jsx_metadata = joanna(js_files);
grunt.log.ok('---- Done with Joanna (jsx metadata)----');
Object.assign(metadata[0].files, jsx_metadata.files);
console.log(metadata[0]);
grunt.file.write('/tmp/metadata.json', JSON.stringify(metadata, null, 2));
try {
api = tello.digest(metadata);
} catch (e) {
2017-09-27 02:33:08 +08:00
console.log(e);
2017-01-28 03:42:53 +08:00
console.log(e.stack);
2017-09-27 02:33:08 +08:00
console.log(metadata);
2017-01-28 03:42:53 +08:00
return;
}
console.log('---- Done with Tello ----');
Object.assign(api.classes, getClassesToInclude());
2017-01-28 03:42:53 +08:00
2017-09-27 02:33:08 +08:00
console.log(api.classes);
2017-01-28 03:42:53 +08:00
api.classes = sortClasses(api.classes);
2017-09-27 02:33:08 +08:00
console.log(api.classes);
2017-01-28 03:42:53 +08:00
let apiJson = JSON.stringify(api, null, 2);
let apiJsonPath = path.join(classDocsOutputDir, 'api.json');
grunt.file.write(apiJsonPath, apiJson);
return done();
});
});
};