Detalhes do pacote

unbounded

bevry108.5kArtistic-2.06.3.1

Function.prototype.bind replacement that provides an unbounded hidden property on the returned bounded function, that contains the original unbounded function

bind, binded, browser, deno

readme (leia-me)

unbounded

Status of the GitHub Workflow: bevry NPM version NPM downloads
GitHub Sponsors donate button ThanksDev donate button Patreon donate button Liberapay donate button Buy Me A Coffee donate button Open Collective donate button crypto donate button PayPal donate button
Discord server badge Twitch community badge

Function.prototype.bind replacement that provides an unbounded hidden property on the returned bounded function, that contains the original unbounded function

Usage

Complete API Documentation.

This package functions like Function.prototype.bind, however it exposes a hidden unbounded property on the returned bounded function that contains the original unbounded function.

This is very useful as it means you can do:

  • (fn.unbounded || fn).length to always get the correct amount of arguments
  • (fn.unbounded || fn).toString() to always get the source code of any function instead of getting function () { [native code] } for bounded functions
  • fn.bind(firstContext).unbounded.bind(secondContext) to have fn actually bind to the second context, as fn.bind(firstContext).bind(secondContext) only binds to the first context

To have all bounded functions have the unbounded property, use patch:

import { patch } from 'unbounded'
patch()

const context = { hello: 'world' }
function myFunction() {
    return this.hello
}

import { equal } from 'assert'
const boundedFunction = myFunction.bind(context)
equal(boundedFunction(), context.hello, 'context was correct')
equal(boundedFunction.unbounded, myFunction, 'unbounded was correct')

To have only specific functions have the unbounded property, use binder:

import { equal } from 'assert'
import { binder } from 'unbounded'

const context = { hello: 'world' }
function myFunction() {
    return this.hello
}

import { equal } from 'assert'
const boundedFunction = binder.call(myFunction, context)
equal(boundedFunction(), context.hello, 'context was correct')
equal(boundedFunction.unbounded, myFunction, 'unbounded was correct')

Install

npm

  • Install: npm install --save unbounded
  • Import: import * as pkg from ('unbounded')
  • Require: const pkg = require('unbounded')

Deno

import * as pkg from 'https://unpkg.com/unbounded@^6.3.1/edition-deno/index.ts'

Skypack

<script type="module">
    import * as pkg from '//cdn.skypack.dev/unbounded@^6.3.1'
</script>

unpkg

<script type="module">
    import * as pkg from '//unpkg.com/unbounded@^6.3.1'
</script>

jspm

<script type="module">
    import * as pkg from '//dev.jspm.io/unbounded@6.3.1'
</script>

Editions

This package is published with the following editions:

  • unbounded aliases unbounded/index.cjs which uses the Editions Autoloader to automatically select the correct edition for the consumer's environment
  • unbounded/source/index.ts is TypeScript source code with Import for modules
  • unbounded/edition-browsers/index.js is TypeScript compiled against ES2022 for web browsers with Import for modules
  • unbounded/edition-es2022/index.js is TypeScript compiled against ES2022 for Node.js 6 || 8 || 10 || 12 || 14 || 16 || 18 || 20 || 21 with Require for modules
  • unbounded/edition-es5/index.js is TypeScript compiled against ES5 for Node.js 4 || 6 || 8 || 10 || 12 || 14 || 16 || 18 || 20 || 21 with Require for modules
  • unbounded/edition-es2022-esm/index.js is TypeScript compiled against ES2022 for Node.js 12 || 14 || 16 || 18 || 20 || 21 with Import for modules
  • unbounded/edition-types/index.d.ts is TypeScript compiled Types with Import for modules
  • unbounded/edition-deno/index.ts is TypeScript source code made to be compatible with Deno

History

Discover the release history by heading on over to the HISTORY.md file.

Backers

Code

Discover how to contribute via the CONTRIBUTING.md file.

Authors

Maintainers

Contributors

Finances

GitHub Sponsors donate button ThanksDev donate button Patreon donate button Liberapay donate button Buy Me A Coffee donate button Open Collective donate button crypto donate button PayPal donate button

Sponsors

  • Andrew Nesbitt — Software engineer and researcher
  • Balsa — We're Balsa, and we're building tools for builders.
  • Codecov — Empower developers with tools to improve code quality and testing.
  • Poonacha Medappa
  • Rob Morris
  • Sentry — Real-time crash reporting for your web apps, mobile apps, and games.
  • Syntax — Syntax Podcast

Donors

License

Unless stated otherwise all works are:

and licensed under:

changelog (log de mudanças)

History

v6.3.1 2023 December 29

v6.3.0 2023 December 29

v6.2.0 2023 December 27

v6.1.0 2023 December 6

v6.0.0 2023 November 26

  • Rewrote in TypeScript
  • define and patch now return void
  • define is no longer exported
  • Updated dependencies, base files, and editions using boundation

v5.4.0 2023 November 25

v5.3.0 2023 November 21

v5.2.0 2023 November 15

v5.1.0 2023 November 13

v5.0.0 2023 November 13

  • Updated dependencies, base files, and editions using boundation
  • Minimum required Node.js version changed from node: >=8 to node: >=4 adapting to ecosystem changes

v4.0.0 2023 November 13

  • Updated dependencies, base files, and editions using boundation
  • Minimum required Node.js version changed from node: >=10 to node: >=8 adapting to ecosystem changes

v3.16.0 2023 November 2

v3.15.0 2021 July 31

v3.14.0 2021 July 28

v3.13.0 2020 October 29

v3.12.0 2020 September 5

v3.11.0 2020 August 18

v3.10.0 2020 August 4

v3.9.0 2020 July 23

v3.8.0 2020 June 25

v3.7.0 2020 June 21

v3.6.0 2020 June 20

v3.5.0 2020 June 11

v3.4.0 2020 June 10

v3.3.0 2020 May 22

v3.2.0 2020 May 21

v3.1.0 2020 May 21

v3.0.0 2020 May 11

  • Updated dependencies, base files, and editions using boundation
  • Minimum required node version changed from node: >=8 to node: >=10 to keep up with mandatory ecosystem changes

v2.3.0 2019 December 10

v2.2.0 2019 December 1

v2.1.0 2019 December 1

v2.0.0 2019 November 18

  • Updated dependencies, base files, and editions using boundation
  • Minimum required node version changed from node: >=0.8 to node: >=8 to keep up with mandatory ecosystem changes

v1.3.0 2019 November 13

v1.2.0 2019 January 1

v1.1.0 2018 July 13

  • Exports define for manually specifying the unbounded property

v1.0.0 2018 July 13

  • Initial working version