Some checks failed
Test examples / Test Examples (20) (push) Has been cancelled
Test examples / Test Examples (22) (push) Has been cancelled
Lock Threads / action (push) Has been cancelled
Trigger Release / start (push) Has been cancelled
Stale issue handler / stale (push) Has been cancelled
Update Font Data / create-pull-request (push) Has been cancelled
build-and-deploy / deploy-target (push) Has been cancelled
build-and-deploy / build (push) Has been cancelled
build-and-deploy / stable - aarch64-unknown-linux-musl - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-unknown-linux-musl - node@16 (push) Has been cancelled
build-and-deploy / stable - aarch64-unknown-linux-gnu - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-unknown-linux-gnu - node@16 (push) Has been cancelled
build-and-deploy / stable - aarch64-pc-windows-msvc - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-pc-windows-msvc - node@16 (push) Has been cancelled
build-and-deploy / stable - aarch64-apple-darwin - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-apple-darwin - node@16 (push) Has been cancelled
build-and-deploy / build-wasm (nodejs) (push) Has been cancelled
build-and-deploy / build-wasm (web) (push) Has been cancelled
build-and-deploy / Deploy preview tarball (push) Has been cancelled
build-and-deploy / Potentially publish release (push) Has been cancelled
build-and-deploy / publish-turbopack-npm-packages (push) Has been cancelled
build-and-deploy / Deploy examples (push) Has been cancelled
build-and-deploy / thank you, build (push) Has been cancelled
build-and-deploy / Upload Turbopack Bytesize metrics to Datadog (push) Has been cancelled
Rspack Next.js development integration tests / Rspack integration tests (push) Has been cancelled
Rspack Next.js production integration tests / Rspack integration tests (push) Has been cancelled
Turbopack Next.js development integration tests / Next.js integration tests (push) Has been cancelled
Turbopack Next.js production integration tests / Next.js integration tests (push) Has been cancelled
Update Rspack test manifest / Update and upload Rspack development test manifest (push) Has been cancelled
Update Rspack test manifest / Update and upload Rspack production test manifest (push) Has been cancelled
Upload bundler test manifests to areweturboyet.com / Upload test results (push) Has been cancelled
Update React / create-pull-request (push) Has been cancelled
test-e2e-project-reset-cron / reset-test-project (push) Has been cancelled
Notify about the top 15 issues/PRs/feature requests (most reacted) in the last 90 days / run (push) Has been cancelled
65 lines
1.6 KiB
TypeScript
65 lines
1.6 KiB
TypeScript
import fs from "fs";
|
|
import chokidar from "chokidar";
|
|
|
|
/**
|
|
* Run watch mode, watching on @var rootPath
|
|
*/
|
|
export function watchItems(rootPath: string, cb: () => void): void {
|
|
chokidar
|
|
.watch(rootPath, { ignoreInitial: true, awaitWriteFinish: true })
|
|
.on("add", cb)
|
|
.on("unlink", cb);
|
|
}
|
|
|
|
/**
|
|
* Using @var path find all files recursively and generate output using @var resolveItem by calling it for each file
|
|
* @param path plugins path
|
|
* @param resolveItem will resolve item in required data format
|
|
* @param cb will be called when new item is found
|
|
* @param fileFormat Matches specific files
|
|
* @returns {Item[]} items
|
|
*/
|
|
export function getItems<Item>(settings: {
|
|
path: string;
|
|
resolveItem: (path: string, name: string) => Item;
|
|
cb?: (name: string) => void;
|
|
fileFormat?: RegExp;
|
|
}): Item[] {
|
|
const {
|
|
path,
|
|
resolveItem,
|
|
cb,
|
|
fileFormat = new RegExp(/(.+)(?<!\.d)\.[jt]sx?$/),
|
|
} = settings;
|
|
const items: Item[] = [];
|
|
const folders: fs.Dirent[] = [];
|
|
|
|
if (!fs.existsSync(path)) return [];
|
|
|
|
fs.readdirSync(path, { withFileTypes: true }).forEach((item) => {
|
|
if (item.isDirectory()) {
|
|
folders.push(item);
|
|
}
|
|
|
|
if (fileFormat.test(item.name)) {
|
|
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
|
const name = item.name.match(fileFormat)![1];
|
|
items.push(resolveItem(path, name));
|
|
cb && cb(name);
|
|
}
|
|
});
|
|
|
|
for (const folder of folders) {
|
|
items.push(
|
|
...getItems<Item>({
|
|
path: `${path}/${folder.name}`,
|
|
resolveItem,
|
|
cb,
|
|
fileFormat,
|
|
}),
|
|
);
|
|
}
|
|
|
|
return items;
|
|
}
|