@gsknnft/bigint-buffer 1.4.6 → 1.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +150 -107
- package/build/Release/bigint_buffer.node +0 -0
- package/dist/build/Release/bigint_buffer.node +0 -0
- package/dist/conversion/bundle.iife.js +421 -0
- package/dist/conversion/bundle.umd.js +423 -0
- package/dist/conversion/cjs/converter.d.ts +14 -0
- package/dist/conversion/cjs/index.d.ts +33 -0
- package/dist/conversion/cjs/index.js +418 -0
- package/dist/conversion/cjs/index.node.js +4 -0
- package/dist/conversion/cjs/package.json +1 -0
- package/dist/conversion/converter.d.ts +14 -0
- package/dist/conversion/esm/bundle.js +416 -0
- package/dist/conversion/esm/bundle.min.js +1 -0
- package/dist/conversion/esm/converter.d.ts +14 -0
- package/dist/conversion/esm/index.browser.js +416 -0
- package/dist/conversion/esm/index.d.ts +33 -0
- package/dist/conversion/esm/index.js +416 -0
- package/dist/conversion/esm/index.node.js +2 -0
- package/dist/conversion/esm/package.json +1 -0
- package/dist/conversion/index.d.ts +1 -0
- package/dist/index.cjs +1 -1
- package/dist/{types/dist/dist/index.d.ts → index.d.ts} +5 -5
- package/dist/index.js +301 -419
- package/dist/index.umd.js +1 -1
- package/dist/types/conversion/index.d.ts +1 -2
- package/dist/types/conversion/src/index.d.ts +2 -0
- package/dist/types/conversion/src/ts/converter.d.ts +7 -3
- package/dist/types/conversion/src/ts/index.d.ts +23 -10
- package/dist/types/index.d.ts +5 -5
- package/package.json +50 -33
- package/prebuilds/win32-x64/@gsknnft+bigint-buffer.node +0 -0
- package/scripts/postinstall.cjs +40 -0
- package/build/Release/bigint_buffer.exp +0 -0
- package/build/Release/bigint_buffer.iobj +0 -0
- package/build/Release/bigint_buffer.ipdb +0 -0
- package/build/Release/bigint_buffer.lib +0 -0
- package/build/Release/bigint_buffer.pdb +0 -0
- package/build/Release/obj/bigint_buffer/bigint_buffer.node.recipe +0 -11
- package/build/Release/obj/bigint_buffer/bigint_buffer.tlog/CL.command.1.tlog +0 -0
- package/build/Release/obj/bigint_buffer/bigint_buffer.tlog/CL.read.1.tlog +0 -0
- package/build/Release/obj/bigint_buffer/bigint_buffer.tlog/CL.write.1.tlog +0 -0
- package/build/Release/obj/bigint_buffer/bigint_buffer.tlog/Cl.items.tlog +0 -2
- package/build/Release/obj/bigint_buffer/bigint_buffer.tlog/bigint_buffer.lastbuildstate +0 -2
- package/build/Release/obj/bigint_buffer/bigint_buffer.tlog/link.command.1.tlog +0 -0
- package/build/Release/obj/bigint_buffer/bigint_buffer.tlog/link.read.1.tlog +0 -0
- package/build/Release/obj/bigint_buffer/bigint_buffer.tlog/link.secondary.1.tlog +0 -5
- package/build/Release/obj/bigint_buffer/bigint_buffer.tlog/link.write.1.tlog +0 -0
- package/build/Release/obj/bigint_buffer/src/bigint-buffer.obj +0 -0
- package/build/Release/obj/bigint_buffer/win_delay_load_hook.obj +0 -0
- package/build/bigint_buffer.vcxproj +0 -148
- package/build/bigint_buffer.vcxproj.filters +0 -64
- package/build/binding.sln +0 -19
- package/build/config.gypi +0 -525
- package/dist/tsconfig.tsbuildinfo +0 -1
- package/dist/types/bigint-buffer.test.d.ts +0 -1
- package/dist/types/conversion/src/ts/fixedPoint/index.d.ts +0 -12
- package/dist/types/conversion/test/bigintToBase64.test.d.ts +0 -1
- package/dist/types/conversion/test/bigintToBuf.test.d.ts +0 -1
- package/dist/types/conversion/test/bigintToHex.test.d.ts +0 -1
- package/dist/types/conversion/test/bigintToText.test.d.ts +0 -1
- package/dist/types/conversion/test/bufToBigint.test.d.ts +0 -1
- package/dist/types/conversion/test/hexToBigint.test.d.ts +0 -1
- package/dist/types/conversion/test/hexToBuf.test.d.ts +0 -1
- package/dist/types/conversion/test/parseHex.test.d.ts +0 -1
- package/dist/types/conversion/test/setup.test.d.ts +0 -1
- package/dist/types/conversion/test/textToBuf.test.d.ts +0 -1
- package/dist/types/conversion/vite.config.d.ts +0 -2
- package/dist/types/conversion/vitest.config.d.ts +0 -2
- package/dist/types/dist/dist/conversion/conversion/index.d.ts +0 -2
- package/dist/types/index.bench.d.ts +0 -1
- package/dist/types/index.spec.d.ts +0 -1
- package/src/bigint-buffer.test.ts +0 -11
- package/src/conversion/.github/workflows/build-and-test.yml +0 -116
- package/src/conversion/.rollup.cache/C/Users/G/AppData/Local/Temp/rollup-plugin-typescript-allowjs-PYrzNv/src/ts/index.js +0 -178
- package/src/conversion/.rollup.cache/C/Users/G/AppData/Local/Temp/rollup-plugin-typescript-allowjs-PYrzNv/src/ts/index.js.map +0 -1
- package/src/conversion/.rollup.cache/C/Users/G/AppData/Local/Temp/rollup-plugin-typescript-allowjs-h16OVM/src/ts/index.js +0 -178
- package/src/conversion/.rollup.cache/C/Users/G/AppData/Local/Temp/rollup-plugin-typescript-allowjs-h16OVM/src/ts/index.js.map +0 -1
- package/src/conversion/.rollup.cache/C/Users/G/AppData/Local/Temp/rollup-plugin-typescript-allowjs-uUCFYt/src/ts/index.js +0 -178
- package/src/conversion/.rollup.cache/C/Users/G/AppData/Local/Temp/rollup-plugin-typescript-allowjs-uUCFYt/src/ts/index.js.map +0 -1
- package/src/conversion/CODE_OF_CONDUCT.md +0 -134
- package/src/conversion/LICENSE +0 -21
- package/src/conversion/README.md +0 -48
- package/src/conversion/coverage/base.css +0 -224
- package/src/conversion/coverage/block-navigation.js +0 -87
- package/src/conversion/coverage/clover.xml +0 -131
- package/src/conversion/coverage/coverage-final.json +0 -2
- package/src/conversion/coverage/favicon.png +0 -0
- package/src/conversion/coverage/index.html +0 -116
- package/src/conversion/coverage/index.ts.html +0 -1225
- package/src/conversion/coverage/prettify.css +0 -1
- package/src/conversion/coverage/prettify.js +0 -2
- package/src/conversion/coverage/sort-arrow-sprite.png +0 -0
- package/src/conversion/coverage/sorter.js +0 -210
- package/src/conversion/docs/README.md +0 -42
- package/src/conversion/docs/functions/base64ToBigint.md +0 -27
- package/src/conversion/docs/functions/bigintToBase64.md +0 -43
- package/src/conversion/docs/functions/bigintToBuf.md +0 -35
- package/src/conversion/docs/functions/bigintToHex.md +0 -43
- package/src/conversion/docs/functions/bigintToText.md +0 -31
- package/src/conversion/docs/functions/bufToBigint.md +0 -25
- package/src/conversion/docs/functions/bufToHex.md +0 -37
- package/src/conversion/docs/functions/bufToText.md +0 -27
- package/src/conversion/docs/functions/hexToBigint.md +0 -29
- package/src/conversion/docs/functions/hexToBuf.md +0 -37
- package/src/conversion/docs/functions/parseHex.md +0 -45
- package/src/conversion/docs/functions/textToBigint.md +0 -27
- package/src/conversion/docs/functions/textToBuf.md +0 -33
- package/src/conversion/docs/functions/toBigIntBE.md +0 -27
- package/src/conversion/docs/functions/toBigIntLE.md +0 -27
- package/src/conversion/docs/functions/toBufferBE.md +0 -33
- package/src/conversion/docs/functions/toBufferLE.md +0 -33
- package/src/conversion/docs/functions/validateBigIntBuffer.md +0 -15
- package/src/conversion/docs/type-aliases/TypedArray.md +0 -11
- package/src/conversion/docs/variables/isNative.md +0 -11
- package/src/conversion/example.cjs +0 -9
- package/src/conversion/example.esm.js +0 -11
- package/src/conversion/index.ts +0 -2
- package/src/conversion/node_modules/.bin/_mocha +0 -21
- package/src/conversion/node_modules/.bin/_mocha.CMD +0 -12
- package/src/conversion/node_modules/.bin/_mocha.ps1 +0 -41
- package/src/conversion/node_modules/.bin/c8 +0 -21
- package/src/conversion/node_modules/.bin/c8.CMD +0 -12
- package/src/conversion/node_modules/.bin/c8.ps1 +0 -41
- package/src/conversion/node_modules/.bin/esbuild +0 -21
- package/src/conversion/node_modules/.bin/esbuild.CMD +0 -12
- package/src/conversion/node_modules/.bin/esbuild.ps1 +0 -41
- package/src/conversion/node_modules/.bin/eslint +0 -21
- package/src/conversion/node_modules/.bin/eslint.CMD +0 -12
- package/src/conversion/node_modules/.bin/eslint.ps1 +0 -41
- package/src/conversion/node_modules/.bin/jiti +0 -21
- package/src/conversion/node_modules/.bin/jiti.CMD +0 -12
- package/src/conversion/node_modules/.bin/jiti.ps1 +0 -41
- package/src/conversion/node_modules/.bin/json5 +0 -21
- package/src/conversion/node_modules/.bin/json5.CMD +0 -12
- package/src/conversion/node_modules/.bin/json5.ps1 +0 -41
- package/src/conversion/node_modules/.bin/mocha +0 -21
- package/src/conversion/node_modules/.bin/mocha.CMD +0 -12
- package/src/conversion/node_modules/.bin/mocha.ps1 +0 -41
- package/src/conversion/node_modules/.bin/npm-run-all +0 -21
- package/src/conversion/node_modules/.bin/npm-run-all.CMD +0 -12
- package/src/conversion/node_modules/.bin/npm-run-all.ps1 +0 -41
- package/src/conversion/node_modules/.bin/puppeteer +0 -21
- package/src/conversion/node_modules/.bin/puppeteer.CMD +0 -12
- package/src/conversion/node_modules/.bin/puppeteer.ps1 +0 -41
- package/src/conversion/node_modules/.bin/rimraf +0 -16
- package/src/conversion/node_modules/.bin/rimraf.cmd +0 -17
- package/src/conversion/node_modules/.bin/rimraf.ps1 +0 -28
- package/src/conversion/node_modules/.bin/rollup +0 -21
- package/src/conversion/node_modules/.bin/rollup.CMD +0 -12
- package/src/conversion/node_modules/.bin/rollup.ps1 +0 -41
- package/src/conversion/node_modules/.bin/run-p +0 -21
- package/src/conversion/node_modules/.bin/run-p.CMD +0 -12
- package/src/conversion/node_modules/.bin/run-p.ps1 +0 -41
- package/src/conversion/node_modules/.bin/run-s +0 -21
- package/src/conversion/node_modules/.bin/run-s.CMD +0 -12
- package/src/conversion/node_modules/.bin/run-s.ps1 +0 -41
- package/src/conversion/node_modules/.bin/terser +0 -21
- package/src/conversion/node_modules/.bin/terser.CMD +0 -12
- package/src/conversion/node_modules/.bin/terser.ps1 +0 -41
- package/src/conversion/node_modules/.bin/ts-standard +0 -21
- package/src/conversion/node_modules/.bin/ts-standard.CMD +0 -12
- package/src/conversion/node_modules/.bin/ts-standard.ps1 +0 -41
- package/src/conversion/node_modules/.bin/tsc +0 -21
- package/src/conversion/node_modules/.bin/tsc.CMD +0 -12
- package/src/conversion/node_modules/.bin/tsc.ps1 +0 -41
- package/src/conversion/node_modules/.bin/tsserver +0 -21
- package/src/conversion/node_modules/.bin/tsserver.CMD +0 -12
- package/src/conversion/node_modules/.bin/tsserver.ps1 +0 -41
- package/src/conversion/node_modules/.bin/typedoc +0 -21
- package/src/conversion/node_modules/.bin/typedoc.CMD +0 -12
- package/src/conversion/node_modules/.bin/typedoc.ps1 +0 -41
- package/src/conversion/node_modules/.bin/vite +0 -21
- package/src/conversion/node_modules/.bin/vite.CMD +0 -12
- package/src/conversion/node_modules/.bin/vite.ps1 +0 -41
- package/src/conversion/node_modules/.bin/vitest +0 -21
- package/src/conversion/node_modules/.bin/vitest.CMD +0 -12
- package/src/conversion/node_modules/.bin/vitest.ps1 +0 -41
- package/src/conversion/node_modules/.bin/yaml +0 -21
- package/src/conversion/node_modules/.bin/yaml.CMD +0 -12
- package/src/conversion/node_modules/.bin/yaml.ps1 +0 -41
- package/src/conversion/node_modules/glob/LICENSE.md +0 -63
- package/src/conversion/node_modules/glob/README.md +0 -1177
- package/src/conversion/node_modules/glob/dist/commonjs/glob.d.ts +0 -388
- package/src/conversion/node_modules/glob/dist/commonjs/glob.d.ts.map +0 -1
- package/src/conversion/node_modules/glob/dist/commonjs/glob.js +0 -247
- package/src/conversion/node_modules/glob/dist/commonjs/glob.js.map +0 -1
- package/src/conversion/node_modules/glob/dist/commonjs/has-magic.d.ts +0 -14
- package/src/conversion/node_modules/glob/dist/commonjs/has-magic.d.ts.map +0 -1
- package/src/conversion/node_modules/glob/dist/commonjs/has-magic.js +0 -27
- package/src/conversion/node_modules/glob/dist/commonjs/has-magic.js.map +0 -1
- package/src/conversion/node_modules/glob/dist/commonjs/ignore.d.ts +0 -24
- package/src/conversion/node_modules/glob/dist/commonjs/ignore.d.ts.map +0 -1
- package/src/conversion/node_modules/glob/dist/commonjs/ignore.js +0 -119
- package/src/conversion/node_modules/glob/dist/commonjs/ignore.js.map +0 -1
- package/src/conversion/node_modules/glob/dist/commonjs/index.d.ts +0 -97
- package/src/conversion/node_modules/glob/dist/commonjs/index.d.ts.map +0 -1
- package/src/conversion/node_modules/glob/dist/commonjs/index.js +0 -68
- package/src/conversion/node_modules/glob/dist/commonjs/index.js.map +0 -1
- package/src/conversion/node_modules/glob/dist/commonjs/package.json +0 -3
- package/src/conversion/node_modules/glob/dist/commonjs/pattern.d.ts +0 -76
- package/src/conversion/node_modules/glob/dist/commonjs/pattern.d.ts.map +0 -1
- package/src/conversion/node_modules/glob/dist/commonjs/pattern.js +0 -219
- package/src/conversion/node_modules/glob/dist/commonjs/pattern.js.map +0 -1
- package/src/conversion/node_modules/glob/dist/commonjs/processor.d.ts +0 -59
- package/src/conversion/node_modules/glob/dist/commonjs/processor.d.ts.map +0 -1
- package/src/conversion/node_modules/glob/dist/commonjs/processor.js +0 -301
- package/src/conversion/node_modules/glob/dist/commonjs/processor.js.map +0 -1
- package/src/conversion/node_modules/glob/dist/commonjs/walker.d.ts +0 -97
- package/src/conversion/node_modules/glob/dist/commonjs/walker.d.ts.map +0 -1
- package/src/conversion/node_modules/glob/dist/commonjs/walker.js +0 -387
- package/src/conversion/node_modules/glob/dist/commonjs/walker.js.map +0 -1
- package/src/conversion/node_modules/glob/dist/esm/glob.d.ts +0 -388
- package/src/conversion/node_modules/glob/dist/esm/glob.d.ts.map +0 -1
- package/src/conversion/node_modules/glob/dist/esm/glob.js +0 -243
- package/src/conversion/node_modules/glob/dist/esm/glob.js.map +0 -1
- package/src/conversion/node_modules/glob/dist/esm/has-magic.d.ts +0 -14
- package/src/conversion/node_modules/glob/dist/esm/has-magic.d.ts.map +0 -1
- package/src/conversion/node_modules/glob/dist/esm/has-magic.js +0 -23
- package/src/conversion/node_modules/glob/dist/esm/has-magic.js.map +0 -1
- package/src/conversion/node_modules/glob/dist/esm/ignore.d.ts +0 -24
- package/src/conversion/node_modules/glob/dist/esm/ignore.d.ts.map +0 -1
- package/src/conversion/node_modules/glob/dist/esm/ignore.js +0 -115
- package/src/conversion/node_modules/glob/dist/esm/ignore.js.map +0 -1
- package/src/conversion/node_modules/glob/dist/esm/index.d.ts +0 -97
- package/src/conversion/node_modules/glob/dist/esm/index.d.ts.map +0 -1
- package/src/conversion/node_modules/glob/dist/esm/index.js +0 -55
- package/src/conversion/node_modules/glob/dist/esm/index.js.map +0 -1
- package/src/conversion/node_modules/glob/dist/esm/package.json +0 -3
- package/src/conversion/node_modules/glob/dist/esm/pattern.d.ts +0 -76
- package/src/conversion/node_modules/glob/dist/esm/pattern.d.ts.map +0 -1
- package/src/conversion/node_modules/glob/dist/esm/pattern.js +0 -215
- package/src/conversion/node_modules/glob/dist/esm/pattern.js.map +0 -1
- package/src/conversion/node_modules/glob/dist/esm/processor.d.ts +0 -59
- package/src/conversion/node_modules/glob/dist/esm/processor.d.ts.map +0 -1
- package/src/conversion/node_modules/glob/dist/esm/processor.js +0 -294
- package/src/conversion/node_modules/glob/dist/esm/processor.js.map +0 -1
- package/src/conversion/node_modules/glob/dist/esm/walker.d.ts +0 -97
- package/src/conversion/node_modules/glob/dist/esm/walker.d.ts.map +0 -1
- package/src/conversion/node_modules/glob/dist/esm/walker.js +0 -381
- package/src/conversion/node_modules/glob/dist/esm/walker.js.map +0 -1
- package/src/conversion/node_modules/glob/package.json +0 -93
- package/src/conversion/node_modules/minimatch/LICENSE.md +0 -55
- package/src/conversion/node_modules/minimatch/README.md +0 -453
- package/src/conversion/node_modules/minimatch/dist/commonjs/assert-valid-pattern.d.ts +0 -2
- package/src/conversion/node_modules/minimatch/dist/commonjs/assert-valid-pattern.d.ts.map +0 -1
- package/src/conversion/node_modules/minimatch/dist/commonjs/assert-valid-pattern.js +0 -14
- package/src/conversion/node_modules/minimatch/dist/commonjs/assert-valid-pattern.js.map +0 -1
- package/src/conversion/node_modules/minimatch/dist/commonjs/ast.d.ts +0 -20
- package/src/conversion/node_modules/minimatch/dist/commonjs/ast.d.ts.map +0 -1
- package/src/conversion/node_modules/minimatch/dist/commonjs/ast.js +0 -591
- package/src/conversion/node_modules/minimatch/dist/commonjs/ast.js.map +0 -1
- package/src/conversion/node_modules/minimatch/dist/commonjs/brace-expressions.d.ts +0 -8
- package/src/conversion/node_modules/minimatch/dist/commonjs/brace-expressions.d.ts.map +0 -1
- package/src/conversion/node_modules/minimatch/dist/commonjs/brace-expressions.js +0 -152
- package/src/conversion/node_modules/minimatch/dist/commonjs/brace-expressions.js.map +0 -1
- package/src/conversion/node_modules/minimatch/dist/commonjs/escape.d.ts +0 -15
- package/src/conversion/node_modules/minimatch/dist/commonjs/escape.d.ts.map +0 -1
- package/src/conversion/node_modules/minimatch/dist/commonjs/escape.js +0 -30
- package/src/conversion/node_modules/minimatch/dist/commonjs/escape.js.map +0 -1
- package/src/conversion/node_modules/minimatch/dist/commonjs/index.d.ts +0 -94
- package/src/conversion/node_modules/minimatch/dist/commonjs/index.d.ts.map +0 -1
- package/src/conversion/node_modules/minimatch/dist/commonjs/index.js +0 -1029
- package/src/conversion/node_modules/minimatch/dist/commonjs/index.js.map +0 -1
- package/src/conversion/node_modules/minimatch/dist/commonjs/package.json +0 -3
- package/src/conversion/node_modules/minimatch/dist/commonjs/unescape.d.ts +0 -22
- package/src/conversion/node_modules/minimatch/dist/commonjs/unescape.d.ts.map +0 -1
- package/src/conversion/node_modules/minimatch/dist/commonjs/unescape.js +0 -38
- package/src/conversion/node_modules/minimatch/dist/commonjs/unescape.js.map +0 -1
- package/src/conversion/node_modules/minimatch/dist/esm/assert-valid-pattern.d.ts +0 -2
- package/src/conversion/node_modules/minimatch/dist/esm/assert-valid-pattern.d.ts.map +0 -1
- package/src/conversion/node_modules/minimatch/dist/esm/assert-valid-pattern.js +0 -10
- package/src/conversion/node_modules/minimatch/dist/esm/assert-valid-pattern.js.map +0 -1
- package/src/conversion/node_modules/minimatch/dist/esm/ast.d.ts +0 -20
- package/src/conversion/node_modules/minimatch/dist/esm/ast.d.ts.map +0 -1
- package/src/conversion/node_modules/minimatch/dist/esm/ast.js +0 -587
- package/src/conversion/node_modules/minimatch/dist/esm/ast.js.map +0 -1
- package/src/conversion/node_modules/minimatch/dist/esm/brace-expressions.d.ts +0 -8
- package/src/conversion/node_modules/minimatch/dist/esm/brace-expressions.d.ts.map +0 -1
- package/src/conversion/node_modules/minimatch/dist/esm/brace-expressions.js +0 -148
- package/src/conversion/node_modules/minimatch/dist/esm/brace-expressions.js.map +0 -1
- package/src/conversion/node_modules/minimatch/dist/esm/escape.d.ts +0 -15
- package/src/conversion/node_modules/minimatch/dist/esm/escape.d.ts.map +0 -1
- package/src/conversion/node_modules/minimatch/dist/esm/escape.js +0 -26
- package/src/conversion/node_modules/minimatch/dist/esm/escape.js.map +0 -1
- package/src/conversion/node_modules/minimatch/dist/esm/index.d.ts +0 -94
- package/src/conversion/node_modules/minimatch/dist/esm/index.d.ts.map +0 -1
- package/src/conversion/node_modules/minimatch/dist/esm/index.js +0 -1016
- package/src/conversion/node_modules/minimatch/dist/esm/index.js.map +0 -1
- package/src/conversion/node_modules/minimatch/dist/esm/package.json +0 -3
- package/src/conversion/node_modules/minimatch/dist/esm/unescape.d.ts +0 -22
- package/src/conversion/node_modules/minimatch/dist/esm/unescape.d.ts.map +0 -1
- package/src/conversion/node_modules/minimatch/dist/esm/unescape.js +0 -34
- package/src/conversion/node_modules/minimatch/dist/esm/unescape.js.map +0 -1
- package/src/conversion/node_modules/minimatch/package.json +0 -78
- package/src/conversion/node_modules/rimraf/LICENSE.md +0 -55
- package/src/conversion/node_modules/rimraf/README.md +0 -226
- package/src/conversion/node_modules/rimraf/dist/commonjs/default-tmp.d.ts +0 -3
- package/src/conversion/node_modules/rimraf/dist/commonjs/default-tmp.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/default-tmp.js +0 -58
- package/src/conversion/node_modules/rimraf/dist/commonjs/default-tmp.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/error.d.ts +0 -6
- package/src/conversion/node_modules/rimraf/dist/commonjs/error.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/error.js +0 -10
- package/src/conversion/node_modules/rimraf/dist/commonjs/error.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/fix-eperm.d.ts +0 -3
- package/src/conversion/node_modules/rimraf/dist/commonjs/fix-eperm.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/fix-eperm.js +0 -38
- package/src/conversion/node_modules/rimraf/dist/commonjs/fix-eperm.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/fs.d.ts +0 -15
- package/src/conversion/node_modules/rimraf/dist/commonjs/fs.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/fs.js +0 -33
- package/src/conversion/node_modules/rimraf/dist/commonjs/fs.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/ignore-enoent.d.ts +0 -3
- package/src/conversion/node_modules/rimraf/dist/commonjs/ignore-enoent.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/ignore-enoent.js +0 -24
- package/src/conversion/node_modules/rimraf/dist/commonjs/ignore-enoent.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/index.d.ts +0 -50
- package/src/conversion/node_modules/rimraf/dist/commonjs/index.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/index.js +0 -78
- package/src/conversion/node_modules/rimraf/dist/commonjs/index.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/opt-arg.d.ts +0 -34
- package/src/conversion/node_modules/rimraf/dist/commonjs/opt-arg.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/opt-arg.js +0 -53
- package/src/conversion/node_modules/rimraf/dist/commonjs/opt-arg.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/package.json +0 -3
- package/src/conversion/node_modules/rimraf/dist/commonjs/path-arg.d.ts +0 -4
- package/src/conversion/node_modules/rimraf/dist/commonjs/path-arg.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/path-arg.js +0 -48
- package/src/conversion/node_modules/rimraf/dist/commonjs/path-arg.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/readdir-or-error.d.ts +0 -3
- package/src/conversion/node_modules/rimraf/dist/commonjs/readdir-or-error.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/readdir-or-error.js +0 -19
- package/src/conversion/node_modules/rimraf/dist/commonjs/readdir-or-error.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/retry-busy.d.ts +0 -8
- package/src/conversion/node_modules/rimraf/dist/commonjs/retry-busy.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/retry-busy.js +0 -65
- package/src/conversion/node_modules/rimraf/dist/commonjs/retry-busy.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/rimraf-manual.d.ts +0 -3
- package/src/conversion/node_modules/rimraf/dist/commonjs/rimraf-manual.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/rimraf-manual.js +0 -8
- package/src/conversion/node_modules/rimraf/dist/commonjs/rimraf-manual.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/rimraf-move-remove.d.ts +0 -4
- package/src/conversion/node_modules/rimraf/dist/commonjs/rimraf-move-remove.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/rimraf-move-remove.js +0 -138
- package/src/conversion/node_modules/rimraf/dist/commonjs/rimraf-move-remove.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/rimraf-native.d.ts +0 -4
- package/src/conversion/node_modules/rimraf/dist/commonjs/rimraf-native.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/rimraf-native.js +0 -24
- package/src/conversion/node_modules/rimraf/dist/commonjs/rimraf-native.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/rimraf-posix.d.ts +0 -4
- package/src/conversion/node_modules/rimraf/dist/commonjs/rimraf-posix.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/rimraf-posix.js +0 -103
- package/src/conversion/node_modules/rimraf/dist/commonjs/rimraf-posix.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/rimraf-windows.d.ts +0 -4
- package/src/conversion/node_modules/rimraf/dist/commonjs/rimraf-windows.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/rimraf-windows.js +0 -159
- package/src/conversion/node_modules/rimraf/dist/commonjs/rimraf-windows.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/use-native.d.ts +0 -4
- package/src/conversion/node_modules/rimraf/dist/commonjs/use-native.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/commonjs/use-native.js +0 -18
- package/src/conversion/node_modules/rimraf/dist/commonjs/use-native.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/bin.d.mts +0 -3
- package/src/conversion/node_modules/rimraf/dist/esm/bin.d.mts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/bin.mjs +0 -250
- package/src/conversion/node_modules/rimraf/dist/esm/bin.mjs.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/default-tmp.d.ts +0 -3
- package/src/conversion/node_modules/rimraf/dist/esm/default-tmp.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/default-tmp.js +0 -55
- package/src/conversion/node_modules/rimraf/dist/esm/default-tmp.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/error.d.ts +0 -6
- package/src/conversion/node_modules/rimraf/dist/esm/error.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/error.js +0 -5
- package/src/conversion/node_modules/rimraf/dist/esm/error.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/fix-eperm.d.ts +0 -3
- package/src/conversion/node_modules/rimraf/dist/esm/fix-eperm.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/fix-eperm.js +0 -33
- package/src/conversion/node_modules/rimraf/dist/esm/fix-eperm.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/fs.d.ts +0 -15
- package/src/conversion/node_modules/rimraf/dist/esm/fs.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/fs.js +0 -18
- package/src/conversion/node_modules/rimraf/dist/esm/fs.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/ignore-enoent.d.ts +0 -3
- package/src/conversion/node_modules/rimraf/dist/esm/ignore-enoent.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/ignore-enoent.js +0 -19
- package/src/conversion/node_modules/rimraf/dist/esm/ignore-enoent.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/index.d.ts +0 -50
- package/src/conversion/node_modules/rimraf/dist/esm/index.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/index.js +0 -70
- package/src/conversion/node_modules/rimraf/dist/esm/index.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/opt-arg.d.ts +0 -34
- package/src/conversion/node_modules/rimraf/dist/esm/opt-arg.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/opt-arg.js +0 -46
- package/src/conversion/node_modules/rimraf/dist/esm/opt-arg.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/package.json +0 -3
- package/src/conversion/node_modules/rimraf/dist/esm/path-arg.d.ts +0 -4
- package/src/conversion/node_modules/rimraf/dist/esm/path-arg.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/path-arg.js +0 -46
- package/src/conversion/node_modules/rimraf/dist/esm/path-arg.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/readdir-or-error.d.ts +0 -3
- package/src/conversion/node_modules/rimraf/dist/esm/readdir-or-error.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/readdir-or-error.js +0 -14
- package/src/conversion/node_modules/rimraf/dist/esm/readdir-or-error.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/retry-busy.d.ts +0 -8
- package/src/conversion/node_modules/rimraf/dist/esm/retry-busy.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/retry-busy.js +0 -60
- package/src/conversion/node_modules/rimraf/dist/esm/retry-busy.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/rimraf-manual.d.ts +0 -3
- package/src/conversion/node_modules/rimraf/dist/esm/rimraf-manual.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/rimraf-manual.js +0 -5
- package/src/conversion/node_modules/rimraf/dist/esm/rimraf-manual.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/rimraf-move-remove.d.ts +0 -4
- package/src/conversion/node_modules/rimraf/dist/esm/rimraf-move-remove.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/rimraf-move-remove.js +0 -133
- package/src/conversion/node_modules/rimraf/dist/esm/rimraf-move-remove.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/rimraf-native.d.ts +0 -4
- package/src/conversion/node_modules/rimraf/dist/esm/rimraf-native.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/rimraf-native.js +0 -19
- package/src/conversion/node_modules/rimraf/dist/esm/rimraf-native.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/rimraf-posix.d.ts +0 -4
- package/src/conversion/node_modules/rimraf/dist/esm/rimraf-posix.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/rimraf-posix.js +0 -98
- package/src/conversion/node_modules/rimraf/dist/esm/rimraf-posix.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/rimraf-windows.d.ts +0 -4
- package/src/conversion/node_modules/rimraf/dist/esm/rimraf-windows.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/rimraf-windows.js +0 -154
- package/src/conversion/node_modules/rimraf/dist/esm/rimraf-windows.js.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/use-native.d.ts +0 -4
- package/src/conversion/node_modules/rimraf/dist/esm/use-native.d.ts.map +0 -1
- package/src/conversion/node_modules/rimraf/dist/esm/use-native.js +0 -15
- package/src/conversion/node_modules/rimraf/dist/esm/use-native.js.map +0 -1
- package/src/conversion/node_modules/rimraf/package.json +0 -92
- package/src/conversion/package.json +0 -154
- package/src/conversion/src/docs/index.md +0 -52
- package/src/conversion/src/ts/converter.ts +0 -85
- package/src/conversion/src/ts/fixedPoint/index.ts +0 -87
- package/src/conversion/src/ts/index.ts +0 -500
- package/src/conversion/test/bigintToBase64.test.ts +0 -37
- package/src/conversion/test/bigintToBuf.test.ts +0 -43
- package/src/conversion/test/bigintToHex.test.ts +0 -52
- package/src/conversion/test/bigintToText.test.ts +0 -30
- package/src/conversion/test/bufToBigint.test.ts +0 -20
- package/src/conversion/test/hexToBigint.test.ts +0 -22
- package/src/conversion/test/hexToBuf.test.ts +0 -39
- package/src/conversion/test/parseHex.test.ts +0 -35
- package/src/conversion/test/setup.test.ts +0 -9
- package/src/conversion/test/textToBuf.test.ts +0 -26
- package/src/conversion/tsconfig.json +0 -57
- package/src/conversion/typedoc.json +0 -5
- package/src/conversion/vite.config.ts +0 -47
- package/src/conversion/vitest.config.ts +0 -15
- package/src/index.bench.ts +0 -206
- package/src/index.spec.ts +0 -318
- package/src/index.ts +0 -343
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"readdir-or-error.js","sourceRoot":"","sources":["../../src/readdir-or-error.ts"],"names":[],"mappings":";;;AAAA,kDAAkD;AAClD,6CAA6C;AAC7C,mCAA+C;AAC/C,MAAM,EAAE,OAAO,EAAE,GAAG,gBAAQ,CAAA;AAErB,MAAM,cAAc,GAAG,CAAC,IAAY,EAAE,EAAE,CAC7C,OAAO,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,EAAE,CAAC,EAAW,CAAC,CAAA;AAD3B,QAAA,cAAc,kBACa;AACjC,MAAM,kBAAkB,GAAG,CAAC,IAAY,EAAE,EAAE;IACjD,IAAI,CAAC;QACH,OAAO,IAAA,mBAAW,EAAC,IAAI,CAAC,CAAA;IAC1B,CAAC;IAAC,OAAO,EAAE,EAAE,CAAC;QACZ,OAAO,EAAW,CAAA;IACpB,CAAC;AACH,CAAC,CAAA;AANY,QAAA,kBAAkB,sBAM9B","sourcesContent":["// returns an array of entries if readdir() works,\n// or the error that readdir() raised if not.\nimport { promises, readdirSync } from './fs.js'\nconst { readdir } = promises\n\nexport const readdirOrError = (path: string) =>\n readdir(path).catch(er => er as Error)\nexport const readdirOrErrorSync = (path: string) => {\n try {\n return readdirSync(path)\n } catch (er) {\n return er as Error\n }\n}\n"]}
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
import { RimrafAsyncOptions, RimrafOptions } from './index.js';
|
|
2
|
-
export declare const MAXBACKOFF = 200;
|
|
3
|
-
export declare const RATE = 1.2;
|
|
4
|
-
export declare const MAXRETRIES = 10;
|
|
5
|
-
export declare const codes: Set<string>;
|
|
6
|
-
export declare const retryBusy: <T>(fn: (path: string) => Promise<T>) => (path: string, opt: RimrafAsyncOptions, backoff?: number, total?: number) => Promise<T>;
|
|
7
|
-
export declare const retryBusySync: <T>(fn: (path: string) => T) => (path: string, opt: RimrafOptions) => T;
|
|
8
|
-
//# sourceMappingURL=retry-busy.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"retry-busy.d.ts","sourceRoot":"","sources":["../../src/retry-busy.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,kBAAkB,EAAE,aAAa,EAAE,MAAM,YAAY,CAAA;AAG9D,eAAO,MAAM,UAAU,MAAM,CAAA;AAC7B,eAAO,MAAM,IAAI,MAAM,CAAA;AACvB,eAAO,MAAM,UAAU,KAAK,CAAA;AAC5B,eAAO,MAAM,KAAK,aAAyC,CAAA;AAE3D,eAAO,MAAM,SAAS,GAAI,CAAC,EAAE,IAAI,CAAC,IAAI,EAAE,MAAM,KAAK,OAAO,CAAC,CAAC,CAAC,YAEnD,MAAM,OACP,kBAAkB,iDA8B1B,CAAA;AAGD,eAAO,MAAM,aAAa,GAAI,CAAC,EAAE,IAAI,CAAC,IAAI,EAAE,MAAM,KAAK,CAAC,YAChC,MAAM,OAAO,aAAa,MAqBjD,CAAA"}
|
|
@@ -1,65 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
// note: max backoff is the maximum that any *single* backoff will do
|
|
3
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
-
exports.retryBusySync = exports.retryBusy = exports.codes = exports.MAXRETRIES = exports.RATE = exports.MAXBACKOFF = void 0;
|
|
5
|
-
const promises_1 = require("timers/promises");
|
|
6
|
-
const error_js_1 = require("./error.js");
|
|
7
|
-
exports.MAXBACKOFF = 200;
|
|
8
|
-
exports.RATE = 1.2;
|
|
9
|
-
exports.MAXRETRIES = 10;
|
|
10
|
-
exports.codes = new Set(['EMFILE', 'ENFILE', 'EBUSY']);
|
|
11
|
-
const retryBusy = (fn) => {
|
|
12
|
-
const method = async (path, opt, backoff = 1, total = 0) => {
|
|
13
|
-
const mbo = opt.maxBackoff || exports.MAXBACKOFF;
|
|
14
|
-
const rate = opt.backoff || exports.RATE;
|
|
15
|
-
const max = opt.maxRetries || exports.MAXRETRIES;
|
|
16
|
-
let retries = 0;
|
|
17
|
-
while (true) {
|
|
18
|
-
try {
|
|
19
|
-
return await fn(path);
|
|
20
|
-
}
|
|
21
|
-
catch (er) {
|
|
22
|
-
if ((0, error_js_1.isFsError)(er) && er.path === path && exports.codes.has(er.code)) {
|
|
23
|
-
backoff = Math.ceil(backoff * rate);
|
|
24
|
-
total = backoff + total;
|
|
25
|
-
if (total < mbo) {
|
|
26
|
-
await (0, promises_1.setTimeout)(backoff);
|
|
27
|
-
return method(path, opt, backoff, total);
|
|
28
|
-
}
|
|
29
|
-
if (retries < max) {
|
|
30
|
-
retries++;
|
|
31
|
-
continue;
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
throw er;
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
};
|
|
38
|
-
return method;
|
|
39
|
-
};
|
|
40
|
-
exports.retryBusy = retryBusy;
|
|
41
|
-
// just retries, no async so no backoff
|
|
42
|
-
const retryBusySync = (fn) => {
|
|
43
|
-
const method = (path, opt) => {
|
|
44
|
-
const max = opt.maxRetries || exports.MAXRETRIES;
|
|
45
|
-
let retries = 0;
|
|
46
|
-
while (true) {
|
|
47
|
-
try {
|
|
48
|
-
return fn(path);
|
|
49
|
-
}
|
|
50
|
-
catch (er) {
|
|
51
|
-
if ((0, error_js_1.isFsError)(er) &&
|
|
52
|
-
er.path === path &&
|
|
53
|
-
exports.codes.has(er.code) &&
|
|
54
|
-
retries < max) {
|
|
55
|
-
retries++;
|
|
56
|
-
continue;
|
|
57
|
-
}
|
|
58
|
-
throw er;
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
};
|
|
62
|
-
return method;
|
|
63
|
-
};
|
|
64
|
-
exports.retryBusySync = retryBusySync;
|
|
65
|
-
//# sourceMappingURL=retry-busy.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"retry-busy.js","sourceRoot":"","sources":["../../src/retry-busy.ts"],"names":[],"mappings":";AAAA,qEAAqE;;;AAErE,8CAA4C;AAE5C,yCAAsC;AAEzB,QAAA,UAAU,GAAG,GAAG,CAAA;AAChB,QAAA,IAAI,GAAG,GAAG,CAAA;AACV,QAAA,UAAU,GAAG,EAAE,CAAA;AACf,QAAA,KAAK,GAAG,IAAI,GAAG,CAAC,CAAC,QAAQ,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC,CAAA;AAEpD,MAAM,SAAS,GAAG,CAAI,EAAgC,EAAE,EAAE;IAC/D,MAAM,MAAM,GAAG,KAAK,EAClB,IAAY,EACZ,GAAuB,EACvB,OAAO,GAAG,CAAC,EACX,KAAK,GAAG,CAAC,EACT,EAAE;QACF,MAAM,GAAG,GAAG,GAAG,CAAC,UAAU,IAAI,kBAAU,CAAA;QACxC,MAAM,IAAI,GAAG,GAAG,CAAC,OAAO,IAAI,YAAI,CAAA;QAChC,MAAM,GAAG,GAAG,GAAG,CAAC,UAAU,IAAI,kBAAU,CAAA;QACxC,IAAI,OAAO,GAAG,CAAC,CAAA;QACf,OAAO,IAAI,EAAE,CAAC;YACZ,IAAI,CAAC;gBACH,OAAO,MAAM,EAAE,CAAC,IAAI,CAAC,CAAA;YACvB,CAAC;YAAC,OAAO,EAAE,EAAE,CAAC;gBACZ,IAAI,IAAA,oBAAS,EAAC,EAAE,CAAC,IAAI,EAAE,CAAC,IAAI,KAAK,IAAI,IAAI,aAAK,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC;oBAC5D,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,CAAA;oBACnC,KAAK,GAAG,OAAO,GAAG,KAAK,CAAA;oBACvB,IAAI,KAAK,GAAG,GAAG,EAAE,CAAC;wBAChB,MAAM,IAAA,qBAAU,EAAC,OAAO,CAAC,CAAA;wBACzB,OAAO,MAAM,CAAC,IAAI,EAAE,GAAG,EAAE,OAAO,EAAE,KAAK,CAAC,CAAA;oBAC1C,CAAC;oBACD,IAAI,OAAO,GAAG,GAAG,EAAE,CAAC;wBAClB,OAAO,EAAE,CAAA;wBACT,SAAQ;oBACV,CAAC;gBACH,CAAC;gBACD,MAAM,EAAE,CAAA;YACV,CAAC;QACH,CAAC;IACH,CAAC,CAAA;IAED,OAAO,MAAM,CAAA;AACf,CAAC,CAAA;AAjCY,QAAA,SAAS,aAiCrB;AAED,uCAAuC;AAChC,MAAM,aAAa,GAAG,CAAI,EAAuB,EAAE,EAAE;IAC1D,MAAM,MAAM,GAAG,CAAC,IAAY,EAAE,GAAkB,EAAE,EAAE;QAClD,MAAM,GAAG,GAAG,GAAG,CAAC,UAAU,IAAI,kBAAU,CAAA;QACxC,IAAI,OAAO,GAAG,CAAC,CAAA;QACf,OAAO,IAAI,EAAE,CAAC;YACZ,IAAI,CAAC;gBACH,OAAO,EAAE,CAAC,IAAI,CAAC,CAAA;YACjB,CAAC;YAAC,OAAO,EAAE,EAAE,CAAC;gBACZ,IACE,IAAA,oBAAS,EAAC,EAAE,CAAC;oBACb,EAAE,CAAC,IAAI,KAAK,IAAI;oBAChB,aAAK,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC;oBAClB,OAAO,GAAG,GAAG,EACb,CAAC;oBACD,OAAO,EAAE,CAAA;oBACT,SAAQ;gBACV,CAAC;gBACD,MAAM,EAAE,CAAA;YACV,CAAC;QACH,CAAC;IACH,CAAC,CAAA;IACD,OAAO,MAAM,CAAA;AACf,CAAC,CAAA;AAtBY,QAAA,aAAa,iBAsBzB","sourcesContent":["// note: max backoff is the maximum that any *single* backoff will do\n\nimport { setTimeout } from 'timers/promises'\nimport { RimrafAsyncOptions, RimrafOptions } from './index.js'\nimport { isFsError } from './error.js'\n\nexport const MAXBACKOFF = 200\nexport const RATE = 1.2\nexport const MAXRETRIES = 10\nexport const codes = new Set(['EMFILE', 'ENFILE', 'EBUSY'])\n\nexport const retryBusy = <T>(fn: (path: string) => Promise<T>) => {\n const method = async (\n path: string,\n opt: RimrafAsyncOptions,\n backoff = 1,\n total = 0,\n ) => {\n const mbo = opt.maxBackoff || MAXBACKOFF\n const rate = opt.backoff || RATE\n const max = opt.maxRetries || MAXRETRIES\n let retries = 0\n while (true) {\n try {\n return await fn(path)\n } catch (er) {\n if (isFsError(er) && er.path === path && codes.has(er.code)) {\n backoff = Math.ceil(backoff * rate)\n total = backoff + total\n if (total < mbo) {\n await setTimeout(backoff)\n return method(path, opt, backoff, total)\n }\n if (retries < max) {\n retries++\n continue\n }\n }\n throw er\n }\n }\n }\n\n return method\n}\n\n// just retries, no async so no backoff\nexport const retryBusySync = <T>(fn: (path: string) => T) => {\n const method = (path: string, opt: RimrafOptions) => {\n const max = opt.maxRetries || MAXRETRIES\n let retries = 0\n while (true) {\n try {\n return fn(path)\n } catch (er) {\n if (\n isFsError(er) &&\n er.path === path &&\n codes.has(er.code) &&\n retries < max\n ) {\n retries++\n continue\n }\n throw er\n }\n }\n }\n return method\n}\n"]}
|
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
export declare const rimrafManual: (path: string, opt: import("./opt-arg.js").RimrafAsyncOptions) => Promise<boolean>;
|
|
2
|
-
export declare const rimrafManualSync: (path: string, opt: import("./opt-arg.js").RimrafSyncOptions) => boolean;
|
|
3
|
-
//# sourceMappingURL=rimraf-manual.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"rimraf-manual.d.ts","sourceRoot":"","sources":["../../src/rimraf-manual.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,YAAY,oFACmC,CAAA;AAC5D,eAAO,MAAM,gBAAgB,0EACuC,CAAA"}
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.rimrafManualSync = exports.rimrafManual = void 0;
|
|
4
|
-
const rimraf_posix_js_1 = require("./rimraf-posix.js");
|
|
5
|
-
const rimraf_windows_js_1 = require("./rimraf-windows.js");
|
|
6
|
-
exports.rimrafManual = process.platform === 'win32' ? rimraf_windows_js_1.rimrafWindows : rimraf_posix_js_1.rimrafPosix;
|
|
7
|
-
exports.rimrafManualSync = process.platform === 'win32' ? rimraf_windows_js_1.rimrafWindowsSync : rimraf_posix_js_1.rimrafPosixSync;
|
|
8
|
-
//# sourceMappingURL=rimraf-manual.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"rimraf-manual.js","sourceRoot":"","sources":["../../src/rimraf-manual.ts"],"names":[],"mappings":";;;AAAA,uDAAgE;AAChE,2DAAsE;AAEzD,QAAA,YAAY,GACvB,OAAO,CAAC,QAAQ,KAAK,OAAO,CAAC,CAAC,CAAC,iCAAa,CAAC,CAAC,CAAC,6BAAW,CAAA;AAC/C,QAAA,gBAAgB,GAC3B,OAAO,CAAC,QAAQ,KAAK,OAAO,CAAC,CAAC,CAAC,qCAAiB,CAAC,CAAC,CAAC,iCAAe,CAAA","sourcesContent":["import { rimrafPosix, rimrafPosixSync } from './rimraf-posix.js'\nimport { rimrafWindows, rimrafWindowsSync } from './rimraf-windows.js'\n\nexport const rimrafManual =\n process.platform === 'win32' ? rimrafWindows : rimrafPosix\nexport const rimrafManualSync =\n process.platform === 'win32' ? rimrafWindowsSync : rimrafPosixSync\n"]}
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import { RimrafAsyncOptions, RimrafSyncOptions } from './index.js';
|
|
2
|
-
export declare const rimrafMoveRemove: (path: string, opt: RimrafAsyncOptions) => Promise<boolean>;
|
|
3
|
-
export declare const rimrafMoveRemoveSync: (path: string, opt: RimrafSyncOptions) => boolean;
|
|
4
|
-
//# sourceMappingURL=rimraf-move-remove.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"rimraf-move-remove.d.ts","sourceRoot":"","sources":["../../src/rimraf-move-remove.ts"],"names":[],"mappings":"AAkBA,OAAO,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAA;AAYlE,eAAO,MAAM,gBAAgB,GAC3B,MAAM,MAAM,EACZ,KAAK,kBAAkB,qBAQxB,CAAA;AA0ED,eAAO,MAAM,oBAAoB,GAAI,MAAM,MAAM,EAAE,KAAK,iBAAiB,YAOxE,CAAA"}
|
|
@@ -1,138 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
// https://youtu.be/uhRWMGBjlO8?t=537
|
|
3
|
-
//
|
|
4
|
-
// 1. readdir
|
|
5
|
-
// 2. for each entry
|
|
6
|
-
// a. if a non-empty directory, recurse
|
|
7
|
-
// b. if an empty directory, move to random hidden file name in $TEMP
|
|
8
|
-
// c. unlink/rmdir $TEMP
|
|
9
|
-
//
|
|
10
|
-
// This works around the fact that unlink/rmdir is non-atomic and takes
|
|
11
|
-
// a non-deterministic amount of time to complete.
|
|
12
|
-
//
|
|
13
|
-
// However, it is HELLA SLOW, like 2-10x slower than a naive recursive rm.
|
|
14
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
-
exports.rimrafMoveRemoveSync = exports.rimrafMoveRemove = void 0;
|
|
16
|
-
const path_1 = require("path");
|
|
17
|
-
const default_tmp_js_1 = require("./default-tmp.js");
|
|
18
|
-
const ignore_enoent_js_1 = require("./ignore-enoent.js");
|
|
19
|
-
const fs_js_1 = require("./fs.js");
|
|
20
|
-
const readdir_or_error_js_1 = require("./readdir-or-error.js");
|
|
21
|
-
const fix_eperm_js_1 = require("./fix-eperm.js");
|
|
22
|
-
const error_js_1 = require("./error.js");
|
|
23
|
-
const { lstat, rename, unlink, rmdir } = fs_js_1.promises;
|
|
24
|
-
// crypto.randomBytes is much slower, and Math.random() is enough here
|
|
25
|
-
const uniqueFilename = (path) => `.${(0, path_1.basename)(path)}.${Math.random()}`;
|
|
26
|
-
const unlinkFixEPERM = (0, fix_eperm_js_1.fixEPERM)(unlink);
|
|
27
|
-
const unlinkFixEPERMSync = (0, fix_eperm_js_1.fixEPERMSync)(fs_js_1.unlinkSync);
|
|
28
|
-
const rimrafMoveRemove = async (path, opt) => {
|
|
29
|
-
opt?.signal?.throwIfAborted();
|
|
30
|
-
return ((await (0, ignore_enoent_js_1.ignoreENOENT)(lstat(path).then(stat => rimrafMoveRemoveDir(path, opt, stat)))) ?? true);
|
|
31
|
-
};
|
|
32
|
-
exports.rimrafMoveRemove = rimrafMoveRemove;
|
|
33
|
-
const rimrafMoveRemoveDir = async (path, opt, ent) => {
|
|
34
|
-
opt?.signal?.throwIfAborted();
|
|
35
|
-
if (!opt.tmp) {
|
|
36
|
-
return rimrafMoveRemoveDir(path, { ...opt, tmp: await (0, default_tmp_js_1.defaultTmp)(path) }, ent);
|
|
37
|
-
}
|
|
38
|
-
if (path === opt.tmp && (0, path_1.parse)(path).root !== path) {
|
|
39
|
-
throw new Error('cannot delete temp directory used for deletion');
|
|
40
|
-
}
|
|
41
|
-
const entries = ent.isDirectory() ? await (0, readdir_or_error_js_1.readdirOrError)(path) : null;
|
|
42
|
-
if (!Array.isArray(entries)) {
|
|
43
|
-
// this can only happen if lstat/readdir lied, or if the dir was
|
|
44
|
-
// swapped out with a file at just the right moment.
|
|
45
|
-
/* c8 ignore start */
|
|
46
|
-
if (entries) {
|
|
47
|
-
if ((0, error_js_1.errorCode)(entries) === 'ENOENT') {
|
|
48
|
-
return true;
|
|
49
|
-
}
|
|
50
|
-
if ((0, error_js_1.errorCode)(entries) !== 'ENOTDIR') {
|
|
51
|
-
throw entries;
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
/* c8 ignore stop */
|
|
55
|
-
if (opt.filter && !(await opt.filter(path, ent))) {
|
|
56
|
-
return false;
|
|
57
|
-
}
|
|
58
|
-
await (0, ignore_enoent_js_1.ignoreENOENT)(tmpUnlink(path, opt.tmp, unlinkFixEPERM));
|
|
59
|
-
return true;
|
|
60
|
-
}
|
|
61
|
-
const removedAll = (await Promise.all(entries.map(ent => rimrafMoveRemoveDir((0, path_1.resolve)(path, ent.name), opt, ent)))).every(v => v === true);
|
|
62
|
-
if (!removedAll) {
|
|
63
|
-
return false;
|
|
64
|
-
}
|
|
65
|
-
// we don't ever ACTUALLY try to unlink /, because that can never work
|
|
66
|
-
// but when preserveRoot is false, we could be operating on it.
|
|
67
|
-
// No need to check if preserveRoot is not false.
|
|
68
|
-
if (opt.preserveRoot === false && path === (0, path_1.parse)(path).root) {
|
|
69
|
-
return false;
|
|
70
|
-
}
|
|
71
|
-
if (opt.filter && !(await opt.filter(path, ent))) {
|
|
72
|
-
return false;
|
|
73
|
-
}
|
|
74
|
-
await (0, ignore_enoent_js_1.ignoreENOENT)(tmpUnlink(path, opt.tmp, rmdir));
|
|
75
|
-
return true;
|
|
76
|
-
};
|
|
77
|
-
const tmpUnlink = async (path, tmp, rm) => {
|
|
78
|
-
const tmpFile = (0, path_1.resolve)(tmp, uniqueFilename(path));
|
|
79
|
-
await rename(path, tmpFile);
|
|
80
|
-
return await rm(tmpFile);
|
|
81
|
-
};
|
|
82
|
-
const rimrafMoveRemoveSync = (path, opt) => {
|
|
83
|
-
opt?.signal?.throwIfAborted();
|
|
84
|
-
return ((0, ignore_enoent_js_1.ignoreENOENTSync)(() => rimrafMoveRemoveDirSync(path, opt, (0, fs_js_1.lstatSync)(path))) ?? true);
|
|
85
|
-
};
|
|
86
|
-
exports.rimrafMoveRemoveSync = rimrafMoveRemoveSync;
|
|
87
|
-
const rimrafMoveRemoveDirSync = (path, opt, ent) => {
|
|
88
|
-
opt?.signal?.throwIfAborted();
|
|
89
|
-
if (!opt.tmp) {
|
|
90
|
-
return rimrafMoveRemoveDirSync(path, { ...opt, tmp: (0, default_tmp_js_1.defaultTmpSync)(path) }, ent);
|
|
91
|
-
}
|
|
92
|
-
const tmp = opt.tmp;
|
|
93
|
-
if (path === opt.tmp && (0, path_1.parse)(path).root !== path) {
|
|
94
|
-
throw new Error('cannot delete temp directory used for deletion');
|
|
95
|
-
}
|
|
96
|
-
const entries = ent.isDirectory() ? (0, readdir_or_error_js_1.readdirOrErrorSync)(path) : null;
|
|
97
|
-
if (!Array.isArray(entries)) {
|
|
98
|
-
// this can only happen if lstat/readdir lied, or if the dir was
|
|
99
|
-
// swapped out with a file at just the right moment.
|
|
100
|
-
/* c8 ignore start */
|
|
101
|
-
if (entries) {
|
|
102
|
-
if ((0, error_js_1.errorCode)(entries) === 'ENOENT') {
|
|
103
|
-
return true;
|
|
104
|
-
}
|
|
105
|
-
if ((0, error_js_1.errorCode)(entries) !== 'ENOTDIR') {
|
|
106
|
-
throw entries;
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
/* c8 ignore stop */
|
|
110
|
-
if (opt.filter && !opt.filter(path, ent)) {
|
|
111
|
-
return false;
|
|
112
|
-
}
|
|
113
|
-
(0, ignore_enoent_js_1.ignoreENOENTSync)(() => tmpUnlinkSync(path, tmp, unlinkFixEPERMSync));
|
|
114
|
-
return true;
|
|
115
|
-
}
|
|
116
|
-
let removedAll = true;
|
|
117
|
-
for (const ent of entries) {
|
|
118
|
-
const p = (0, path_1.resolve)(path, ent.name);
|
|
119
|
-
removedAll = rimrafMoveRemoveDirSync(p, opt, ent) && removedAll;
|
|
120
|
-
}
|
|
121
|
-
if (!removedAll) {
|
|
122
|
-
return false;
|
|
123
|
-
}
|
|
124
|
-
if (opt.preserveRoot === false && path === (0, path_1.parse)(path).root) {
|
|
125
|
-
return false;
|
|
126
|
-
}
|
|
127
|
-
if (opt.filter && !opt.filter(path, ent)) {
|
|
128
|
-
return false;
|
|
129
|
-
}
|
|
130
|
-
(0, ignore_enoent_js_1.ignoreENOENTSync)(() => tmpUnlinkSync(path, tmp, fs_js_1.rmdirSync));
|
|
131
|
-
return true;
|
|
132
|
-
};
|
|
133
|
-
const tmpUnlinkSync = (path, tmp, rmSync) => {
|
|
134
|
-
const tmpFile = (0, path_1.resolve)(tmp, uniqueFilename(path));
|
|
135
|
-
(0, fs_js_1.renameSync)(path, tmpFile);
|
|
136
|
-
return rmSync(tmpFile);
|
|
137
|
-
};
|
|
138
|
-
//# sourceMappingURL=rimraf-move-remove.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"rimraf-move-remove.js","sourceRoot":"","sources":["../../src/rimraf-move-remove.ts"],"names":[],"mappings":"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","sourcesContent":["// https://youtu.be/uhRWMGBjlO8?t=537\n//\n// 1. readdir\n// 2. for each entry\n// a. if a non-empty directory, recurse\n// b. if an empty directory, move to random hidden file name in $TEMP\n// c. unlink/rmdir $TEMP\n//\n// This works around the fact that unlink/rmdir is non-atomic and takes\n// a non-deterministic amount of time to complete.\n//\n// However, it is HELLA SLOW, like 2-10x slower than a naive recursive rm.\n\nimport { basename, parse, resolve } from 'path'\nimport { defaultTmp, defaultTmpSync } from './default-tmp.js'\nimport { ignoreENOENT, ignoreENOENTSync } from './ignore-enoent.js'\nimport { lstatSync, promises, renameSync, rmdirSync, unlinkSync } from './fs.js'\nimport { Dirent, Stats } from 'fs'\nimport { RimrafAsyncOptions, RimrafSyncOptions } from './index.js'\nimport { readdirOrError, readdirOrErrorSync } from './readdir-or-error.js'\nimport { fixEPERM, fixEPERMSync } from './fix-eperm.js'\nimport { errorCode } from './error.js'\nconst { lstat, rename, unlink, rmdir } = promises\n\n// crypto.randomBytes is much slower, and Math.random() is enough here\nconst uniqueFilename = (path: string) => `.${basename(path)}.${Math.random()}`\n\nconst unlinkFixEPERM = fixEPERM(unlink)\nconst unlinkFixEPERMSync = fixEPERMSync(unlinkSync)\n\nexport const rimrafMoveRemove = async (\n path: string,\n opt: RimrafAsyncOptions,\n) => {\n opt?.signal?.throwIfAborted()\n return (\n (await ignoreENOENT(\n lstat(path).then(stat => rimrafMoveRemoveDir(path, opt, stat)),\n )) ?? true\n )\n}\n\nconst rimrafMoveRemoveDir = async (\n path: string,\n opt: RimrafAsyncOptions,\n ent: Dirent | Stats,\n): Promise<boolean> => {\n opt?.signal?.throwIfAborted()\n if (!opt.tmp) {\n return rimrafMoveRemoveDir(\n path,\n { ...opt, tmp: await defaultTmp(path) },\n ent,\n )\n }\n if (path === opt.tmp && parse(path).root !== path) {\n throw new Error('cannot delete temp directory used for deletion')\n }\n\n const entries = ent.isDirectory() ? await readdirOrError(path) : null\n if (!Array.isArray(entries)) {\n // this can only happen if lstat/readdir lied, or if the dir was\n // swapped out with a file at just the right moment.\n /* c8 ignore start */\n if (entries) {\n if (errorCode(entries) === 'ENOENT') {\n return true\n }\n if (errorCode(entries) !== 'ENOTDIR') {\n throw entries\n }\n }\n /* c8 ignore stop */\n if (opt.filter && !(await opt.filter(path, ent))) {\n return false\n }\n await ignoreENOENT(tmpUnlink(path, opt.tmp, unlinkFixEPERM))\n return true\n }\n\n const removedAll = (\n await Promise.all(\n entries.map(ent =>\n rimrafMoveRemoveDir(resolve(path, ent.name), opt, ent),\n ),\n )\n ).every(v => v === true)\n if (!removedAll) {\n return false\n }\n\n // we don't ever ACTUALLY try to unlink /, because that can never work\n // but when preserveRoot is false, we could be operating on it.\n // No need to check if preserveRoot is not false.\n if (opt.preserveRoot === false && path === parse(path).root) {\n return false\n }\n if (opt.filter && !(await opt.filter(path, ent))) {\n return false\n }\n await ignoreENOENT(tmpUnlink(path, opt.tmp, rmdir))\n return true\n}\n\nconst tmpUnlink = async <T>(\n path: string,\n tmp: string,\n rm: (p: string) => Promise<T>,\n) => {\n const tmpFile = resolve(tmp, uniqueFilename(path))\n await rename(path, tmpFile)\n return await rm(tmpFile)\n}\n\nexport const rimrafMoveRemoveSync = (path: string, opt: RimrafSyncOptions) => {\n opt?.signal?.throwIfAborted()\n return (\n ignoreENOENTSync(() =>\n rimrafMoveRemoveDirSync(path, opt, lstatSync(path)),\n ) ?? true\n )\n}\n\nconst rimrafMoveRemoveDirSync = (\n path: string,\n opt: RimrafSyncOptions,\n ent: Dirent | Stats,\n): boolean => {\n opt?.signal?.throwIfAborted()\n if (!opt.tmp) {\n return rimrafMoveRemoveDirSync(\n path,\n { ...opt, tmp: defaultTmpSync(path) },\n ent,\n )\n }\n const tmp: string = opt.tmp\n\n if (path === opt.tmp && parse(path).root !== path) {\n throw new Error('cannot delete temp directory used for deletion')\n }\n\n const entries = ent.isDirectory() ? readdirOrErrorSync(path) : null\n if (!Array.isArray(entries)) {\n // this can only happen if lstat/readdir lied, or if the dir was\n // swapped out with a file at just the right moment.\n /* c8 ignore start */\n if (entries) {\n if (errorCode(entries) === 'ENOENT') {\n return true\n }\n if (errorCode(entries) !== 'ENOTDIR') {\n throw entries\n }\n }\n /* c8 ignore stop */\n if (opt.filter && !opt.filter(path, ent)) {\n return false\n }\n ignoreENOENTSync(() => tmpUnlinkSync(path, tmp, unlinkFixEPERMSync))\n return true\n }\n\n let removedAll = true\n for (const ent of entries) {\n const p = resolve(path, ent.name)\n removedAll = rimrafMoveRemoveDirSync(p, opt, ent) && removedAll\n }\n if (!removedAll) {\n return false\n }\n if (opt.preserveRoot === false && path === parse(path).root) {\n return false\n }\n if (opt.filter && !opt.filter(path, ent)) {\n return false\n }\n ignoreENOENTSync(() => tmpUnlinkSync(path, tmp, rmdirSync))\n return true\n}\n\nconst tmpUnlinkSync = (\n path: string,\n tmp: string,\n rmSync: (p: string) => void,\n) => {\n const tmpFile = resolve(tmp, uniqueFilename(path))\n renameSync(path, tmpFile)\n return rmSync(tmpFile)\n}\n"]}
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import { RimrafAsyncOptions, RimrafSyncOptions } from './index.js';
|
|
2
|
-
export declare const rimrafNative: (path: string, opt: RimrafAsyncOptions) => Promise<boolean>;
|
|
3
|
-
export declare const rimrafNativeSync: (path: string, opt: RimrafSyncOptions) => boolean;
|
|
4
|
-
//# sourceMappingURL=rimraf-native.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"rimraf-native.d.ts","sourceRoot":"","sources":["../../src/rimraf-native.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAA;AAIlE,eAAO,MAAM,YAAY,GACvB,MAAM,MAAM,EACZ,KAAK,kBAAkB,KACtB,OAAO,CAAC,OAAO,CAOjB,CAAA;AAED,eAAO,MAAM,gBAAgB,GAC3B,MAAM,MAAM,EACZ,KAAK,iBAAiB,KACrB,OAOF,CAAA"}
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.rimrafNativeSync = exports.rimrafNative = void 0;
|
|
4
|
-
const fs_js_1 = require("./fs.js");
|
|
5
|
-
const { rm } = fs_js_1.promises;
|
|
6
|
-
const rimrafNative = async (path, opt) => {
|
|
7
|
-
await rm(path, {
|
|
8
|
-
...opt,
|
|
9
|
-
force: true,
|
|
10
|
-
recursive: true,
|
|
11
|
-
});
|
|
12
|
-
return true;
|
|
13
|
-
};
|
|
14
|
-
exports.rimrafNative = rimrafNative;
|
|
15
|
-
const rimrafNativeSync = (path, opt) => {
|
|
16
|
-
(0, fs_js_1.rmSync)(path, {
|
|
17
|
-
...opt,
|
|
18
|
-
force: true,
|
|
19
|
-
recursive: true,
|
|
20
|
-
});
|
|
21
|
-
return true;
|
|
22
|
-
};
|
|
23
|
-
exports.rimrafNativeSync = rimrafNativeSync;
|
|
24
|
-
//# sourceMappingURL=rimraf-native.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"rimraf-native.js","sourceRoot":"","sources":["../../src/rimraf-native.ts"],"names":[],"mappings":";;;AACA,mCAA0C;AAC1C,MAAM,EAAE,EAAE,EAAE,GAAG,gBAAQ,CAAA;AAEhB,MAAM,YAAY,GAAG,KAAK,EAC/B,IAAY,EACZ,GAAuB,EACL,EAAE;IACpB,MAAM,EAAE,CAAC,IAAI,EAAE;QACb,GAAG,GAAG;QACN,KAAK,EAAE,IAAI;QACX,SAAS,EAAE,IAAI;KAChB,CAAC,CAAA;IACF,OAAO,IAAI,CAAA;AACb,CAAC,CAAA;AAVY,QAAA,YAAY,gBAUxB;AAEM,MAAM,gBAAgB,GAAG,CAC9B,IAAY,EACZ,GAAsB,EACb,EAAE;IACX,IAAA,cAAM,EAAC,IAAI,EAAE;QACX,GAAG,GAAG;QACN,KAAK,EAAE,IAAI;QACX,SAAS,EAAE,IAAI;KAChB,CAAC,CAAA;IACF,OAAO,IAAI,CAAA;AACb,CAAC,CAAA;AAVY,QAAA,gBAAgB,oBAU5B","sourcesContent":["import { RimrafAsyncOptions, RimrafSyncOptions } from './index.js'\nimport { promises, rmSync } from './fs.js'\nconst { rm } = promises\n\nexport const rimrafNative = async (\n path: string,\n opt: RimrafAsyncOptions,\n): Promise<boolean> => {\n await rm(path, {\n ...opt,\n force: true,\n recursive: true,\n })\n return true\n}\n\nexport const rimrafNativeSync = (\n path: string,\n opt: RimrafSyncOptions,\n): boolean => {\n rmSync(path, {\n ...opt,\n force: true,\n recursive: true,\n })\n return true\n}\n"]}
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import { RimrafAsyncOptions, RimrafSyncOptions } from './index.js';
|
|
2
|
-
export declare const rimrafPosix: (path: string, opt: RimrafAsyncOptions) => Promise<boolean>;
|
|
3
|
-
export declare const rimrafPosixSync: (path: string, opt: RimrafSyncOptions) => boolean;
|
|
4
|
-
//# sourceMappingURL=rimraf-posix.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"rimraf-posix.d.ts","sourceRoot":"","sources":["../../src/rimraf-posix.ts"],"names":[],"mappings":"AAUA,OAAO,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAA;AAKlE,eAAO,MAAM,WAAW,GAAU,MAAM,MAAM,EAAE,KAAK,kBAAkB,qBAOtE,CAAA;AAED,eAAO,MAAM,eAAe,GAAI,MAAM,MAAM,EAAE,KAAK,iBAAiB,YAMnE,CAAA"}
|
|
@@ -1,103 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
// the simple recursive removal, where unlink and rmdir are atomic
|
|
3
|
-
// Note that this approach does NOT work on Windows!
|
|
4
|
-
// We stat first and only unlink if the Dirent isn't a directory,
|
|
5
|
-
// because sunos will let root unlink a directory, and some
|
|
6
|
-
// SUPER weird breakage happens as a result.
|
|
7
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
-
exports.rimrafPosixSync = exports.rimrafPosix = void 0;
|
|
9
|
-
const fs_js_1 = require("./fs.js");
|
|
10
|
-
const path_1 = require("path");
|
|
11
|
-
const readdir_or_error_js_1 = require("./readdir-or-error.js");
|
|
12
|
-
const ignore_enoent_js_1 = require("./ignore-enoent.js");
|
|
13
|
-
const error_js_1 = require("./error.js");
|
|
14
|
-
const { lstat, rmdir, unlink } = fs_js_1.promises;
|
|
15
|
-
const rimrafPosix = async (path, opt) => {
|
|
16
|
-
opt?.signal?.throwIfAborted();
|
|
17
|
-
return ((await (0, ignore_enoent_js_1.ignoreENOENT)(lstat(path).then(stat => rimrafPosixDir(path, opt, stat)))) ?? true);
|
|
18
|
-
};
|
|
19
|
-
exports.rimrafPosix = rimrafPosix;
|
|
20
|
-
const rimrafPosixSync = (path, opt) => {
|
|
21
|
-
opt?.signal?.throwIfAborted();
|
|
22
|
-
return ((0, ignore_enoent_js_1.ignoreENOENTSync)(() => rimrafPosixDirSync(path, opt, (0, fs_js_1.lstatSync)(path))) ??
|
|
23
|
-
true);
|
|
24
|
-
};
|
|
25
|
-
exports.rimrafPosixSync = rimrafPosixSync;
|
|
26
|
-
const rimrafPosixDir = async (path, opt, ent) => {
|
|
27
|
-
opt?.signal?.throwIfAborted();
|
|
28
|
-
const entries = ent.isDirectory() ? await (0, readdir_or_error_js_1.readdirOrError)(path) : null;
|
|
29
|
-
if (!Array.isArray(entries)) {
|
|
30
|
-
// this can only happen if lstat/readdir lied, or if the dir was
|
|
31
|
-
// swapped out with a file at just the right moment.
|
|
32
|
-
/* c8 ignore start */
|
|
33
|
-
if (entries) {
|
|
34
|
-
if ((0, error_js_1.errorCode)(entries) === 'ENOENT') {
|
|
35
|
-
return true;
|
|
36
|
-
}
|
|
37
|
-
if ((0, error_js_1.errorCode)(entries) !== 'ENOTDIR') {
|
|
38
|
-
throw entries;
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
/* c8 ignore stop */
|
|
42
|
-
if (opt.filter && !(await opt.filter(path, ent))) {
|
|
43
|
-
return false;
|
|
44
|
-
}
|
|
45
|
-
await (0, ignore_enoent_js_1.ignoreENOENT)(unlink(path));
|
|
46
|
-
return true;
|
|
47
|
-
}
|
|
48
|
-
const removedAll = (await Promise.all(entries.map(ent => rimrafPosixDir((0, path_1.resolve)(path, ent.name), opt, ent)))).every(v => v === true);
|
|
49
|
-
if (!removedAll) {
|
|
50
|
-
return false;
|
|
51
|
-
}
|
|
52
|
-
// we don't ever ACTUALLY try to unlink /, because that can never work
|
|
53
|
-
// but when preserveRoot is false, we could be operating on it.
|
|
54
|
-
// No need to check if preserveRoot is not false.
|
|
55
|
-
if (opt.preserveRoot === false && path === (0, path_1.parse)(path).root) {
|
|
56
|
-
return false;
|
|
57
|
-
}
|
|
58
|
-
if (opt.filter && !(await opt.filter(path, ent))) {
|
|
59
|
-
return false;
|
|
60
|
-
}
|
|
61
|
-
await (0, ignore_enoent_js_1.ignoreENOENT)(rmdir(path));
|
|
62
|
-
return true;
|
|
63
|
-
};
|
|
64
|
-
const rimrafPosixDirSync = (path, opt, ent) => {
|
|
65
|
-
opt?.signal?.throwIfAborted();
|
|
66
|
-
const entries = ent.isDirectory() ? (0, readdir_or_error_js_1.readdirOrErrorSync)(path) : null;
|
|
67
|
-
if (!Array.isArray(entries)) {
|
|
68
|
-
// this can only happen if lstat/readdir lied, or if the dir was
|
|
69
|
-
// swapped out with a file at just the right moment.
|
|
70
|
-
/* c8 ignore start */
|
|
71
|
-
if (entries) {
|
|
72
|
-
if ((0, error_js_1.errorCode)(entries) === 'ENOENT') {
|
|
73
|
-
return true;
|
|
74
|
-
}
|
|
75
|
-
if ((0, error_js_1.errorCode)(entries) !== 'ENOTDIR') {
|
|
76
|
-
throw entries;
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
/* c8 ignore stop */
|
|
80
|
-
if (opt.filter && !opt.filter(path, ent)) {
|
|
81
|
-
return false;
|
|
82
|
-
}
|
|
83
|
-
(0, ignore_enoent_js_1.ignoreENOENTSync)(() => (0, fs_js_1.unlinkSync)(path));
|
|
84
|
-
return true;
|
|
85
|
-
}
|
|
86
|
-
let removedAll = true;
|
|
87
|
-
for (const ent of entries) {
|
|
88
|
-
const p = (0, path_1.resolve)(path, ent.name);
|
|
89
|
-
removedAll = rimrafPosixDirSync(p, opt, ent) && removedAll;
|
|
90
|
-
}
|
|
91
|
-
if (opt.preserveRoot === false && path === (0, path_1.parse)(path).root) {
|
|
92
|
-
return false;
|
|
93
|
-
}
|
|
94
|
-
if (!removedAll) {
|
|
95
|
-
return false;
|
|
96
|
-
}
|
|
97
|
-
if (opt.filter && !opt.filter(path, ent)) {
|
|
98
|
-
return false;
|
|
99
|
-
}
|
|
100
|
-
(0, ignore_enoent_js_1.ignoreENOENTSync)(() => (0, fs_js_1.rmdirSync)(path));
|
|
101
|
-
return true;
|
|
102
|
-
};
|
|
103
|
-
//# sourceMappingURL=rimraf-posix.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"rimraf-posix.js","sourceRoot":"","sources":["../../src/rimraf-posix.ts"],"names":[],"mappings":"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","sourcesContent":["// the simple recursive removal, where unlink and rmdir are atomic\n// Note that this approach does NOT work on Windows!\n// We stat first and only unlink if the Dirent isn't a directory,\n// because sunos will let root unlink a directory, and some\n// SUPER weird breakage happens as a result.\n\nimport { lstatSync, promises, rmdirSync, unlinkSync } from './fs.js'\nimport { parse, resolve } from 'path'\nimport { readdirOrError, readdirOrErrorSync } from './readdir-or-error.js'\nimport { Dirent, Stats } from 'fs'\nimport { RimrafAsyncOptions, RimrafSyncOptions } from './index.js'\nimport { ignoreENOENT, ignoreENOENTSync } from './ignore-enoent.js'\nimport { errorCode } from './error.js'\nconst { lstat, rmdir, unlink } = promises\n\nexport const rimrafPosix = async (path: string, opt: RimrafAsyncOptions) => {\n opt?.signal?.throwIfAborted()\n return (\n (await ignoreENOENT(\n lstat(path).then(stat => rimrafPosixDir(path, opt, stat)),\n )) ?? true\n )\n}\n\nexport const rimrafPosixSync = (path: string, opt: RimrafSyncOptions) => {\n opt?.signal?.throwIfAborted()\n return (\n ignoreENOENTSync(() => rimrafPosixDirSync(path, opt, lstatSync(path))) ??\n true\n )\n}\n\nconst rimrafPosixDir = async (\n path: string,\n opt: RimrafAsyncOptions,\n ent: Dirent | Stats,\n): Promise<boolean> => {\n opt?.signal?.throwIfAborted()\n const entries = ent.isDirectory() ? await readdirOrError(path) : null\n if (!Array.isArray(entries)) {\n // this can only happen if lstat/readdir lied, or if the dir was\n // swapped out with a file at just the right moment.\n /* c8 ignore start */\n if (entries) {\n if (errorCode(entries) === 'ENOENT') {\n return true\n }\n if (errorCode(entries) !== 'ENOTDIR') {\n throw entries\n }\n }\n /* c8 ignore stop */\n if (opt.filter && !(await opt.filter(path, ent))) {\n return false\n }\n await ignoreENOENT(unlink(path))\n return true\n }\n\n const removedAll = (\n await Promise.all(\n entries.map(ent => rimrafPosixDir(resolve(path, ent.name), opt, ent)),\n )\n ).every(v => v === true)\n\n if (!removedAll) {\n return false\n }\n\n // we don't ever ACTUALLY try to unlink /, because that can never work\n // but when preserveRoot is false, we could be operating on it.\n // No need to check if preserveRoot is not false.\n if (opt.preserveRoot === false && path === parse(path).root) {\n return false\n }\n\n if (opt.filter && !(await opt.filter(path, ent))) {\n return false\n }\n\n await ignoreENOENT(rmdir(path))\n return true\n}\n\nconst rimrafPosixDirSync = (\n path: string,\n opt: RimrafSyncOptions,\n ent: Dirent | Stats,\n): boolean => {\n opt?.signal?.throwIfAborted()\n const entries = ent.isDirectory() ? readdirOrErrorSync(path) : null\n if (!Array.isArray(entries)) {\n // this can only happen if lstat/readdir lied, or if the dir was\n // swapped out with a file at just the right moment.\n /* c8 ignore start */\n if (entries) {\n if (errorCode(entries) === 'ENOENT') {\n return true\n }\n if (errorCode(entries) !== 'ENOTDIR') {\n throw entries\n }\n }\n /* c8 ignore stop */\n if (opt.filter && !opt.filter(path, ent)) {\n return false\n }\n ignoreENOENTSync(() => unlinkSync(path))\n return true\n }\n let removedAll: boolean = true\n for (const ent of entries) {\n const p = resolve(path, ent.name)\n removedAll = rimrafPosixDirSync(p, opt, ent) && removedAll\n }\n if (opt.preserveRoot === false && path === parse(path).root) {\n return false\n }\n\n if (!removedAll) {\n return false\n }\n\n if (opt.filter && !opt.filter(path, ent)) {\n return false\n }\n\n ignoreENOENTSync(() => rmdirSync(path))\n return true\n}\n"]}
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import { RimrafAsyncOptions, RimrafSyncOptions } from './index.js';
|
|
2
|
-
export declare const rimrafWindows: (path: string, opt: RimrafAsyncOptions) => Promise<boolean>;
|
|
3
|
-
export declare const rimrafWindowsSync: (path: string, opt: RimrafSyncOptions) => boolean;
|
|
4
|
-
//# sourceMappingURL=rimraf-windows.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"rimraf-windows.d.ts","sourceRoot":"","sources":["../../src/rimraf-windows.ts"],"names":[],"mappings":"AAYA,OAAO,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAA;AAwDlE,eAAO,MAAM,aAAa,GAAU,MAAM,MAAM,EAAE,KAAK,kBAAkB,qBAOxE,CAAA;AAED,eAAO,MAAM,iBAAiB,GAAI,MAAM,MAAM,EAAE,KAAK,iBAAiB,YAOrE,CAAA"}
|
|
@@ -1,159 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
// This is the same as rimrafPosix, with the following changes:
|
|
3
|
-
//
|
|
4
|
-
// 1. EBUSY, ENFILE, EMFILE trigger retries and/or exponential backoff
|
|
5
|
-
// 2. All non-directories are removed first and then all directories are
|
|
6
|
-
// removed in a second sweep.
|
|
7
|
-
// 3. If we hit ENOTEMPTY in the second sweep, fall back to move-remove on
|
|
8
|
-
// the that folder.
|
|
9
|
-
//
|
|
10
|
-
// Note: "move then remove" is 2-10 times slower, and just as unreliable.
|
|
11
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
exports.rimrafWindowsSync = exports.rimrafWindows = void 0;
|
|
13
|
-
const path_1 = require("path");
|
|
14
|
-
const fix_eperm_js_1 = require("./fix-eperm.js");
|
|
15
|
-
const fs_js_1 = require("./fs.js");
|
|
16
|
-
const ignore_enoent_js_1 = require("./ignore-enoent.js");
|
|
17
|
-
const readdir_or_error_js_1 = require("./readdir-or-error.js");
|
|
18
|
-
const retry_busy_js_1 = require("./retry-busy.js");
|
|
19
|
-
const rimraf_move_remove_js_1 = require("./rimraf-move-remove.js");
|
|
20
|
-
const error_js_1 = require("./error.js");
|
|
21
|
-
const { unlink, rmdir, lstat } = fs_js_1.promises;
|
|
22
|
-
const rimrafWindowsFile = (0, retry_busy_js_1.retryBusy)((0, fix_eperm_js_1.fixEPERM)(unlink));
|
|
23
|
-
const rimrafWindowsFileSync = (0, retry_busy_js_1.retryBusySync)((0, fix_eperm_js_1.fixEPERMSync)(fs_js_1.unlinkSync));
|
|
24
|
-
const rimrafWindowsDirRetry = (0, retry_busy_js_1.retryBusy)((0, fix_eperm_js_1.fixEPERM)(rmdir));
|
|
25
|
-
const rimrafWindowsDirRetrySync = (0, retry_busy_js_1.retryBusySync)((0, fix_eperm_js_1.fixEPERMSync)(fs_js_1.rmdirSync));
|
|
26
|
-
const rimrafWindowsDirMoveRemoveFallback = async (path,
|
|
27
|
-
// already filtered, remove from options so we don't call unnecessarily
|
|
28
|
-
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
29
|
-
{ filter, ...opt }) => {
|
|
30
|
-
/* c8 ignore next */
|
|
31
|
-
opt?.signal?.throwIfAborted();
|
|
32
|
-
try {
|
|
33
|
-
await rimrafWindowsDirRetry(path, opt);
|
|
34
|
-
return true;
|
|
35
|
-
}
|
|
36
|
-
catch (er) {
|
|
37
|
-
if ((0, error_js_1.errorCode)(er) === 'ENOTEMPTY') {
|
|
38
|
-
return (0, rimraf_move_remove_js_1.rimrafMoveRemove)(path, opt);
|
|
39
|
-
}
|
|
40
|
-
throw er;
|
|
41
|
-
}
|
|
42
|
-
};
|
|
43
|
-
const rimrafWindowsDirMoveRemoveFallbackSync = (path,
|
|
44
|
-
// already filtered, remove from options so we don't call unnecessarily
|
|
45
|
-
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
46
|
-
{ filter, ...opt }) => {
|
|
47
|
-
opt?.signal?.throwIfAborted();
|
|
48
|
-
try {
|
|
49
|
-
rimrafWindowsDirRetrySync(path, opt);
|
|
50
|
-
return true;
|
|
51
|
-
}
|
|
52
|
-
catch (er) {
|
|
53
|
-
if ((0, error_js_1.errorCode)(er) === 'ENOTEMPTY') {
|
|
54
|
-
return (0, rimraf_move_remove_js_1.rimrafMoveRemoveSync)(path, opt);
|
|
55
|
-
}
|
|
56
|
-
throw er;
|
|
57
|
-
}
|
|
58
|
-
};
|
|
59
|
-
const START = Symbol('start');
|
|
60
|
-
const CHILD = Symbol('child');
|
|
61
|
-
const FINISH = Symbol('finish');
|
|
62
|
-
const rimrafWindows = async (path, opt) => {
|
|
63
|
-
opt?.signal?.throwIfAborted();
|
|
64
|
-
return ((await (0, ignore_enoent_js_1.ignoreENOENT)(lstat(path).then(stat => rimrafWindowsDir(path, opt, stat, START)))) ?? true);
|
|
65
|
-
};
|
|
66
|
-
exports.rimrafWindows = rimrafWindows;
|
|
67
|
-
const rimrafWindowsSync = (path, opt) => {
|
|
68
|
-
opt?.signal?.throwIfAborted();
|
|
69
|
-
return ((0, ignore_enoent_js_1.ignoreENOENTSync)(() => rimrafWindowsDirSync(path, opt, (0, fs_js_1.lstatSync)(path), START)) ?? true);
|
|
70
|
-
};
|
|
71
|
-
exports.rimrafWindowsSync = rimrafWindowsSync;
|
|
72
|
-
const rimrafWindowsDir = async (path, opt, ent, state = START) => {
|
|
73
|
-
opt?.signal?.throwIfAborted();
|
|
74
|
-
const entries = ent.isDirectory() ? await (0, readdir_or_error_js_1.readdirOrError)(path) : null;
|
|
75
|
-
if (!Array.isArray(entries)) {
|
|
76
|
-
// this can only happen if lstat/readdir lied, or if the dir was
|
|
77
|
-
// swapped out with a file at just the right moment.
|
|
78
|
-
/* c8 ignore start */
|
|
79
|
-
if (entries) {
|
|
80
|
-
if ((0, error_js_1.errorCode)(entries) === 'ENOENT') {
|
|
81
|
-
return true;
|
|
82
|
-
}
|
|
83
|
-
if ((0, error_js_1.errorCode)(entries) !== 'ENOTDIR') {
|
|
84
|
-
throw entries;
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
/* c8 ignore stop */
|
|
88
|
-
if (opt.filter && !(await opt.filter(path, ent))) {
|
|
89
|
-
return false;
|
|
90
|
-
}
|
|
91
|
-
// is a file
|
|
92
|
-
await (0, ignore_enoent_js_1.ignoreENOENT)(rimrafWindowsFile(path, opt));
|
|
93
|
-
return true;
|
|
94
|
-
}
|
|
95
|
-
const s = state === START ? CHILD : state;
|
|
96
|
-
const removedAll = (await Promise.all(entries.map(ent => rimrafWindowsDir((0, path_1.resolve)(path, ent.name), opt, ent, s)))).every(v => v === true);
|
|
97
|
-
if (state === START) {
|
|
98
|
-
return rimrafWindowsDir(path, opt, ent, FINISH);
|
|
99
|
-
}
|
|
100
|
-
else if (state === FINISH) {
|
|
101
|
-
if (opt.preserveRoot === false && path === (0, path_1.parse)(path).root) {
|
|
102
|
-
return false;
|
|
103
|
-
}
|
|
104
|
-
if (!removedAll) {
|
|
105
|
-
return false;
|
|
106
|
-
}
|
|
107
|
-
if (opt.filter && !(await opt.filter(path, ent))) {
|
|
108
|
-
return false;
|
|
109
|
-
}
|
|
110
|
-
await (0, ignore_enoent_js_1.ignoreENOENT)(rimrafWindowsDirMoveRemoveFallback(path, opt));
|
|
111
|
-
}
|
|
112
|
-
return true;
|
|
113
|
-
};
|
|
114
|
-
const rimrafWindowsDirSync = (path, opt, ent, state = START) => {
|
|
115
|
-
const entries = ent.isDirectory() ? (0, readdir_or_error_js_1.readdirOrErrorSync)(path) : null;
|
|
116
|
-
if (!Array.isArray(entries)) {
|
|
117
|
-
// this can only happen if lstat/readdir lied, or if the dir was
|
|
118
|
-
// swapped out with a file at just the right moment.
|
|
119
|
-
/* c8 ignore start */
|
|
120
|
-
if (entries) {
|
|
121
|
-
if ((0, error_js_1.errorCode)(entries) === 'ENOENT') {
|
|
122
|
-
return true;
|
|
123
|
-
}
|
|
124
|
-
if ((0, error_js_1.errorCode)(entries) !== 'ENOTDIR') {
|
|
125
|
-
throw entries;
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
/* c8 ignore stop */
|
|
129
|
-
if (opt.filter && !opt.filter(path, ent)) {
|
|
130
|
-
return false;
|
|
131
|
-
}
|
|
132
|
-
// is a file
|
|
133
|
-
(0, ignore_enoent_js_1.ignoreENOENTSync)(() => rimrafWindowsFileSync(path, opt));
|
|
134
|
-
return true;
|
|
135
|
-
}
|
|
136
|
-
let removedAll = true;
|
|
137
|
-
for (const ent of entries) {
|
|
138
|
-
const s = state === START ? CHILD : state;
|
|
139
|
-
const p = (0, path_1.resolve)(path, ent.name);
|
|
140
|
-
removedAll = rimrafWindowsDirSync(p, opt, ent, s) && removedAll;
|
|
141
|
-
}
|
|
142
|
-
if (state === START) {
|
|
143
|
-
return rimrafWindowsDirSync(path, opt, ent, FINISH);
|
|
144
|
-
}
|
|
145
|
-
else if (state === FINISH) {
|
|
146
|
-
if (opt.preserveRoot === false && path === (0, path_1.parse)(path).root) {
|
|
147
|
-
return false;
|
|
148
|
-
}
|
|
149
|
-
if (!removedAll) {
|
|
150
|
-
return false;
|
|
151
|
-
}
|
|
152
|
-
if (opt.filter && !opt.filter(path, ent)) {
|
|
153
|
-
return false;
|
|
154
|
-
}
|
|
155
|
-
(0, ignore_enoent_js_1.ignoreENOENTSync)(() => rimrafWindowsDirMoveRemoveFallbackSync(path, opt));
|
|
156
|
-
}
|
|
157
|
-
return true;
|
|
158
|
-
};
|
|
159
|
-
//# sourceMappingURL=rimraf-windows.js.map
|