13f7ad3204
I have added to all packages that are imported from node, the `node:` and I have reordered the imports, first the `node:` ones to make it more readable, as well as only importing the necessary functions. I ran a `node --prof` before and after the modifications and it seems to be more optimal now than before. Co-authored-by: torresgol10.itd <torresgol10.itd@gmail.com> Co-authored-by: Sam Ko <sam@vercel.com>
63 lines
1.4 KiB
TypeScript
63 lines
1.4 KiB
TypeScript
/* eslint-disable import/no-extraneous-dependencies */
|
|
import { lstatSync, readdirSync } from 'node:fs'
|
|
import { join } from 'node:path'
|
|
import { green, blue } from 'picocolors'
|
|
|
|
export function isFolderEmpty(root: string, name: string): boolean {
|
|
const validFiles = [
|
|
'.DS_Store',
|
|
'.git',
|
|
'.gitattributes',
|
|
'.gitignore',
|
|
'.gitlab-ci.yml',
|
|
'.hg',
|
|
'.hgcheck',
|
|
'.hgignore',
|
|
'.idea',
|
|
'.npmignore',
|
|
'.travis.yml',
|
|
'LICENSE',
|
|
'Thumbs.db',
|
|
'docs',
|
|
'mkdocs.yml',
|
|
'npm-debug.log',
|
|
'yarn-debug.log',
|
|
'yarn-error.log',
|
|
'yarnrc.yml',
|
|
'.yarn',
|
|
]
|
|
|
|
const conflicts = readdirSync(root).filter(
|
|
(file) =>
|
|
!validFiles.includes(file) &&
|
|
// Support IntelliJ IDEA-based editors
|
|
!/\.iml$/.test(file)
|
|
)
|
|
|
|
if (conflicts.length > 0) {
|
|
console.log(
|
|
`The directory ${green(name)} contains files that could conflict:`
|
|
)
|
|
console.log()
|
|
for (const file of conflicts) {
|
|
try {
|
|
const stats = lstatSync(join(root, file))
|
|
if (stats.isDirectory()) {
|
|
console.log(` ${blue(file)}/`)
|
|
} else {
|
|
console.log(` ${file}`)
|
|
}
|
|
} catch {
|
|
console.log(` ${file}`)
|
|
}
|
|
}
|
|
console.log()
|
|
console.log(
|
|
'Either try using a new directory name, or remove the files listed above.'
|
|
)
|
|
console.log()
|
|
return false
|
|
}
|
|
|
|
return true
|
|
}
|