closure-plugin.js — react Source File
Architecture documentation for closure-plugin.js, a javascript file in the react codebase.
Entity Profile
Relationship Graph
Source Code
'use strict';
const ClosureCompiler = require('google-closure-compiler').compiler;
const {promisify} = require('util');
const fs = require('fs');
const tmp = require('tmp');
const writeFileAsync = promisify(fs.writeFile);
function compile(flags) {
return new Promise((resolve, reject) => {
const closureCompiler = new ClosureCompiler(flags);
closureCompiler.run(function (exitCode, stdOut, stdErr) {
if (!stdErr) {
resolve(stdOut);
} else {
reject(new Error(stdErr));
}
});
});
}
module.exports = function closure(flags = {}) {
return {
name: 'scripts/rollup/plugins/closure-plugin',
async renderChunk(code, chunk, options) {
const inputFile = tmp.fileSync();
// Tell Closure what JS source file to read, and optionally what sourcemap file to write
const finalFlags = {
...flags,
js: inputFile.name,
};
await writeFileAsync(inputFile.name, code, 'utf8');
const compiledCode = await compile(finalFlags);
inputFile.removeCallback();
return {code: compiledCode};
},
};
};
Domain
Subdomains
Source
Frequently Asked Questions
What does closure-plugin.js do?
closure-plugin.js is a source file in the react codebase, written in javascript. It belongs to the BabelCompiler domain, Optimization subdomain.
What functions are defined in closure-plugin.js?
closure-plugin.js defines 2 function(s): compile, module.
Where is closure-plugin.js in the architecture?
closure-plugin.js is located at scripts/rollup/plugins/closure-plugin.js (domain: BabelCompiler, subdomain: Optimization, directory: scripts/rollup/plugins).
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free