JSPM

make-synchronous

0.1.1
  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 55552
  • Score
    100M100P100Q146949F
  • License MIT

Make an asynchronous function synchronous

Package Exports

  • make-synchronous

This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (make-synchronous) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.

Readme

make-synchronous Build Status

Make an asynchronous function synchronous

This is the wrong tool for most tasks! Prefer using async APIs whenever possible.

The benefit of this package over packages like deasync is that this one is not a native Node.js addon (which comes with a lot of problems). Instead, this package executes the given function synchronously in a subprocess.

Works in Node.js only, not the browser.

Install

$ npm install make-synchronous

Usage

const makeSynchronous = require('make-synchronous');

const fn = makeSynchronous(async number => {
    const delay = require('delay');

    await delay(100);

    return number * 2;
});

console.log(fn(2));
//=> 4

API

makeSynchronous(asyncFunction)

Returns a wrapped version of the given async function which executes synchronously. This means no other code will execute (not even async code) until the given async function is done.

The given function is executed in a subprocess, so you cannot use any variables/imports from outside the scope of the function. You can pass in arguments to the function. To import dependencies, use either require(…) or await import(…) in the function body.

It uses the V8 serialization API transfer arguments, return values, errors between the subprocess and the current process. It supports most values, but not functions and symbols.