1.0.0 • Published 3 years ago

async-inheritance v1.0.0

Weekly downloads
-
License
ISC
Repository
github
Last release
3 years ago

async-inheritance

This module provides a class and the symbols necessary to create classes whose constructors return promises, while staying as close to JavaScript's normal class inheritance functionality as possible.

Usage

The simplest async class looks like this:

const {AsyncClass, async_constructor, async_super} = require("async-inheritance")

class MyClass extends AsyncClass {
    async [async_constructor]() {
        await this[async_super]()
        // async code
    }
}

(async () => {
    const instance = await new MyClass()
    console.log(instance instanceof MyClass) // true
})()

Classes that extend AsyncClass can then be extended further:

const {AsyncClass, async_constructor, async_super} = require("async-inheritance")
const timers = require("timers/promises")

class MyClass1 extends AsyncClass {
    async [async_constructor](construction_delay) {
        await this[async_super]()
        await timers.setTimeout(construction_delay)
    }
}

class MyClass2 extends MyClass1 {
    async [async_constructor]() {
        await this[async_super](100)
        console.log("Finished constructor")
    }
}

(async () => {
    await new MyClass2()
})()

If a child class overrides [[asyncconstructor]] it _must call [[async_super]], but the constructor can be omitted entirely with no issue:

const {AsyncClass, async_constructor, async_super} = require("async-inheritance")
const timers = require("timers/promises")

class MyClass1 extends AsyncClass {
    async [async_constructor](construction_delay) {
        await this[async_super]()
        await timers.setTimeout(construction_delay)
    }
    do_something() {
        // do something
    }
}

class MyClass2 extends MyClass1 {
    do_something() {
        super.do_something()
        // do something more
    }
}

class MyClass3 extends MyClass2 {
    async [async_constructor]() {
        await this[async_super](100)
        console.log("Finished constructor")
    }
}

(async () => {
    await new MyClass3()
})()

Just like with normal constructors, the async constructor can return an object:

const {AsyncClass, async_constructor, async_super} = require("async-inheritance")

class MyClass extends AsyncClass {
    async [async_constructor]() {
        await this[async_super]()
        return {my_property: 1}
    }
}

(async () => {
    const instance = await new MyClass()
    console.log(instance.my_property === 1) // true
})()

Notes

  • Overriding the normal constructor will break the async constructor's functionality
  • Acessing this before calling await this[async_super]() may cause unexpected behavior (it does NOT throw an error the way that normal JavaScript class inheritance does)

Compatibility

This module requires the following features:

  • Symbol
  • Promise
  • classes
  • async/await
  • const
  • rest/spread operator
  • generator functions
  • Object.getPrototypeOf
  • Object.getOwnPropertyNames
  • Object.getOwnPropertySymbols