You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
88 lines
1.2 KiB
Markdown
88 lines
1.2 KiB
Markdown
5 years ago
|
# babel-plugin-transform-regenerator
|
||
|
|
||
|
> Transform async/generator functions with [regenerator](https://github.com/facebook/regenerator)
|
||
|
|
||
|
## Example
|
||
|
|
||
|
**In**
|
||
|
|
||
|
```javascript
|
||
|
function* a() {
|
||
|
yield 1;
|
||
|
}
|
||
|
```
|
||
|
|
||
|
**Out**
|
||
|
|
||
|
```javascript
|
||
|
var _marked = [a].map(regeneratorRuntime.mark);
|
||
|
|
||
|
function a() {
|
||
|
return regeneratorRuntime.wrap(function a$(_context) {
|
||
|
while (1) {
|
||
|
switch (_context.prev = _context.next) {
|
||
|
case 0:
|
||
|
_context.next = 2;
|
||
|
return 1;
|
||
|
|
||
|
case 2:
|
||
|
case "end":
|
||
|
return _context.stop();
|
||
|
}
|
||
|
}
|
||
|
}, _marked[0], this);
|
||
|
}
|
||
|
```
|
||
|
|
||
|
## Installation
|
||
|
|
||
|
```sh
|
||
|
npm install --save-dev babel-plugin-transform-regenerator
|
||
|
```
|
||
|
|
||
|
## Usage
|
||
|
|
||
|
### Via `.babelrc` (Recommended)
|
||
|
|
||
|
Without options:
|
||
|
|
||
|
```json
|
||
|
{
|
||
|
"plugins": ["transform-regenerator"]
|
||
|
}
|
||
|
```
|
||
|
|
||
|
With options:
|
||
|
|
||
|
|name|default value|
|
||
|
|---|---|
|
||
|
|asyncGenerators|true|
|
||
|
|generators|true|
|
||
|
|async|true|
|
||
|
|
||
|
```json
|
||
|
{
|
||
|
"plugins": [
|
||
|
["transform-regenerator", {
|
||
|
"asyncGenerators": false,
|
||
|
"generators": false,
|
||
|
"async": false
|
||
|
}]
|
||
|
]
|
||
|
}
|
||
|
```
|
||
|
|
||
|
### Via CLI
|
||
|
|
||
|
```sh
|
||
|
babel --plugins transform-regenerator script.js
|
||
|
```
|
||
|
|
||
|
### Via Node API
|
||
|
|
||
|
```javascript
|
||
|
require("babel-core").transform("code", {
|
||
|
plugins: ["transform-regenerator"]
|
||
|
});
|
||
|
```
|