especially
v2.0.1
Published
Abstract operations and other functions drawn from the ECMAScript specification
Downloads
637
Readme
ECMAScript Spec Operations, in ECMAScript
Have you ever wanted to write a to-the-letter implementation of some ECMAScript spec function? Maybe you want to run tests against it; maybe you're just crazy and like self-hosting JavaScript in JavaScript. In either case, this is the package for you!
Especially has a small-but-growing collection of meta-textual and abstract operations drawn directly from the pages of the ECMAScript 2015 draft specification. From common things like Get to dealing with internal slots, Especially has you covered.
APIs
Especially has no main module (gasp). Instead, you'll require one of the top-level modules that contain the stuff you want.
require("especially/abstract-operations")
- ArrayCreate
- Call
- CreateDataProperty
- DateFromTime
- Day
- DayFromYear
- DaysInYear
- DayWithinYear
- EnqueueJob
- Get
- GetV
- GetIterator: uses the
@@iterator
symbol. - GetMethod
- GetPrototypeFromConstructor
- HasProperty
- InLeapYear
- Invoke
- IsCallable
- IsConstructor: not spec compliant, but the best we can do
- IsPropertyKey
- IteratorComplete
- IteratorNext
- IteratorStep
- IteratorValue
- MakeDate
- MakeDay
- MakeTime
- MonthFromTime
- ObjectCreate
- OrdinaryCreateFromConstructor
- SameValue
- SameValueZero
- SpeciesConstructor
- TimeClip
- TimeFromYear
- TimeWithinDay
- ToBoolean
- ToInteger
- ToLength
- ToNumber
- ToObject
- ToString
- Type: returns the types as strings, e.g.
"Object"
. - YearFromTime
require("especially/math")
A variety of math operations from the Algorithm Conventions section of the spec:
- abs(x)
- sign(x)
- min(x1, x2, …, xn)
- floor(x)
require("especially/meta")
assert
: ensures you pass it a boolean, then throws if it's not truedefine_built_in_data_property
: a shortcut for defining a built-in data property with the usual property descriptor.- Internal slot management:
make_slots(object, arrayOfSlotNames)
: call this to initialize an object's internal slots. Often referenced in the spec as "instances of (something) are initially created with the internal slots listed in (some table)."get_slot(object, name)
: get the value of an internal slot. Often referenced in the spec as "the value of (object)'s [[SlotName]] internal slot."set_slot(object, name)
: set the value of an internal slot. Often referenced in the spec as "Set (object)'s [[SlotName]] internal slot to (a value)."has_slot(object)
: check whether an object has an internal slot with the given name. Often referenced in the spec as "If (object) does not have a [[SlotName]] internal slot."
require("especially/well-known-symbols")
One well-known symbol is included:
"@@iterator"
will give you a symbol that is used by GetIterator. (It is the same as V8's defaultSymbol.iterator
.)"@@species"
will give the symbol that is used by SpeciesConstructor. (It is a freshly-minted symbol, since V8 doesn't haveSymbol.species
yet.)
require("especially/intrinsics")
Some of the well-known intrinsic objects are included by name, e.g. "%ObjectPrototype%"
. These are used by GetPrototypeFromConstructor and related operations.
Usage Notes
Especially is meant to run in io.js (not Node.js™). It uses certain ES2015 features only implemented in modern V8.
Install it from npm into your project with npm install especially
.
You can see examples of it in use in the reference implementation of the ES2015 promises specification.