UNPKG

documentation

Version:
64 lines (60 loc) 2.48 kB
'use strict'; const mdeps = require('module-deps-sortable'); const path = require('path'); const babelify = require('babelify'); const concat = require('concat-stream'); const moduleFilters = require('../module_filters'); const smartGlob = require('../smart_glob.js'); /** * Returns a readable stream of dependencies, given an array of entry * points and an object of options to provide to module-deps. * * This stream requires filesystem access, and thus isn't suitable * for a browser environment. * * @param indexes paths to entry files as strings * @param config optional options passed * @returns results */ function dependencyStream(indexes, config) { const md = mdeps({ /** * Determine whether a module should be included in documentation * @param {string} id path to a module * @returns {boolean} true if the module should be included. */ filter: id => !!config.external || moduleFilters.internalOnly(id), extensions: [].concat(config.requireExtension || []).map(ext => '.' + ext.replace(/^\./, '')).concat(['.mjs', '.js', '.json', '.es6', '.jsx']), transform: [babelify.configure({ sourceMap: false, compact: false, presets: [require('babel-preset-env'), require('babel-preset-stage-0'), require('babel-preset-react')], plugins: [require('babel-plugin-transform-decorators-legacy').default, // Required to support webpack's System.import // https://github.com/documentationjs/documentation/issues/578 require('babel-plugin-system-import-transformer').default] })], postFilter: moduleFilters.externals(indexes, config) }); smartGlob(indexes, config.parseExtension).forEach(index => { md.write(path.resolve(index)); }); md.end(); return new Promise((resolve, reject) => { md.once('error', reject); md.pipe(concat(function (inputs) { resolve(inputs.filter(input => // At this point, we may have allowed a JSON file to be caught by // module-deps, or anything else allowed by requireExtension. // otherwise module-deps would complain about // it not being found. But Babel can't parse JSON, so we filter non-JavaScript // files away. config.parseExtension.indexOf(path.extname(input.file).replace(/^\./, '')) > -1).map(input => { // remove source file, since it's transformed anyway delete input.source; return input; })); })); }); } module.exports = dependencyStream;