cloudstructs 0.9.26 → 0.9.28
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/.jsii +54 -21
- package/API.md +42 -16
- package/assets/slack-textract/detect.lambda/index.js +866 -17
- package/lib/codecommit-mirror/index.js +2 -2
- package/lib/dmarc/index.js +1 -1
- package/lib/ecs-service-roller/index.js +2 -2
- package/lib/email-receiver/receiver.d.ts +11 -1
- package/lib/email-receiver/receiver.js +12 -8
- package/lib/mjml-template/index.js +1 -1
- package/lib/saml-identity-provider/index.js +2 -2
- package/lib/slack-app/manifest.js +1 -1
- package/lib/slack-app/slack-app.js +2 -2
- package/lib/slack-events/index.js +1 -1
- package/lib/slack-textract/index.js +1 -1
- package/lib/ssl-server-test/index.js +1 -1
- package/lib/state-machine-cr-provider/index.js +1 -1
- package/lib/static-website/index.js +1 -1
- package/lib/toolkit-cleaner/index.js +1 -1
- package/lib/url-shortener/index.js +1 -1
- package/node_modules/@babel/runtime/helpers/esm/objectWithoutProperties.js +2 -2
- package/node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js +1 -1
- package/node_modules/@babel/runtime/helpers/objectWithoutProperties.js +2 -2
- package/node_modules/@babel/runtime/helpers/objectWithoutPropertiesLoose.js +1 -1
- package/node_modules/@babel/runtime/package.json +1 -1
- package/node_modules/@slack/logger/node_modules/@types/node/README.md +1 -1
- package/node_modules/@slack/logger/node_modules/@types/node/assert.d.ts +55 -0
- package/node_modules/@slack/logger/node_modules/@types/node/buffer.buffer.d.ts +2 -1
- package/node_modules/@slack/logger/node_modules/@types/node/dgram.d.ts +10 -7
- package/node_modules/@slack/logger/node_modules/@types/node/fs/promises.d.ts +2 -2
- package/node_modules/@slack/logger/node_modules/@types/node/fs.d.ts +45 -98
- package/node_modules/@slack/logger/node_modules/@types/node/globals.d.ts +0 -57
- package/node_modules/@slack/logger/node_modules/@types/node/http.d.ts +1 -0
- package/node_modules/@slack/logger/node_modules/@types/node/module.d.ts +527 -234
- package/node_modules/@slack/logger/node_modules/@types/node/net.d.ts +30 -5
- package/node_modules/@slack/logger/node_modules/@types/node/package.json +2 -2
- package/node_modules/@slack/logger/node_modules/@types/node/perf_hooks.d.ts +5 -0
- package/node_modules/@slack/logger/node_modules/@types/node/process.d.ts +54 -4
- package/node_modules/@slack/logger/node_modules/@types/node/sea.d.ts +1 -1
- package/node_modules/@slack/logger/node_modules/@types/node/sqlite.d.ts +207 -2
- package/node_modules/@slack/logger/node_modules/@types/node/stream.d.ts +6 -1
- package/node_modules/@slack/logger/node_modules/@types/node/test.d.ts +40 -138
- package/node_modules/@slack/logger/node_modules/@types/node/util.d.ts +85 -17
- package/node_modules/@slack/logger/node_modules/@types/node/vm.d.ts +1 -1
- package/node_modules/@slack/web-api/node_modules/@types/node/README.md +1 -1
- package/node_modules/@slack/web-api/node_modules/@types/node/assert.d.ts +55 -0
- package/node_modules/@slack/web-api/node_modules/@types/node/buffer.buffer.d.ts +2 -1
- package/node_modules/@slack/web-api/node_modules/@types/node/dgram.d.ts +10 -7
- package/node_modules/@slack/web-api/node_modules/@types/node/fs/promises.d.ts +2 -2
- package/node_modules/@slack/web-api/node_modules/@types/node/fs.d.ts +45 -98
- package/node_modules/@slack/web-api/node_modules/@types/node/globals.d.ts +0 -57
- package/node_modules/@slack/web-api/node_modules/@types/node/http.d.ts +1 -0
- package/node_modules/@slack/web-api/node_modules/@types/node/module.d.ts +527 -234
- package/node_modules/@slack/web-api/node_modules/@types/node/net.d.ts +30 -5
- package/node_modules/@slack/web-api/node_modules/@types/node/package.json +2 -2
- package/node_modules/@slack/web-api/node_modules/@types/node/perf_hooks.d.ts +5 -0
- package/node_modules/@slack/web-api/node_modules/@types/node/process.d.ts +54 -4
- package/node_modules/@slack/web-api/node_modules/@types/node/sea.d.ts +1 -1
- package/node_modules/@slack/web-api/node_modules/@types/node/sqlite.d.ts +207 -2
- package/node_modules/@slack/web-api/node_modules/@types/node/stream.d.ts +6 -1
- package/node_modules/@slack/web-api/node_modules/@types/node/test.d.ts +40 -138
- package/node_modules/@slack/web-api/node_modules/@types/node/util.d.ts +85 -17
- package/node_modules/@slack/web-api/node_modules/@types/node/vm.d.ts +1 -1
- package/node_modules/@types/cacheable-request/node_modules/@types/node/README.md +1 -1
- package/node_modules/@types/cacheable-request/node_modules/@types/node/assert.d.ts +55 -0
- package/node_modules/@types/cacheable-request/node_modules/@types/node/buffer.buffer.d.ts +2 -1
- package/node_modules/@types/cacheable-request/node_modules/@types/node/dgram.d.ts +10 -7
- package/node_modules/@types/cacheable-request/node_modules/@types/node/fs/promises.d.ts +2 -2
- package/node_modules/@types/cacheable-request/node_modules/@types/node/fs.d.ts +45 -98
- package/node_modules/@types/cacheable-request/node_modules/@types/node/globals.d.ts +0 -57
- package/node_modules/@types/cacheable-request/node_modules/@types/node/http.d.ts +1 -0
- package/node_modules/@types/cacheable-request/node_modules/@types/node/module.d.ts +527 -234
- package/node_modules/@types/cacheable-request/node_modules/@types/node/net.d.ts +30 -5
- package/node_modules/@types/cacheable-request/node_modules/@types/node/package.json +2 -2
- package/node_modules/@types/cacheable-request/node_modules/@types/node/perf_hooks.d.ts +5 -0
- package/node_modules/@types/cacheable-request/node_modules/@types/node/process.d.ts +54 -4
- package/node_modules/@types/cacheable-request/node_modules/@types/node/sea.d.ts +1 -1
- package/node_modules/@types/cacheable-request/node_modules/@types/node/sqlite.d.ts +207 -2
- package/node_modules/@types/cacheable-request/node_modules/@types/node/stream.d.ts +6 -1
- package/node_modules/@types/cacheable-request/node_modules/@types/node/test.d.ts +40 -138
- package/node_modules/@types/cacheable-request/node_modules/@types/node/util.d.ts +85 -17
- package/node_modules/@types/cacheable-request/node_modules/@types/node/vm.d.ts +1 -1
- package/node_modules/@types/keyv/node_modules/@types/node/README.md +1 -1
- package/node_modules/@types/keyv/node_modules/@types/node/assert.d.ts +55 -0
- package/node_modules/@types/keyv/node_modules/@types/node/buffer.buffer.d.ts +2 -1
- package/node_modules/@types/keyv/node_modules/@types/node/dgram.d.ts +10 -7
- package/node_modules/@types/keyv/node_modules/@types/node/fs/promises.d.ts +2 -2
- package/node_modules/@types/keyv/node_modules/@types/node/fs.d.ts +45 -98
- package/node_modules/@types/keyv/node_modules/@types/node/globals.d.ts +0 -57
- package/node_modules/@types/keyv/node_modules/@types/node/http.d.ts +1 -0
- package/node_modules/@types/keyv/node_modules/@types/node/module.d.ts +527 -234
- package/node_modules/@types/keyv/node_modules/@types/node/net.d.ts +30 -5
- package/node_modules/@types/keyv/node_modules/@types/node/package.json +2 -2
- package/node_modules/@types/keyv/node_modules/@types/node/perf_hooks.d.ts +5 -0
- package/node_modules/@types/keyv/node_modules/@types/node/process.d.ts +54 -4
- package/node_modules/@types/keyv/node_modules/@types/node/sea.d.ts +1 -1
- package/node_modules/@types/keyv/node_modules/@types/node/sqlite.d.ts +207 -2
- package/node_modules/@types/keyv/node_modules/@types/node/stream.d.ts +6 -1
- package/node_modules/@types/keyv/node_modules/@types/node/test.d.ts +40 -138
- package/node_modules/@types/keyv/node_modules/@types/node/util.d.ts +85 -17
- package/node_modules/@types/keyv/node_modules/@types/node/vm.d.ts +1 -1
- package/node_modules/@types/responselike/node_modules/@types/node/README.md +1 -1
- package/node_modules/@types/responselike/node_modules/@types/node/assert.d.ts +55 -0
- package/node_modules/@types/responselike/node_modules/@types/node/buffer.buffer.d.ts +2 -1
- package/node_modules/@types/responselike/node_modules/@types/node/dgram.d.ts +10 -7
- package/node_modules/@types/responselike/node_modules/@types/node/fs/promises.d.ts +2 -2
- package/node_modules/@types/responselike/node_modules/@types/node/fs.d.ts +45 -98
- package/node_modules/@types/responselike/node_modules/@types/node/globals.d.ts +0 -57
- package/node_modules/@types/responselike/node_modules/@types/node/http.d.ts +1 -0
- package/node_modules/@types/responselike/node_modules/@types/node/module.d.ts +527 -234
- package/node_modules/@types/responselike/node_modules/@types/node/net.d.ts +30 -5
- package/node_modules/@types/responselike/node_modules/@types/node/package.json +2 -2
- package/node_modules/@types/responselike/node_modules/@types/node/perf_hooks.d.ts +5 -0
- package/node_modules/@types/responselike/node_modules/@types/node/process.d.ts +54 -4
- package/node_modules/@types/responselike/node_modules/@types/node/sea.d.ts +1 -1
- package/node_modules/@types/responselike/node_modules/@types/node/sqlite.d.ts +207 -2
- package/node_modules/@types/responselike/node_modules/@types/node/stream.d.ts +6 -1
- package/node_modules/@types/responselike/node_modules/@types/node/test.d.ts +40 -138
- package/node_modules/@types/responselike/node_modules/@types/node/util.d.ts +85 -17
- package/node_modules/@types/responselike/node_modules/@types/node/vm.d.ts +1 -1
- package/node_modules/abbrev/package.json +11 -9
- package/node_modules/call-bind-apply-helpers/.eslintrc +17 -0
- package/node_modules/call-bind-apply-helpers/.github/FUNDING.yml +12 -0
- package/node_modules/call-bind-apply-helpers/.nycrc +9 -0
- package/node_modules/call-bind-apply-helpers/CHANGELOG.md +30 -0
- package/node_modules/call-bind-apply-helpers/LICENSE +21 -0
- package/node_modules/call-bind-apply-helpers/README.md +62 -0
- package/node_modules/call-bind-apply-helpers/actualApply.d.ts +1 -0
- package/node_modules/call-bind-apply-helpers/actualApply.js +10 -0
- package/node_modules/call-bind-apply-helpers/applyBind.d.ts +19 -0
- package/node_modules/call-bind-apply-helpers/applyBind.js +10 -0
- package/node_modules/call-bind-apply-helpers/functionApply.d.ts +1 -0
- package/node_modules/call-bind-apply-helpers/functionApply.js +4 -0
- package/node_modules/call-bind-apply-helpers/functionCall.d.ts +1 -0
- package/node_modules/call-bind-apply-helpers/functionCall.js +4 -0
- package/node_modules/call-bind-apply-helpers/index.d.ts +64 -0
- package/node_modules/call-bind-apply-helpers/index.js +15 -0
- package/node_modules/call-bind-apply-helpers/package.json +85 -0
- package/node_modules/call-bind-apply-helpers/reflectApply.d.ts +3 -0
- package/node_modules/call-bind-apply-helpers/reflectApply.js +4 -0
- package/node_modules/call-bind-apply-helpers/test/index.js +63 -0
- package/node_modules/call-bind-apply-helpers/tsconfig.json +9 -0
- package/node_modules/dunder-proto/.eslintrc +5 -0
- package/node_modules/dunder-proto/.github/FUNDING.yml +12 -0
- package/node_modules/dunder-proto/.nycrc +13 -0
- package/node_modules/dunder-proto/CHANGELOG.md +24 -0
- package/node_modules/dunder-proto/LICENSE +21 -0
- package/node_modules/dunder-proto/README.md +54 -0
- package/node_modules/dunder-proto/get.d.ts +5 -0
- package/node_modules/dunder-proto/get.js +30 -0
- package/node_modules/dunder-proto/package.json +76 -0
- package/node_modules/dunder-proto/set.d.ts +5 -0
- package/node_modules/dunder-proto/set.js +35 -0
- package/node_modules/dunder-proto/test/get.js +34 -0
- package/node_modules/dunder-proto/test/index.js +4 -0
- package/node_modules/dunder-proto/test/set.js +50 -0
- package/node_modules/dunder-proto/tsconfig.json +9 -0
- package/node_modules/es-define-property/.eslintrc +13 -0
- package/node_modules/es-define-property/.github/FUNDING.yml +12 -0
- package/node_modules/es-define-property/.nycrc +9 -0
- package/node_modules/es-define-property/CHANGELOG.md +29 -0
- package/node_modules/es-define-property/LICENSE +21 -0
- package/node_modules/es-define-property/README.md +49 -0
- package/node_modules/es-define-property/index.d.ts +3 -0
- package/node_modules/es-define-property/index.js +14 -0
- package/node_modules/es-define-property/package.json +81 -0
- package/node_modules/es-define-property/test/index.js +56 -0
- package/node_modules/es-define-property/tsconfig.json +10 -0
- package/node_modules/es-errors/.eslintrc +5 -0
- package/node_modules/es-errors/.github/FUNDING.yml +12 -0
- package/node_modules/es-errors/CHANGELOG.md +40 -0
- package/node_modules/es-errors/LICENSE +21 -0
- package/node_modules/es-errors/README.md +55 -0
- package/node_modules/es-errors/eval.d.ts +3 -0
- package/node_modules/es-errors/eval.js +4 -0
- package/node_modules/es-errors/index.d.ts +3 -0
- package/node_modules/es-errors/index.js +4 -0
- package/node_modules/es-errors/package.json +80 -0
- package/node_modules/es-errors/range.d.ts +3 -0
- package/node_modules/es-errors/range.js +4 -0
- package/node_modules/es-errors/ref.d.ts +3 -0
- package/node_modules/es-errors/ref.js +4 -0
- package/node_modules/es-errors/syntax.d.ts +3 -0
- package/node_modules/es-errors/syntax.js +4 -0
- package/node_modules/es-errors/test/index.js +19 -0
- package/node_modules/es-errors/tsconfig.json +49 -0
- package/node_modules/es-errors/type.d.ts +3 -0
- package/node_modules/es-errors/type.js +4 -0
- package/node_modules/es-errors/uri.d.ts +3 -0
- package/node_modules/es-errors/uri.js +4 -0
- package/node_modules/es-object-atoms/.eslintrc +16 -0
- package/node_modules/es-object-atoms/.github/FUNDING.yml +12 -0
- package/node_modules/es-object-atoms/CHANGELOG.md +37 -0
- package/node_modules/es-object-atoms/LICENSE +21 -0
- package/node_modules/es-object-atoms/README.md +63 -0
- package/node_modules/es-object-atoms/RequireObjectCoercible.d.ts +3 -0
- package/node_modules/es-object-atoms/RequireObjectCoercible.js +11 -0
- package/node_modules/es-object-atoms/ToObject.d.ts +7 -0
- package/node_modules/es-object-atoms/ToObject.js +10 -0
- package/node_modules/es-object-atoms/index.d.ts +3 -0
- package/node_modules/es-object-atoms/index.js +4 -0
- package/node_modules/es-object-atoms/isObject.d.ts +3 -0
- package/node_modules/es-object-atoms/isObject.js +6 -0
- package/node_modules/es-object-atoms/package.json +80 -0
- package/node_modules/es-object-atoms/test/index.js +38 -0
- package/node_modules/es-object-atoms/tsconfig.json +6 -0
- package/node_modules/es-set-tostringtag/.eslintrc +13 -0
- package/node_modules/es-set-tostringtag/.nycrc +9 -0
- package/node_modules/es-set-tostringtag/CHANGELOG.md +67 -0
- package/node_modules/es-set-tostringtag/LICENSE +21 -0
- package/node_modules/es-set-tostringtag/README.md +53 -0
- package/node_modules/es-set-tostringtag/index.d.ts +10 -0
- package/node_modules/es-set-tostringtag/index.js +35 -0
- package/node_modules/es-set-tostringtag/package.json +78 -0
- package/node_modules/es-set-tostringtag/test/index.js +85 -0
- package/node_modules/es-set-tostringtag/tsconfig.json +9 -0
- package/node_modules/form-data/lib/form_data.js +24 -22
- package/node_modules/form-data/package.json +17 -14
- package/node_modules/function-bind/.eslintrc +21 -0
- package/node_modules/function-bind/.github/FUNDING.yml +12 -0
- package/node_modules/function-bind/.github/SECURITY.md +3 -0
- package/node_modules/function-bind/.nycrc +13 -0
- package/node_modules/function-bind/CHANGELOG.md +136 -0
- package/node_modules/function-bind/LICENSE +20 -0
- package/node_modules/function-bind/README.md +46 -0
- package/node_modules/function-bind/implementation.js +84 -0
- package/node_modules/function-bind/index.js +5 -0
- package/node_modules/function-bind/package.json +87 -0
- package/node_modules/function-bind/test/.eslintrc +9 -0
- package/node_modules/function-bind/test/index.js +252 -0
- package/node_modules/get-intrinsic/.eslintrc +42 -0
- package/node_modules/get-intrinsic/.github/FUNDING.yml +12 -0
- package/node_modules/get-intrinsic/.nycrc +9 -0
- package/node_modules/get-intrinsic/CHANGELOG.md +186 -0
- package/node_modules/get-intrinsic/LICENSE +21 -0
- package/node_modules/get-intrinsic/README.md +71 -0
- package/node_modules/get-intrinsic/index.js +378 -0
- package/node_modules/get-intrinsic/package.json +97 -0
- package/node_modules/get-intrinsic/test/GetIntrinsic.js +274 -0
- package/node_modules/get-proto/.eslintrc +10 -0
- package/node_modules/get-proto/.github/FUNDING.yml +12 -0
- package/node_modules/get-proto/.nycrc +9 -0
- package/node_modules/get-proto/CHANGELOG.md +21 -0
- package/node_modules/get-proto/LICENSE +21 -0
- package/node_modules/get-proto/Object.getPrototypeOf.d.ts +5 -0
- package/node_modules/get-proto/Object.getPrototypeOf.js +6 -0
- package/node_modules/get-proto/README.md +50 -0
- package/node_modules/get-proto/Reflect.getPrototypeOf.d.ts +3 -0
- package/node_modules/get-proto/Reflect.getPrototypeOf.js +4 -0
- package/node_modules/get-proto/index.d.ts +5 -0
- package/node_modules/get-proto/index.js +27 -0
- package/node_modules/get-proto/package.json +81 -0
- package/node_modules/get-proto/test/index.js +68 -0
- package/node_modules/get-proto/tsconfig.json +9 -0
- package/node_modules/gopd/.eslintrc +16 -0
- package/node_modules/gopd/.github/FUNDING.yml +12 -0
- package/node_modules/gopd/CHANGELOG.md +45 -0
- package/node_modules/gopd/LICENSE +21 -0
- package/node_modules/gopd/README.md +40 -0
- package/node_modules/gopd/gOPD.d.ts +1 -0
- package/node_modules/gopd/gOPD.js +4 -0
- package/node_modules/gopd/index.d.ts +5 -0
- package/node_modules/gopd/index.js +15 -0
- package/node_modules/gopd/package.json +77 -0
- package/node_modules/gopd/test/index.js +36 -0
- package/node_modules/gopd/tsconfig.json +9 -0
- package/node_modules/has-symbols/.eslintrc +11 -0
- package/node_modules/has-symbols/.github/FUNDING.yml +12 -0
- package/node_modules/has-symbols/.nycrc +9 -0
- package/node_modules/has-symbols/CHANGELOG.md +91 -0
- package/node_modules/has-symbols/LICENSE +21 -0
- package/node_modules/has-symbols/README.md +46 -0
- package/node_modules/has-symbols/index.d.ts +3 -0
- package/node_modules/has-symbols/index.js +14 -0
- package/node_modules/has-symbols/package.json +111 -0
- package/node_modules/has-symbols/shams.d.ts +3 -0
- package/node_modules/has-symbols/shams.js +45 -0
- package/node_modules/has-symbols/test/index.js +22 -0
- package/node_modules/has-symbols/test/shams/core-js.js +29 -0
- package/node_modules/has-symbols/test/shams/get-own-property-symbols.js +29 -0
- package/node_modules/has-symbols/test/tests.js +58 -0
- package/node_modules/has-symbols/tsconfig.json +10 -0
- package/node_modules/has-tostringtag/.eslintrc +5 -0
- package/node_modules/has-tostringtag/.github/FUNDING.yml +12 -0
- package/node_modules/has-tostringtag/.nycrc +13 -0
- package/node_modules/has-tostringtag/CHANGELOG.md +42 -0
- package/node_modules/has-tostringtag/LICENSE +21 -0
- package/node_modules/has-tostringtag/README.md +46 -0
- package/node_modules/has-tostringtag/index.d.ts +3 -0
- package/node_modules/has-tostringtag/index.js +8 -0
- package/node_modules/has-tostringtag/package.json +108 -0
- package/node_modules/has-tostringtag/shams.d.ts +3 -0
- package/node_modules/has-tostringtag/shams.js +8 -0
- package/node_modules/has-tostringtag/test/index.js +21 -0
- package/node_modules/has-tostringtag/test/shams/core-js.js +31 -0
- package/node_modules/has-tostringtag/test/shams/get-own-property-symbols.js +30 -0
- package/node_modules/has-tostringtag/test/tests.js +15 -0
- package/node_modules/has-tostringtag/tsconfig.json +49 -0
- package/node_modules/hasown/.eslintrc +5 -0
- package/node_modules/hasown/.github/FUNDING.yml +12 -0
- package/node_modules/hasown/.nycrc +13 -0
- package/node_modules/hasown/CHANGELOG.md +40 -0
- package/node_modules/hasown/LICENSE +21 -0
- package/node_modules/hasown/README.md +40 -0
- package/node_modules/hasown/index.d.ts +3 -0
- package/node_modules/hasown/index.js +8 -0
- package/node_modules/hasown/package.json +92 -0
- package/node_modules/hasown/tsconfig.json +6 -0
- package/node_modules/js-beautify/README.md +19 -8
- package/node_modules/js-beautify/js/lib/beautifier.js +35 -18
- package/node_modules/js-beautify/js/lib/beautifier.min.js +1 -1
- package/node_modules/js-beautify/js/lib/beautify-html.js +35 -18
- package/node_modules/js-beautify/js/lib/beautify.js +4 -0
- package/node_modules/js-beautify/js/src/core/templatablepattern.js +4 -0
- package/node_modules/js-beautify/js/src/html/beautifier.js +5 -4
- package/node_modules/js-beautify/js/src/html/tokenizer.js +26 -14
- package/node_modules/js-beautify/package.json +5 -5
- package/node_modules/math-intrinsics/.eslintrc +16 -0
- package/node_modules/math-intrinsics/.github/FUNDING.yml +12 -0
- package/node_modules/math-intrinsics/CHANGELOG.md +24 -0
- package/node_modules/math-intrinsics/LICENSE +21 -0
- package/node_modules/math-intrinsics/README.md +50 -0
- package/node_modules/math-intrinsics/abs.d.ts +1 -0
- package/node_modules/math-intrinsics/abs.js +4 -0
- package/node_modules/math-intrinsics/constants/maxArrayLength.d.ts +3 -0
- package/node_modules/math-intrinsics/constants/maxArrayLength.js +4 -0
- package/node_modules/math-intrinsics/constants/maxSafeInteger.d.ts +3 -0
- package/node_modules/math-intrinsics/constants/maxSafeInteger.js +5 -0
- package/node_modules/math-intrinsics/constants/maxValue.d.ts +3 -0
- package/node_modules/math-intrinsics/constants/maxValue.js +5 -0
- package/node_modules/math-intrinsics/floor.d.ts +1 -0
- package/node_modules/math-intrinsics/floor.js +4 -0
- package/node_modules/math-intrinsics/isFinite.d.ts +3 -0
- package/node_modules/math-intrinsics/isFinite.js +12 -0
- package/node_modules/math-intrinsics/isInteger.d.ts +3 -0
- package/node_modules/math-intrinsics/isInteger.js +16 -0
- package/node_modules/math-intrinsics/isNaN.d.ts +1 -0
- package/node_modules/math-intrinsics/isNaN.js +6 -0
- package/node_modules/math-intrinsics/isNegativeZero.d.ts +3 -0
- package/node_modules/math-intrinsics/isNegativeZero.js +6 -0
- package/node_modules/math-intrinsics/max.d.ts +1 -0
- package/node_modules/math-intrinsics/max.js +4 -0
- package/node_modules/math-intrinsics/min.d.ts +1 -0
- package/node_modules/math-intrinsics/min.js +4 -0
- package/node_modules/math-intrinsics/mod.d.ts +3 -0
- package/node_modules/math-intrinsics/mod.js +9 -0
- package/node_modules/math-intrinsics/package.json +86 -0
- package/node_modules/math-intrinsics/pow.d.ts +1 -0
- package/node_modules/math-intrinsics/pow.js +4 -0
- package/node_modules/math-intrinsics/round.d.ts +1 -0
- package/node_modules/math-intrinsics/round.js +4 -0
- package/node_modules/math-intrinsics/sign.d.ts +3 -0
- package/node_modules/math-intrinsics/sign.js +11 -0
- package/node_modules/math-intrinsics/test/index.js +192 -0
- package/node_modules/math-intrinsics/tsconfig.json +3 -0
- package/node_modules/nopt/README.md +9 -8
- package/node_modules/nopt/lib/nopt-lib.js +40 -5
- package/node_modules/nopt/lib/nopt.js +4 -0
- package/node_modules/nopt/package.json +10 -9
- package/node_modules/semver/README.md +14 -4
- package/node_modules/semver/bin/semver.js +2 -1
- package/node_modules/semver/classes/semver.js +22 -6
- package/node_modules/semver/functions/diff.js +5 -12
- package/node_modules/semver/internal/re.js +2 -0
- package/node_modules/semver/package.json +8 -7
- package/package.json +17 -17
- /package/node_modules/{path-scurry/node_modules/lru-cache → lru-cache}/LICENSE +0 -0
- /package/node_modules/{path-scurry/node_modules/lru-cache → lru-cache}/README.md +0 -0
- /package/node_modules/{path-scurry/node_modules/lru-cache → lru-cache}/dist/commonjs/index.d.ts +0 -0
- /package/node_modules/{path-scurry/node_modules/lru-cache → lru-cache}/dist/commonjs/index.d.ts.map +0 -0
- /package/node_modules/{path-scurry/node_modules/lru-cache → lru-cache}/dist/commonjs/index.js +0 -0
- /package/node_modules/{path-scurry/node_modules/lru-cache → lru-cache}/dist/commonjs/index.js.map +0 -0
- /package/node_modules/{path-scurry/node_modules/lru-cache → lru-cache}/dist/commonjs/index.min.js +0 -0
- /package/node_modules/{path-scurry/node_modules/lru-cache → lru-cache}/dist/commonjs/index.min.js.map +0 -0
- /package/node_modules/{path-scurry/node_modules/lru-cache → lru-cache}/dist/commonjs/package.json +0 -0
- /package/node_modules/{path-scurry/node_modules/lru-cache → lru-cache}/dist/esm/index.d.ts +0 -0
- /package/node_modules/{path-scurry/node_modules/lru-cache → lru-cache}/dist/esm/index.d.ts.map +0 -0
- /package/node_modules/{path-scurry/node_modules/lru-cache → lru-cache}/dist/esm/index.js +0 -0
- /package/node_modules/{path-scurry/node_modules/lru-cache → lru-cache}/dist/esm/index.js.map +0 -0
- /package/node_modules/{path-scurry/node_modules/lru-cache → lru-cache}/dist/esm/index.min.js +0 -0
- /package/node_modules/{path-scurry/node_modules/lru-cache → lru-cache}/dist/esm/index.min.js.map +0 -0
- /package/node_modules/{path-scurry/node_modules/lru-cache → lru-cache}/dist/esm/package.json +0 -0
- /package/node_modules/{path-scurry/node_modules/lru-cache → lru-cache}/package.json +0 -0
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
type RemoveFromTuple<
|
|
2
|
+
Tuple extends readonly unknown[],
|
|
3
|
+
RemoveCount extends number,
|
|
4
|
+
Index extends 1[] = []
|
|
5
|
+
> = Index["length"] extends RemoveCount
|
|
6
|
+
? Tuple
|
|
7
|
+
: Tuple extends [infer First, ...infer Rest]
|
|
8
|
+
? RemoveFromTuple<Rest, RemoveCount, [...Index, 1]>
|
|
9
|
+
: Tuple;
|
|
10
|
+
|
|
11
|
+
type ConcatTuples<
|
|
12
|
+
Prefix extends readonly unknown[],
|
|
13
|
+
Suffix extends readonly unknown[]
|
|
14
|
+
> = [...Prefix, ...Suffix];
|
|
15
|
+
|
|
16
|
+
type ExtractFunctionParams<T> = T extends (this: infer TThis, ...args: infer P extends readonly unknown[]) => infer R
|
|
17
|
+
? { thisArg: TThis; params: P; returnType: R }
|
|
18
|
+
: never;
|
|
19
|
+
|
|
20
|
+
type BindFunction<
|
|
21
|
+
T extends (this: any, ...args: any[]) => any,
|
|
22
|
+
TThis,
|
|
23
|
+
TBoundArgs extends readonly unknown[],
|
|
24
|
+
ReceiverBound extends boolean
|
|
25
|
+
> = ExtractFunctionParams<T> extends {
|
|
26
|
+
thisArg: infer OrigThis;
|
|
27
|
+
params: infer P extends readonly unknown[];
|
|
28
|
+
returnType: infer R;
|
|
29
|
+
}
|
|
30
|
+
? ReceiverBound extends true
|
|
31
|
+
? (...args: RemoveFromTuple<P, Extract<TBoundArgs["length"], number>>) => R extends [OrigThis, ...infer Rest]
|
|
32
|
+
? [TThis, ...Rest] // Replace `this` with `thisArg`
|
|
33
|
+
: R
|
|
34
|
+
: <U, RemainingArgs extends RemoveFromTuple<P, Extract<TBoundArgs["length"], number>>>(
|
|
35
|
+
thisArg: U,
|
|
36
|
+
...args: RemainingArgs
|
|
37
|
+
) => R extends [OrigThis, ...infer Rest]
|
|
38
|
+
? [U, ...ConcatTuples<TBoundArgs, Rest>] // Preserve bound args in return type
|
|
39
|
+
: R
|
|
40
|
+
: never;
|
|
41
|
+
|
|
42
|
+
declare function callBind<
|
|
43
|
+
const T extends (this: any, ...args: any[]) => any,
|
|
44
|
+
Extracted extends ExtractFunctionParams<T>,
|
|
45
|
+
const TBoundArgs extends Partial<Extracted["params"]> & readonly unknown[],
|
|
46
|
+
const TThis extends Extracted["thisArg"]
|
|
47
|
+
>(
|
|
48
|
+
args: [fn: T, thisArg: TThis, ...boundArgs: TBoundArgs]
|
|
49
|
+
): BindFunction<T, TThis, TBoundArgs, true>;
|
|
50
|
+
|
|
51
|
+
declare function callBind<
|
|
52
|
+
const T extends (this: any, ...args: any[]) => any,
|
|
53
|
+
Extracted extends ExtractFunctionParams<T>,
|
|
54
|
+
const TBoundArgs extends Partial<Extracted["params"]> & readonly unknown[]
|
|
55
|
+
>(
|
|
56
|
+
args: [fn: T, ...boundArgs: TBoundArgs]
|
|
57
|
+
): BindFunction<T, Extracted["thisArg"], TBoundArgs, false>;
|
|
58
|
+
|
|
59
|
+
declare function callBind<const TArgs extends readonly unknown[]>(
|
|
60
|
+
args: [fn: Exclude<TArgs[0], Function>, ...rest: TArgs]
|
|
61
|
+
): never;
|
|
62
|
+
|
|
63
|
+
// export as namespace callBind;
|
|
64
|
+
export = callBind;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var bind = require('function-bind');
|
|
4
|
+
var $TypeError = require('es-errors/type');
|
|
5
|
+
|
|
6
|
+
var $call = require('./functionCall');
|
|
7
|
+
var $actualApply = require('./actualApply');
|
|
8
|
+
|
|
9
|
+
/** @type {(args: [Function, thisArg?: unknown, ...args: unknown[]]) => Function} TODO FIXME, find a way to use import('.') */
|
|
10
|
+
module.exports = function callBindBasic(args) {
|
|
11
|
+
if (args.length < 1 || typeof args[0] !== 'function') {
|
|
12
|
+
throw new $TypeError('a function is required');
|
|
13
|
+
}
|
|
14
|
+
return $actualApply(bind, $call, args);
|
|
15
|
+
};
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "call-bind-apply-helpers",
|
|
3
|
+
"version": "1.0.2",
|
|
4
|
+
"description": "Helper functions around Function call/apply/bind, for use in `call-bind`",
|
|
5
|
+
"main": "index.js",
|
|
6
|
+
"exports": {
|
|
7
|
+
".": "./index.js",
|
|
8
|
+
"./actualApply": "./actualApply.js",
|
|
9
|
+
"./applyBind": "./applyBind.js",
|
|
10
|
+
"./functionApply": "./functionApply.js",
|
|
11
|
+
"./functionCall": "./functionCall.js",
|
|
12
|
+
"./reflectApply": "./reflectApply.js",
|
|
13
|
+
"./package.json": "./package.json"
|
|
14
|
+
},
|
|
15
|
+
"scripts": {
|
|
16
|
+
"prepack": "npmignore --auto --commentLines=auto",
|
|
17
|
+
"prepublish": "not-in-publish || npm run prepublishOnly",
|
|
18
|
+
"prepublishOnly": "safe-publish-latest",
|
|
19
|
+
"prelint": "evalmd README.md",
|
|
20
|
+
"lint": "eslint --ext=.js,.mjs .",
|
|
21
|
+
"postlint": "tsc -p . && attw -P",
|
|
22
|
+
"pretest": "npm run lint",
|
|
23
|
+
"tests-only": "nyc tape 'test/**/*.js'",
|
|
24
|
+
"test": "npm run tests-only",
|
|
25
|
+
"posttest": "npx npm@'>=10.2' audit --production",
|
|
26
|
+
"version": "auto-changelog && git add CHANGELOG.md",
|
|
27
|
+
"postversion": "auto-changelog && git add CHANGELOG.md && git commit --no-edit --amend && git tag -f \"v$(node -e \"console.log(require('./package.json').version)\")\""
|
|
28
|
+
},
|
|
29
|
+
"repository": {
|
|
30
|
+
"type": "git",
|
|
31
|
+
"url": "git+https://github.com/ljharb/call-bind-apply-helpers.git"
|
|
32
|
+
},
|
|
33
|
+
"author": "Jordan Harband <ljharb@gmail.com>",
|
|
34
|
+
"license": "MIT",
|
|
35
|
+
"bugs": {
|
|
36
|
+
"url": "https://github.com/ljharb/call-bind-apply-helpers/issues"
|
|
37
|
+
},
|
|
38
|
+
"homepage": "https://github.com/ljharb/call-bind-apply-helpers#readme",
|
|
39
|
+
"dependencies": {
|
|
40
|
+
"es-errors": "^1.3.0",
|
|
41
|
+
"function-bind": "^1.1.2"
|
|
42
|
+
},
|
|
43
|
+
"devDependencies": {
|
|
44
|
+
"@arethetypeswrong/cli": "^0.17.3",
|
|
45
|
+
"@ljharb/eslint-config": "^21.1.1",
|
|
46
|
+
"@ljharb/tsconfig": "^0.2.3",
|
|
47
|
+
"@types/for-each": "^0.3.3",
|
|
48
|
+
"@types/function-bind": "^1.1.10",
|
|
49
|
+
"@types/object-inspect": "^1.13.0",
|
|
50
|
+
"@types/tape": "^5.8.1",
|
|
51
|
+
"auto-changelog": "^2.5.0",
|
|
52
|
+
"encoding": "^0.1.13",
|
|
53
|
+
"es-value-fixtures": "^1.7.1",
|
|
54
|
+
"eslint": "=8.8.0",
|
|
55
|
+
"evalmd": "^0.0.19",
|
|
56
|
+
"for-each": "^0.3.5",
|
|
57
|
+
"has-strict-mode": "^1.1.0",
|
|
58
|
+
"in-publish": "^2.0.1",
|
|
59
|
+
"npmignore": "^0.3.1",
|
|
60
|
+
"nyc": "^10.3.2",
|
|
61
|
+
"object-inspect": "^1.13.4",
|
|
62
|
+
"safe-publish-latest": "^2.0.0",
|
|
63
|
+
"tape": "^5.9.0",
|
|
64
|
+
"typescript": "next"
|
|
65
|
+
},
|
|
66
|
+
"testling": {
|
|
67
|
+
"files": "test/index.js"
|
|
68
|
+
},
|
|
69
|
+
"auto-changelog": {
|
|
70
|
+
"output": "CHANGELOG.md",
|
|
71
|
+
"template": "keepachangelog",
|
|
72
|
+
"unreleased": false,
|
|
73
|
+
"commitLimit": false,
|
|
74
|
+
"backfillLimit": false,
|
|
75
|
+
"hideCredit": true
|
|
76
|
+
},
|
|
77
|
+
"publishConfig": {
|
|
78
|
+
"ignore": [
|
|
79
|
+
".github/workflows"
|
|
80
|
+
]
|
|
81
|
+
},
|
|
82
|
+
"engines": {
|
|
83
|
+
"node": ">= 0.4"
|
|
84
|
+
}
|
|
85
|
+
}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var callBind = require('../');
|
|
4
|
+
var hasStrictMode = require('has-strict-mode')();
|
|
5
|
+
var forEach = require('for-each');
|
|
6
|
+
var inspect = require('object-inspect');
|
|
7
|
+
var v = require('es-value-fixtures');
|
|
8
|
+
|
|
9
|
+
var test = require('tape');
|
|
10
|
+
|
|
11
|
+
test('callBindBasic', function (t) {
|
|
12
|
+
forEach(v.nonFunctions, function (nonFunction) {
|
|
13
|
+
t['throws'](
|
|
14
|
+
// @ts-expect-error
|
|
15
|
+
function () { callBind([nonFunction]); },
|
|
16
|
+
TypeError,
|
|
17
|
+
inspect(nonFunction) + ' is not a function'
|
|
18
|
+
);
|
|
19
|
+
});
|
|
20
|
+
|
|
21
|
+
var sentinel = { sentinel: true };
|
|
22
|
+
/** @type {<T, A extends number, B extends number>(this: T, a: A, b: B) => [T | undefined, A, B]} */
|
|
23
|
+
var func = function (a, b) {
|
|
24
|
+
// eslint-disable-next-line no-invalid-this
|
|
25
|
+
return [!hasStrictMode && this === global ? undefined : this, a, b];
|
|
26
|
+
};
|
|
27
|
+
t.equal(func.length, 2, 'original function length is 2');
|
|
28
|
+
|
|
29
|
+
/** type {(thisArg: unknown, a: number, b: number) => [unknown, number, number]} */
|
|
30
|
+
var bound = callBind([func]);
|
|
31
|
+
/** type {((a: number, b: number) => [typeof sentinel, typeof a, typeof b])} */
|
|
32
|
+
var boundR = callBind([func, sentinel]);
|
|
33
|
+
/** type {((b: number) => [typeof sentinel, number, typeof b])} */
|
|
34
|
+
var boundArg = callBind([func, sentinel, /** @type {const} */ (1)]);
|
|
35
|
+
|
|
36
|
+
// @ts-expect-error
|
|
37
|
+
t.deepEqual(bound(), [undefined, undefined, undefined], 'bound func with no args');
|
|
38
|
+
|
|
39
|
+
// @ts-expect-error
|
|
40
|
+
t.deepEqual(func(), [undefined, undefined, undefined], 'unbound func with too few args');
|
|
41
|
+
// @ts-expect-error
|
|
42
|
+
t.deepEqual(bound(1, 2), [hasStrictMode ? 1 : Object(1), 2, undefined], 'bound func too few args');
|
|
43
|
+
// @ts-expect-error
|
|
44
|
+
t.deepEqual(boundR(), [sentinel, undefined, undefined], 'bound func with receiver, with too few args');
|
|
45
|
+
// @ts-expect-error
|
|
46
|
+
t.deepEqual(boundArg(), [sentinel, 1, undefined], 'bound func with receiver and arg, with too few args');
|
|
47
|
+
|
|
48
|
+
t.deepEqual(func(1, 2), [undefined, 1, 2], 'unbound func with right args');
|
|
49
|
+
t.deepEqual(bound(1, 2, 3), [hasStrictMode ? 1 : Object(1), 2, 3], 'bound func with right args');
|
|
50
|
+
t.deepEqual(boundR(1, 2), [sentinel, 1, 2], 'bound func with receiver, with right args');
|
|
51
|
+
t.deepEqual(boundArg(2), [sentinel, 1, 2], 'bound func with receiver and arg, with right arg');
|
|
52
|
+
|
|
53
|
+
// @ts-expect-error
|
|
54
|
+
t.deepEqual(func(1, 2, 3), [undefined, 1, 2], 'unbound func with too many args');
|
|
55
|
+
// @ts-expect-error
|
|
56
|
+
t.deepEqual(bound(1, 2, 3, 4), [hasStrictMode ? 1 : Object(1), 2, 3], 'bound func with too many args');
|
|
57
|
+
// @ts-expect-error
|
|
58
|
+
t.deepEqual(boundR(1, 2, 3), [sentinel, 1, 2], 'bound func with receiver, with too many args');
|
|
59
|
+
// @ts-expect-error
|
|
60
|
+
t.deepEqual(boundArg(2, 3), [sentinel, 1, 2], 'bound func with receiver and arg, with too many args');
|
|
61
|
+
|
|
62
|
+
t.end();
|
|
63
|
+
});
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
# These are supported funding model platforms
|
|
2
|
+
|
|
3
|
+
github: [ljharb]
|
|
4
|
+
patreon: # Replace with a single Patreon username
|
|
5
|
+
open_collective: # Replace with a single Open Collective username
|
|
6
|
+
ko_fi: # Replace with a single Ko-fi username
|
|
7
|
+
tidelift: npm/dunder-proto
|
|
8
|
+
community_bridge: # Replace with a single Community Bridge project-name e.g., cloud-foundry
|
|
9
|
+
liberapay: # Replace with a single Liberapay username
|
|
10
|
+
issuehunt: # Replace with a single IssueHunt username
|
|
11
|
+
otechie: # Replace with a single Otechie username
|
|
12
|
+
custom: # Replace with up to 4 custom sponsorship URLs e.g., ['link1', 'link2']
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
# Changelog
|
|
2
|
+
|
|
3
|
+
All notable changes to this project will be documented in this file.
|
|
4
|
+
|
|
5
|
+
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/)
|
|
6
|
+
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
|
7
|
+
|
|
8
|
+
## [v1.0.1](https://github.com/es-shims/dunder-proto/compare/v1.0.0...v1.0.1) - 2024-12-16
|
|
9
|
+
|
|
10
|
+
### Commits
|
|
11
|
+
|
|
12
|
+
- [Fix] do not crash when `--disable-proto=throw` [`6c367d9`](https://github.com/es-shims/dunder-proto/commit/6c367d919bc1604778689a297bbdbfea65752847)
|
|
13
|
+
- [Tests] ensure noproto tests only use the current version of dunder-proto [`b02365b`](https://github.com/es-shims/dunder-proto/commit/b02365b9cf889c4a2cac7be0c3cfc90a789af36c)
|
|
14
|
+
- [Dev Deps] update `@arethetypeswrong/cli`, `@types/tape` [`e3c5c3b`](https://github.com/es-shims/dunder-proto/commit/e3c5c3bd81cf8cef7dff2eca19e558f0e307f666)
|
|
15
|
+
- [Deps] update `call-bind-apply-helpers` [`19f1da0`](https://github.com/es-shims/dunder-proto/commit/19f1da028b8dd0d05c85bfd8f7eed2819b686450)
|
|
16
|
+
|
|
17
|
+
## v1.0.0 - 2024-12-06
|
|
18
|
+
|
|
19
|
+
### Commits
|
|
20
|
+
|
|
21
|
+
- Initial implementation, tests, readme, types [`a5b74b0`](https://github.com/es-shims/dunder-proto/commit/a5b74b0082f5270cb0905cd9a2e533cee7498373)
|
|
22
|
+
- Initial commit [`73fb5a3`](https://github.com/es-shims/dunder-proto/commit/73fb5a353b51ac2ab00c9fdeb0114daffd4c07a8)
|
|
23
|
+
- npm init [`80152dc`](https://github.com/es-shims/dunder-proto/commit/80152dc98155da4eb046d9f67a87ed96e8280a1d)
|
|
24
|
+
- Only apps should have lockfiles [`03e6660`](https://github.com/es-shims/dunder-proto/commit/03e6660a1d70dc401f3e217a031475ec537243dd)
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2024 ECMAScript Shims
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
# dunder-proto <sup>[![Version Badge][npm-version-svg]][package-url]</sup>
|
|
2
|
+
|
|
3
|
+
[![github actions][actions-image]][actions-url]
|
|
4
|
+
[![coverage][codecov-image]][codecov-url]
|
|
5
|
+
[![License][license-image]][license-url]
|
|
6
|
+
[![Downloads][downloads-image]][downloads-url]
|
|
7
|
+
|
|
8
|
+
[![npm badge][npm-badge-png]][package-url]
|
|
9
|
+
|
|
10
|
+
If available, the `Object.prototype.__proto__` accessor and mutator, call-bound.
|
|
11
|
+
|
|
12
|
+
## Getting started
|
|
13
|
+
|
|
14
|
+
```sh
|
|
15
|
+
npm install --save dunder-proto
|
|
16
|
+
```
|
|
17
|
+
|
|
18
|
+
## Usage/Examples
|
|
19
|
+
|
|
20
|
+
```js
|
|
21
|
+
const assert = require('assert');
|
|
22
|
+
const getDunder = require('dunder-proto/get');
|
|
23
|
+
const setDunder = require('dunder-proto/set');
|
|
24
|
+
|
|
25
|
+
const obj = {};
|
|
26
|
+
|
|
27
|
+
assert.equal('toString' in obj, true);
|
|
28
|
+
assert.equal(getDunder(obj), Object.prototype);
|
|
29
|
+
|
|
30
|
+
setDunder(obj, null);
|
|
31
|
+
|
|
32
|
+
assert.equal('toString' in obj, false);
|
|
33
|
+
assert.equal(getDunder(obj), null);
|
|
34
|
+
```
|
|
35
|
+
|
|
36
|
+
## Tests
|
|
37
|
+
|
|
38
|
+
Clone the repo, `npm install`, and run `npm test`
|
|
39
|
+
|
|
40
|
+
[package-url]: https://npmjs.org/package/dunder-proto
|
|
41
|
+
[npm-version-svg]: https://versionbadg.es/es-shims/dunder-proto.svg
|
|
42
|
+
[deps-svg]: https://david-dm.org/es-shims/dunder-proto.svg
|
|
43
|
+
[deps-url]: https://david-dm.org/es-shims/dunder-proto
|
|
44
|
+
[dev-deps-svg]: https://david-dm.org/es-shims/dunder-proto/dev-status.svg
|
|
45
|
+
[dev-deps-url]: https://david-dm.org/es-shims/dunder-proto#info=devDependencies
|
|
46
|
+
[npm-badge-png]: https://nodei.co/npm/dunder-proto.png?downloads=true&stars=true
|
|
47
|
+
[license-image]: https://img.shields.io/npm/l/dunder-proto.svg
|
|
48
|
+
[license-url]: LICENSE
|
|
49
|
+
[downloads-image]: https://img.shields.io/npm/dm/dunder-proto.svg
|
|
50
|
+
[downloads-url]: https://npm-stat.com/charts.html?package=dunder-proto
|
|
51
|
+
[codecov-image]: https://codecov.io/gh/es-shims/dunder-proto/branch/main/graphs/badge.svg
|
|
52
|
+
[codecov-url]: https://app.codecov.io/gh/es-shims/dunder-proto/
|
|
53
|
+
[actions-image]: https://img.shields.io/endpoint?url=https://github-actions-badge-u3jn4tfpocch.runkit.sh/es-shims/dunder-proto
|
|
54
|
+
[actions-url]: https://github.com/es-shims/dunder-proto/actions
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var callBind = require('call-bind-apply-helpers');
|
|
4
|
+
var gOPD = require('gopd');
|
|
5
|
+
|
|
6
|
+
var hasProtoAccessor;
|
|
7
|
+
try {
|
|
8
|
+
// eslint-disable-next-line no-extra-parens, no-proto
|
|
9
|
+
hasProtoAccessor = /** @type {{ __proto__?: typeof Array.prototype }} */ ([]).__proto__ === Array.prototype;
|
|
10
|
+
} catch (e) {
|
|
11
|
+
if (!e || typeof e !== 'object' || !('code' in e) || e.code !== 'ERR_PROTO_ACCESS') {
|
|
12
|
+
throw e;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
// eslint-disable-next-line no-extra-parens
|
|
17
|
+
var desc = !!hasProtoAccessor && gOPD && gOPD(Object.prototype, /** @type {keyof typeof Object.prototype} */ ('__proto__'));
|
|
18
|
+
|
|
19
|
+
var $Object = Object;
|
|
20
|
+
var $getPrototypeOf = $Object.getPrototypeOf;
|
|
21
|
+
|
|
22
|
+
/** @type {import('./get')} */
|
|
23
|
+
module.exports = desc && typeof desc.get === 'function'
|
|
24
|
+
? callBind([desc.get])
|
|
25
|
+
: typeof $getPrototypeOf === 'function'
|
|
26
|
+
? /** @type {import('./get')} */ function getDunder(value) {
|
|
27
|
+
// eslint-disable-next-line eqeqeq
|
|
28
|
+
return $getPrototypeOf(value == null ? value : $Object(value));
|
|
29
|
+
}
|
|
30
|
+
: false;
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "dunder-proto",
|
|
3
|
+
"version": "1.0.1",
|
|
4
|
+
"description": "If available, the `Object.prototype.__proto__` accessor and mutator, call-bound",
|
|
5
|
+
"main": false,
|
|
6
|
+
"exports": {
|
|
7
|
+
"./get": "./get.js",
|
|
8
|
+
"./set": "./set.js",
|
|
9
|
+
"./package.json": "./package.json"
|
|
10
|
+
},
|
|
11
|
+
"sideEffects": false,
|
|
12
|
+
"scripts": {
|
|
13
|
+
"prepack": "npmignore --auto --commentLines=autogenerated",
|
|
14
|
+
"prepublish": "not-in-publish || npm run prepublishOnly",
|
|
15
|
+
"prepublishOnly": "safe-publish-latest",
|
|
16
|
+
"prelint": "evalmd README.md",
|
|
17
|
+
"lint": "eslint --ext=.js,.mjs .",
|
|
18
|
+
"postlint": "tsc -p . && attw -P",
|
|
19
|
+
"pretest": "npm run lint",
|
|
20
|
+
"tests-only": "nyc tape 'test/**/*.js'",
|
|
21
|
+
"test": "npm run tests-only",
|
|
22
|
+
"posttest": "npx npm@'>= 10.2' audit --production",
|
|
23
|
+
"version": "auto-changelog && git add CHANGELOG.md",
|
|
24
|
+
"postversion": "auto-changelog && git add CHANGELOG.md && git commit --no-edit --amend && git tag -f \"v$(node -e \"console.log(require('./package.json').version)\")\""
|
|
25
|
+
},
|
|
26
|
+
"repository": {
|
|
27
|
+
"type": "git",
|
|
28
|
+
"url": "git+https://github.com/es-shims/dunder-proto.git"
|
|
29
|
+
},
|
|
30
|
+
"author": "Jordan Harband <ljharb@gmail.com>",
|
|
31
|
+
"license": "MIT",
|
|
32
|
+
"bugs": {
|
|
33
|
+
"url": "https://github.com/es-shims/dunder-proto/issues"
|
|
34
|
+
},
|
|
35
|
+
"homepage": "https://github.com/es-shims/dunder-proto#readme",
|
|
36
|
+
"dependencies": {
|
|
37
|
+
"call-bind-apply-helpers": "^1.0.1",
|
|
38
|
+
"es-errors": "^1.3.0",
|
|
39
|
+
"gopd": "^1.2.0"
|
|
40
|
+
},
|
|
41
|
+
"devDependencies": {
|
|
42
|
+
"@arethetypeswrong/cli": "^0.17.1",
|
|
43
|
+
"@ljharb/eslint-config": "^21.1.1",
|
|
44
|
+
"@ljharb/tsconfig": "^0.2.2",
|
|
45
|
+
"@types/tape": "^5.7.0",
|
|
46
|
+
"auto-changelog": "^2.5.0",
|
|
47
|
+
"encoding": "^0.1.13",
|
|
48
|
+
"eslint": "=8.8.0",
|
|
49
|
+
"evalmd": "^0.0.19",
|
|
50
|
+
"in-publish": "^2.0.1",
|
|
51
|
+
"npmignore": "^0.3.1",
|
|
52
|
+
"nyc": "^10.3.2",
|
|
53
|
+
"safe-publish-latest": "^2.0.0",
|
|
54
|
+
"tape": "^5.9.0",
|
|
55
|
+
"typescript": "next"
|
|
56
|
+
},
|
|
57
|
+
"auto-changelog": {
|
|
58
|
+
"output": "CHANGELOG.md",
|
|
59
|
+
"template": "keepachangelog",
|
|
60
|
+
"unreleased": false,
|
|
61
|
+
"commitLimit": false,
|
|
62
|
+
"backfillLimit": false,
|
|
63
|
+
"hideCredit": true
|
|
64
|
+
},
|
|
65
|
+
"testling": {
|
|
66
|
+
"files": "test/index.js"
|
|
67
|
+
},
|
|
68
|
+
"publishConfig": {
|
|
69
|
+
"ignore": [
|
|
70
|
+
".github/workflows"
|
|
71
|
+
]
|
|
72
|
+
},
|
|
73
|
+
"engines": {
|
|
74
|
+
"node": ">= 0.4"
|
|
75
|
+
}
|
|
76
|
+
}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var callBind = require('call-bind-apply-helpers');
|
|
4
|
+
var gOPD = require('gopd');
|
|
5
|
+
var $TypeError = require('es-errors/type');
|
|
6
|
+
|
|
7
|
+
/** @type {{ __proto__?: object | null }} */
|
|
8
|
+
var obj = {};
|
|
9
|
+
try {
|
|
10
|
+
obj.__proto__ = null; // eslint-disable-line no-proto
|
|
11
|
+
} catch (e) {
|
|
12
|
+
if (!e || typeof e !== 'object' || !('code' in e) || e.code !== 'ERR_PROTO_ACCESS') {
|
|
13
|
+
throw e;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
var hasProtoMutator = !('toString' in obj);
|
|
18
|
+
|
|
19
|
+
// eslint-disable-next-line no-extra-parens
|
|
20
|
+
var desc = gOPD && gOPD(Object.prototype, /** @type {keyof typeof Object.prototype} */ ('__proto__'));
|
|
21
|
+
|
|
22
|
+
/** @type {import('./set')} */
|
|
23
|
+
module.exports = hasProtoMutator && (
|
|
24
|
+
// eslint-disable-next-line no-extra-parens
|
|
25
|
+
(!!desc && typeof desc.set === 'function' && /** @type {import('./set')} */ (callBind([desc.set])))
|
|
26
|
+
|| /** @type {import('./set')} */ function setDunder(object, proto) {
|
|
27
|
+
// this is node v0.10 or older, which doesn't have Object.setPrototypeOf and has undeniable __proto__
|
|
28
|
+
if (object == null) { // eslint-disable-line eqeqeq
|
|
29
|
+
throw new $TypeError('set Object.prototype.__proto__ called on null or undefined');
|
|
30
|
+
}
|
|
31
|
+
// eslint-disable-next-line no-proto, no-param-reassign, no-extra-parens
|
|
32
|
+
/** @type {{ __proto__?: object | null }} */ (object).__proto__ = proto;
|
|
33
|
+
return proto;
|
|
34
|
+
}
|
|
35
|
+
);
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var test = require('tape');
|
|
4
|
+
|
|
5
|
+
var getDunderProto = require('../get');
|
|
6
|
+
|
|
7
|
+
test('getDunderProto', { skip: !getDunderProto }, function (t) {
|
|
8
|
+
if (!getDunderProto) {
|
|
9
|
+
throw 'should never happen; this is just for type narrowing'; // eslint-disable-line no-throw-literal
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
// @ts-expect-error
|
|
13
|
+
t['throws'](function () { getDunderProto(); }, TypeError, 'throws if no argument');
|
|
14
|
+
// @ts-expect-error
|
|
15
|
+
t['throws'](function () { getDunderProto(undefined); }, TypeError, 'throws with undefined');
|
|
16
|
+
// @ts-expect-error
|
|
17
|
+
t['throws'](function () { getDunderProto(null); }, TypeError, 'throws with null');
|
|
18
|
+
|
|
19
|
+
t.equal(getDunderProto({}), Object.prototype);
|
|
20
|
+
t.equal(getDunderProto([]), Array.prototype);
|
|
21
|
+
t.equal(getDunderProto(function () {}), Function.prototype);
|
|
22
|
+
t.equal(getDunderProto(/./g), RegExp.prototype);
|
|
23
|
+
t.equal(getDunderProto(42), Number.prototype);
|
|
24
|
+
t.equal(getDunderProto(true), Boolean.prototype);
|
|
25
|
+
t.equal(getDunderProto('foo'), String.prototype);
|
|
26
|
+
|
|
27
|
+
t.end();
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
test('no dunder proto', { skip: !!getDunderProto }, function (t) {
|
|
31
|
+
t.notOk('__proto__' in Object.prototype, 'no __proto__ in Object.prototype');
|
|
32
|
+
|
|
33
|
+
t.end();
|
|
34
|
+
});
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var test = require('tape');
|
|
4
|
+
|
|
5
|
+
var setDunderProto = require('../set');
|
|
6
|
+
|
|
7
|
+
test('setDunderProto', { skip: !setDunderProto }, function (t) {
|
|
8
|
+
if (!setDunderProto) {
|
|
9
|
+
throw 'should never happen; this is just for type narrowing'; // eslint-disable-line no-throw-literal
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
// @ts-expect-error
|
|
13
|
+
t['throws'](function () { setDunderProto(); }, TypeError, 'throws if no arguments');
|
|
14
|
+
// @ts-expect-error
|
|
15
|
+
t['throws'](function () { setDunderProto(undefined); }, TypeError, 'throws with undefined and nothing');
|
|
16
|
+
// @ts-expect-error
|
|
17
|
+
t['throws'](function () { setDunderProto(undefined, undefined); }, TypeError, 'throws with undefined and undefined');
|
|
18
|
+
// @ts-expect-error
|
|
19
|
+
t['throws'](function () { setDunderProto(null); }, TypeError, 'throws with null and undefined');
|
|
20
|
+
// @ts-expect-error
|
|
21
|
+
t['throws'](function () { setDunderProto(null, undefined); }, TypeError, 'throws with null and undefined');
|
|
22
|
+
|
|
23
|
+
/** @type {{ inherited?: boolean }} */
|
|
24
|
+
var obj = {};
|
|
25
|
+
t.ok('toString' in obj, 'object initially has toString');
|
|
26
|
+
|
|
27
|
+
setDunderProto(obj, null);
|
|
28
|
+
t.notOk('toString' in obj, 'object no longer has toString');
|
|
29
|
+
|
|
30
|
+
t.notOk('inherited' in obj, 'object lacks inherited property');
|
|
31
|
+
setDunderProto(obj, { inherited: true });
|
|
32
|
+
t.equal(obj.inherited, true, 'object has inherited property');
|
|
33
|
+
|
|
34
|
+
t.end();
|
|
35
|
+
});
|
|
36
|
+
|
|
37
|
+
test('no dunder proto', { skip: !!setDunderProto }, function (t) {
|
|
38
|
+
if ('__proto__' in Object.prototype) {
|
|
39
|
+
t['throws'](
|
|
40
|
+
// @ts-expect-error
|
|
41
|
+
function () { ({}).__proto__ = null; }, // eslint-disable-line no-proto
|
|
42
|
+
Error,
|
|
43
|
+
'throws when setting Object.prototype.__proto__'
|
|
44
|
+
);
|
|
45
|
+
} else {
|
|
46
|
+
t.notOk('__proto__' in Object.prototype, 'no __proto__ in Object.prototype');
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
t.end();
|
|
50
|
+
});
|