UNPKG

@linaria/utils

Version:

Blazing fast zero-runtime CSS in JS library

153 lines (150 loc) 4.69 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.createFileReporter = void 0; var _fs = require("fs"); var _path = _interopRequireDefault(require("path")); var _EventEmitter = require("../EventEmitter"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } /* eslint-disable no-console */ const workingDir = process.cwd(); function replacer(_key, value) { if (typeof value === 'string' && _path.default.isAbsolute(value)) { return _path.default.relative(workingDir, value); } if (value instanceof Map) { return Array.from(value.entries()).reduce((obj, [k, v]) => { const key = replacer(k, k); return { ...obj, [key]: replacer(key, v) }; }, {}); } return value; } function printTimings(timings, startedAt, sourceRoot) { if (timings.size === 0) { return; } console.log(`\nTimings:`); console.log(` Total: ${(performance.now() - startedAt).toFixed()}ms`); Array.from(timings.entries()).forEach(([label, byLabel]) => { console.log(`\n By ${label}:`); const array = Array.from(byLabel.entries()); // array.sort(([, a], [, b]) => b - a); array.sort(([a], [b]) => a.localeCompare(b)).forEach(([value, time]) => { const name = value.startsWith(sourceRoot) ? _path.default.relative(sourceRoot, value) : value; console.log(` ${name}: ${time}ms`); }); }); } const writeJSONl = (stream, data) => { stream.write(`${JSON.stringify(data, replacer)}\n`); }; const createFileReporter = (options = false) => { if (!options || !options.dir) { return { emitter: _EventEmitter.EventEmitter.dummy, onDone: () => {} }; } const reportFolder = (0, _fs.existsSync)(options.dir) ? options.dir : (0, _fs.mkdirSync)(options.dir, { recursive: true }); if (!reportFolder) { throw new Error(`Could not create directory ${options.dir}`); } const actionStream = (0, _fs.createWriteStream)(_path.default.join(options.dir, 'actions.jsonl')); const dependenciesStream = (0, _fs.createWriteStream)(_path.default.join(options.dir, 'dependencies.jsonl')); const entrypointStream = (0, _fs.createWriteStream)(_path.default.join(options.dir, 'entrypoint.jsonl')); const startedAt = performance.now(); const timings = new Map(); const addTiming = (label, key, value) => { if (!timings.has(label)) { timings.set(label, new Map()); } const forLabel = timings.get(label); forLabel.set(key, Math.round((forLabel.get(key) || 0) + value)); }; const processDependencyEvent = ({ file, only, imports, fileIdx }) => { writeJSONl(dependenciesStream, { file, only, imports, fileIdx }); }; const processSingleEvent = meta => { if (meta.type === 'dependency') { processDependencyEvent(meta); } }; const startTimes = new Map(); const onEvent = (meta, type) => { if (type === 'single') { processSingleEvent(meta); return; } if (type === 'start') { Object.entries(meta).forEach(([label, value]) => { startTimes.set(`${label}\0${value}`, performance.now()); }); } else { Object.entries(meta).forEach(([label, value]) => { const startTime = startTimes.get(`${label}\0${value}`); if (startTime) { addTiming(label, String(value), performance.now() - startTime); } }); } }; let actionId = 0; const onAction = (...args) => { if ((0, _EventEmitter.isOnActionStartArgs)(args)) { const [, timestamp, type, idx, entrypointRef] = args; writeJSONl(actionStream, { actionId, entrypointRef, idx, startedAt: timestamp, type }); // eslint-disable-next-line no-plusplus return actionId++; } const [result, timestamp, id, isAsync, error] = args; writeJSONl(actionStream, { actionId: id, error, finishedAt: timestamp, isAsync, result: `${result}ed` }); return id; }; const onEntrypointEvent = (emitterId, timestamp, event) => { entrypointStream.write(`${JSON.stringify([emitterId, timestamp, event])}\n`); }; const emitter = new _EventEmitter.EventEmitter(onEvent, onAction, onEntrypointEvent); return { emitter, onDone: sourceRoot => { if (options.print) { printTimings(timings, startedAt, sourceRoot); console.log('\nMemory usage:', process.memoryUsage()); } actionStream.end(); dependenciesStream.end(); timings.clear(); } }; }; exports.createFileReporter = createFileReporter; //# sourceMappingURL=fileReporter.js.map