generator-begcode
Version:
Spring Boot + Angular/React/Vue in one handy generator
55 lines (54 loc) • 2.3 kB
JavaScript
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();
});
};