UNPKG

generator-begcode

Version:

Spring Boot + Angular/React/Vue in one handy generator

55 lines (54 loc) 2.3 kB
import { passthrough } from 'p-transform'; import { isFileStateModified } from 'mem-fs-editor/state'; import { Minimatch } from 'minimatch'; import { Piscina } from 'piscina'; const minimatch = new Minimatch('**/{.prettierrc**,.prettierignore}'); export const isPrettierConfigFilePath = (filePath) => minimatch.match(filePath); export const isPrettierConfigFile = (file) => isPrettierConfigFilePath(file.path); export const createPrettierTransform = async function (options = {}) { const pool = new Piscina({ maxThreads: 1, filename: new URL('./prettier-worker.js', import.meta.url).href, }); const { ignoreErrors = false, extensions = '*', prettierPackageJson, prettierJava, prettierProperties, prettierOptions } = options; const globExpression = extensions.includes(',') ? `**/*.{${extensions}}` : `**/*.${extensions}`; const minimatch = new Minimatch(globExpression, { dot: true }); return passthrough(async (file) => { if (!minimatch.match(file.path) || !isFileStateModified(file)) { return; } if (file.relative.includes('mobile/uniapp/src/plugin/jweixin-module/index.js') || file.relative.includes('mobile/uniapp/src/uni_modules/') || file.relative.includes('/uview-ui/') || file.relative.includes('.min.js') || file.relative.includes('assets/vendor/') || file.relative.includes('.min.css') || file.relative.includes('assets/vendor/')) { return; } if (!file.contents) { throw new Error(`File content doesn't exist for ${file.relative}`); } const { result, errorMessage } = await pool.run({ relativeFilePath: file.relative, filePath: file.path, fileContents: file.contents.toString('utf8'), prettierOptions, prettierPackageJson, prettierJava, prettierProperties, ignoreErrors, }); if (result) { file.contents = Buffer.from(result); } if (errorMessage) { if (!ignoreErrors) { throw new Error(errorMessage); } this?.log?.warn?.(errorMessage); } }, () => { pool.destroy(); }); };