0.8.18 • Published 4 years ago

babel-plugin-transform-async-to-promises v0.8.18

Weekly downloads
164,248
License
MIT
Repository
github
Last release
4 years ago

babel-plugin-transform-async-to-promises

Babel plugin to transform async functions containing await expressions to the equivalent chain of Promise calls with use of minimal helper functions.

Input:

async function fetchAsObjectURL(url) {
    const response = await fetch(url);
    const blob = await response.blob();
    return URL.createObjectURL(blob);
}

Output:

const fetchAsObjectURL = _async(function(url) {
	return _await(fetch(url), function(response) {
		return _await(response.blob(), URL.createObjectURL);
	});
});

Output with hoist enabled:

function _response$blob(response) {
	return _await(response.blob(), URL.createObjectURL);
}
const fetchAsObjectURL = _async(function(url) {
	return _await(fetch(url), _response$blob);
});

Output with inlineHelpers enabled:

const fetchAsObjectURL = function(url) {
	try {
		return Promise.resolve(fetch(url)).then(function(response) {
			return Promise.resolve(response.blob()).then(URL.createObjectURL);
		});
	} catch(e) {
		return Promise.reject(e);
	}
}

Output with externalHelpers enabled:

In the normal case, helpers are added to the top of the file for the _async and _await functions (as well as others). This can cause bloat in a codebase due to duplication of helper code in every file. To avoid this, enable externalHelpers and those will be imported instead:

import { _async } from "babel-plugin-transform-async-to-promises/helpers";
import { _await } from "babel-plugin-transform-async-to-promises/helpers";

const fetchAsObjectURL = _async(function(url) {
	return _await(fetch(url), function(response) {
		return _await(response.blob(), URL.createObjectURL);
	});
});

export default fetchAsObjectURL;

JavaScript Language Features

Full Support

  • async/await
  • for/while/do loops (including loops that would exhaust stack if dispatched recursively)
  • switch statements (including fallthrough and default cases)
  • conditional expressions
  • logical expressions
  • try/catch
  • break/continue statements (on both loops and labeled statements)
  • throw expressions
  • Function hoisting
  • Variable hoisting
  • Arrow functions
  • Methods
  • arguments
  • this
  • Proper member dereference order of operations
  • Standards-compliant event loop scheduling

Partial Support

  • Function.length: async functions will often return a length of 0 (when the _async wrapper is used)
  • Top level await support is experimental with compatible module bundler. Set topLevelAwait option to return when using SystemJS.

No support

  • eval: impossible to support without deep hooks into the runtime
  • Async generator functions: not implemented or planned
  • Function.name: rewrite pass removes function name instrumentation
  • new AsyncFunction(...): impossible to support without shipping babel and the plugin in the output
@jvdx/babel@jvdx/babel-preset-jvdxtsdx-extraproject-name-herecloud-archive-s3@codewitchbella/microbundletakla-buildertakla-builder-presets@cyca/babel-presets@saaspe/componentsfe-cli-script@everything-registry/sub-chunk-1204p149-tabletemporaetwillow-build-toolswebchestep-interpreter@bung87/bilijm-rolluplib-creatorkrown_login_librarymbix@walrus/pansy@walrus/babel-preset-walrus@valy/tsd@wx-fc/babel-preset@ttungbmt/microbundle-crl@ttungbmt/bundlers.rollup@touchtech/microbundle@tomyail/microbundle@vinceau/tsdx@yolkai/nx-web@zalastax/nolb-babel-plugin-t@zh0st/evm-chainsa-b-doeraxonv2sdkbabel-preset-minimal@iosio/rollup-plugin-custom-x-babel@graines-digitales/nice-handsome-button@1stg/babel-preset@akinoxsolutions/microbundle@alexandernanberg/bricks@hasparus/microbundle@cpro-js/vite-ui5-integration-plugin@eik/microbundle@ambroseus/tsdxstyledbuttonxxsuntmolestiaesource-map-to-codetzcc-lg-v1ui5-tooling-transpiletranzpile@backslashbuild/microbundle@bscswap/binance-connector@chialab/babel-presetzeusxtsdx-with-svgzero-bundlerzlc@infinitebrahmanuniverse/nolb-babel-plugin-t@knapsack/babel-config@lotus-ui/angela@leiyulf/gantt-task-react@lianfangti/gantt-task-react@n3tr/tsdx@knapsack/babel-config-starter@kay.eg/pkg@klutch-card/klutch-cli@kne/microbundle@kommunicate/kommunicate-chatbot-plugin@react-vant/cli@qp-mongosh/async-rewriter2@quantfive/microbundle-crl@saasify/microbundle@probablyup/microbundle@projectbabelfish/defikingdoms-sdk@quercia/cli@paljs/create@pansy/climuleifymicrobundlemicrobundle-alosdmicrobundle-cra-oprmicrobundle-crlmicrobundle-crl-postcss8microbundle-crl-runtimemicrobundle-crl-with-assetsmicrobundle-enhancedmina-scriptsp147-tablep148-tablerollup-workerray-pack-toolkitrollup-configuredrollup-toolkitreact-lightbox-pack-18supportreact-gantt-chart7node-geohashnka-gantt-task-reactnecessitatibusdeleniti
0.8.18

4 years ago

0.8.17

4 years ago

0.8.16

4 years ago

0.8.15

6 years ago

0.8.14

6 years ago

0.8.13

6 years ago

0.8.12

6 years ago

0.8.11

6 years ago

0.8.10

6 years ago

0.8.9

7 years ago

0.8.8

7 years ago

0.8.7

7 years ago

0.8.6

7 years ago

0.8.5

7 years ago

0.8.4

7 years ago

0.8.3

7 years ago

0.8.2

7 years ago

0.8.1

7 years ago

0.8.0

7 years ago

0.7.2

7 years ago

0.7.1

7 years ago

0.7.0

7 years ago

0.6.1

8 years ago

0.6.0

8 years ago

0.5.7

8 years ago

0.5.6

8 years ago

0.5.5

8 years ago

0.5.4

8 years ago

0.5.3

8 years ago

0.5.2

8 years ago

0.5.1

8 years ago

0.5.0

8 years ago

0.4.0

8 years ago

0.3.0

8 years ago

0.2.0

8 years ago

0.1.0

8 years ago