Support for NumericLiteralSeparator, Stage 1 feature (#5793)
* Support for NumericLiteralSeparator, Stage 1 feature
commit cd8f6e062876261a334d968f875e477a48927b6d
Author: Sven SAULEAU <xtuc@users.noreply.github.com>
Date: Wed May 31 16:14:15 2017 +0200
docs: update README [skip ci]
commit cf013e3382bf73cdf9224026c1ec0b1a368cfef2
Author: Rick Waldron <waldron.rick@gmail.com>
Date: Tue May 30 14:51:20 2017 -0400
Support for NumericLiteralSeparator, Stage 1 feature
Signed-off-by: Rick Waldron <waldron.rick@gmail.com>
Signed-off-by: Rick Waldron <waldron.rick@gmail.com>
* add note about presets [skip ci]
This commit is contained in:
parent
defde165ed
commit
5393a49349
@ -32,7 +32,7 @@
|
|||||||
"babel-template": "7.0.0-alpha.10",
|
"babel-template": "7.0.0-alpha.10",
|
||||||
"babel-traverse": "7.0.0-alpha.10",
|
"babel-traverse": "7.0.0-alpha.10",
|
||||||
"babel-types": "7.0.0-alpha.10",
|
"babel-types": "7.0.0-alpha.10",
|
||||||
"babylon": "7.0.0-beta.11",
|
"babylon": "7.0.0-beta.12",
|
||||||
"convert-source-map": "^1.1.0",
|
"convert-source-map": "^1.1.0",
|
||||||
"debug": "^2.1.1",
|
"debug": "^2.1.1",
|
||||||
"json5": "^0.5.0",
|
"json5": "^0.5.0",
|
||||||
|
|||||||
@ -21,6 +21,6 @@
|
|||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"babel-helper-fixtures": "7.0.0-alpha.10",
|
"babel-helper-fixtures": "7.0.0-alpha.10",
|
||||||
"babylon": "^7.0.0-beta.8"
|
"babylon": "^7.0.0-beta.12"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -0,0 +1,3 @@
|
|||||||
|
node_modules
|
||||||
|
*.log
|
||||||
|
src
|
||||||
36
packages/babel-plugin-syntax-numeric-separator/README.md
Normal file
36
packages/babel-plugin-syntax-numeric-separator/README.md
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
# babel-plugin-syntax-numeric-separator
|
||||||
|
|
||||||
|
> Allow parsing of Numeric Literals (Decimal, Binary, Hex and Octal) that contain a _NumericLiteralSeparator_.
|
||||||
|
|
||||||
|
|
||||||
|
## Installation
|
||||||
|
|
||||||
|
```sh
|
||||||
|
npm install --save-dev babel-plugin-syntax-numeric-separator
|
||||||
|
```
|
||||||
|
|
||||||
|
## Usage
|
||||||
|
|
||||||
|
### Via `.babelrc` (Recommended)
|
||||||
|
|
||||||
|
**.babelrc**
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"plugins": ["syntax-numeric-separator"]
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### Via CLI
|
||||||
|
|
||||||
|
```sh
|
||||||
|
babel --plugins syntax-numeric-separator script.js
|
||||||
|
```
|
||||||
|
|
||||||
|
### Via Node API
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
require("babel-core").transform("code", {
|
||||||
|
plugins: ["syntax-numeric-separator"]
|
||||||
|
});
|
||||||
|
```
|
||||||
13
packages/babel-plugin-syntax-numeric-separator/package.json
Normal file
13
packages/babel-plugin-syntax-numeric-separator/package.json
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
{
|
||||||
|
"name": "babel-plugin-syntax-numeric-separator",
|
||||||
|
"version": "7.0.0-alpha.12",
|
||||||
|
"description": "Allow parsing of Decimal, Binary, Hex and Octal literals that contain a Numeric Literal Separator",
|
||||||
|
"repository": "https://github.com/babel/babel/tree/master/packages/babel-plugin-syntax-numeric-separator",
|
||||||
|
"license": "MIT",
|
||||||
|
"main": "lib/index.js",
|
||||||
|
"keywords": [
|
||||||
|
"babel-plugin"
|
||||||
|
],
|
||||||
|
"dependencies": {},
|
||||||
|
"devDependencies": {}
|
||||||
|
}
|
||||||
@ -0,0 +1,7 @@
|
|||||||
|
export default function () {
|
||||||
|
return {
|
||||||
|
manipulateOptions(opts, parserOpts) {
|
||||||
|
parserOpts.plugins.push("numericSeparator");
|
||||||
|
},
|
||||||
|
};
|
||||||
|
}
|
||||||
@ -0,0 +1,3 @@
|
|||||||
|
src
|
||||||
|
test
|
||||||
|
*.log
|
||||||
114
packages/babel-plugin-transform-numeric-separator/README.md
Normal file
114
packages/babel-plugin-transform-numeric-separator/README.md
Normal file
@ -0,0 +1,114 @@
|
|||||||
|
# babel-plugin-transform-numeric-separator
|
||||||
|
|
||||||
|
> This plugin allows Babel to transform Decimal, Binary, Hex and Octal literals containing Numeric Literal Separator to their non-separated form.
|
||||||
|
|
||||||
|
## Example
|
||||||
|
|
||||||
|
### Decimal Literals
|
||||||
|
|
||||||
|
```js
|
||||||
|
let budget = 1_000_000_000_000;
|
||||||
|
|
||||||
|
// What is the value of `budget`? It's 1 trillion!
|
||||||
|
//
|
||||||
|
// Let's confirm:
|
||||||
|
console.log(budget === 10 ** 12); // true
|
||||||
|
```
|
||||||
|
|
||||||
|
### Binary Literals
|
||||||
|
|
||||||
|
```js
|
||||||
|
let nibbles = 0b1010_0001_1000_0101;
|
||||||
|
|
||||||
|
// Is bit 7 on? It sure is!
|
||||||
|
// 0b1010_0001_1000_0101
|
||||||
|
// ^
|
||||||
|
//
|
||||||
|
// We can double check:
|
||||||
|
console.log(!!(nibbles & (1 << 7))); // true
|
||||||
|
```
|
||||||
|
|
||||||
|
### Hex Literal
|
||||||
|
|
||||||
|
```js
|
||||||
|
// Messages are sent as 24 bit values, but should be
|
||||||
|
// treated as 3 distinct bytes:
|
||||||
|
let message = 0xA0_B0_C0;
|
||||||
|
|
||||||
|
// What's the value of the upper most byte? It's A0, or 160.
|
||||||
|
// We can confirm that:
|
||||||
|
let a = (message >> 16) & 0xFF;
|
||||||
|
console.log(a.toString(16), a); // a0, 160
|
||||||
|
|
||||||
|
// What's the value of the middle byte? It's B0, or 176.
|
||||||
|
// Let's just make sure...
|
||||||
|
let b = (message >> 8) & 0xFF;
|
||||||
|
console.log(b.toString(16), b); // b0, 176
|
||||||
|
|
||||||
|
// What's the value of the lower most byte? It's C0, or 192.
|
||||||
|
// Again, let's prove that:
|
||||||
|
let c = message & 0xFF;
|
||||||
|
console.log(c.toString(16), b); // c0, 192
|
||||||
|
```
|
||||||
|
|
||||||
|
### Octal Literal
|
||||||
|
|
||||||
|
*hand wave emoji*
|
||||||
|
|
||||||
|
Octals are great for permissions, but also look better when represented in `0o0000` form. No real benefit with separators here.
|
||||||
|
|
||||||
|
## Installation
|
||||||
|
|
||||||
|
```sh
|
||||||
|
npm install --save-dev babel-plugin-transform-numeric-separator
|
||||||
|
```
|
||||||
|
|
||||||
|
## Usage
|
||||||
|
|
||||||
|
### Via `.babelrc` (Recommended)
|
||||||
|
|
||||||
|
**.babelrc**
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"plugins": ["transform-numeric-separator"]
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### Via CLI
|
||||||
|
|
||||||
|
```sh
|
||||||
|
babel --plugins transform-numeric-separator script.js
|
||||||
|
```
|
||||||
|
|
||||||
|
### Via Node API
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
require("babel-core").transform("code", {
|
||||||
|
plugins: ["transform-numeric-separator"]
|
||||||
|
});
|
||||||
|
```
|
||||||
|
|
||||||
|
## Additional Information
|
||||||
|
|
||||||
|
If you need to further compile ES2015 Decimal, Binary, Hex and Octal number representations to their pre-ES2015 numeric literal form, add the [`"transform-es2015-literals"`](http://babeljs.io/docs/plugins/transform-es2015-literals/) plugin:
|
||||||
|
|
||||||
|
> `transform-es2015-literals` is already included in [babel-preset-env](https://github.com/babel/babel-preset-env) and babel-preset-es2015.
|
||||||
|
|
||||||
|
### Via `.babelrc` (Recommended)
|
||||||
|
|
||||||
|
**.babelrc**
|
||||||
|
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"presets": ["env"],
|
||||||
|
"plugins": ["transform-numeric-separator"]
|
||||||
|
}
|
||||||
|
{
|
||||||
|
"plugins": ["transform-numeric-separator", "transform-es2015-literals"]
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
## References
|
||||||
|
|
||||||
|
* [Proposal: Numeric Separators](https://github.com/samuelgoto/proposal-numeric-separator)
|
||||||
@ -0,0 +1,17 @@
|
|||||||
|
{
|
||||||
|
"name": "babel-plugin-transform-numeric-separator",
|
||||||
|
"version": "7.0.0-alpha.12",
|
||||||
|
"description": "Remove numeric separators from Decimal, Binary, Hex and Octal literals",
|
||||||
|
"repository": "https://github.com/babel/babel/tree/master/packages/babel-plugin-transform-numeric-separator",
|
||||||
|
"license": "MIT",
|
||||||
|
"main": "lib/index.js",
|
||||||
|
"keywords": [
|
||||||
|
"babel-plugin"
|
||||||
|
],
|
||||||
|
"dependencies": {
|
||||||
|
"babel-plugin-syntax-numeric-separator": "7.0.0-alpha.12"
|
||||||
|
},
|
||||||
|
"devDependencies": {
|
||||||
|
"babel-helper-plugin-test-runner": "7.0.0-alpha.10"
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,31 @@
|
|||||||
|
import syntaxNumericSeparator from "babel-plugin-syntax-numeric-separator";
|
||||||
|
|
||||||
|
export default function () {
|
||||||
|
|
||||||
|
function replacer(value) {
|
||||||
|
return value.replace(/_/g, "");
|
||||||
|
}
|
||||||
|
|
||||||
|
function replaceNumberArg({ node }) {
|
||||||
|
if (node.callee.name === "Number") {
|
||||||
|
node.arguments[0].value = replacer(node.arguments[0].value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const CallExpression = replaceNumberArg;
|
||||||
|
const NewExpression = replaceNumberArg;
|
||||||
|
|
||||||
|
return {
|
||||||
|
inherits: syntaxNumericSeparator,
|
||||||
|
|
||||||
|
visitor: {
|
||||||
|
CallExpression,
|
||||||
|
NewExpression,
|
||||||
|
NumericLiteral({ node }) {
|
||||||
|
if (node.extra && /_/.test(node.extra.raw)) {
|
||||||
|
node.value = replacer(node.extra.raw);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
},
|
||||||
|
};
|
||||||
|
}
|
||||||
9
packages/babel-plugin-transform-numeric-separator/test/fixtures/number/exec.js
vendored
Normal file
9
packages/babel-plugin-transform-numeric-separator/test/fixtures/number/exec.js
vendored
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
assert.equal(Number("1_000"), Number("1000"));
|
||||||
|
assert.equal(Number("0xAE_BE_CE"), Number("0xAEBECE"));
|
||||||
|
assert.equal(Number("0b1010_0001_1000_0101"), Number("0b1010000110000101"));
|
||||||
|
assert.equal(Number("0o0_6_6_6"), Number("0o0666"));
|
||||||
|
|
||||||
|
assert.equal(new Number("1_000").valueOf(), new Number("1000").valueOf());
|
||||||
|
assert.equal(new Number("0xAE_BE_CE").valueOf(), new Number("0xAEBECE").valueOf());
|
||||||
|
assert.equal(new Number("0b1010_0001_1000_0101").valueOf(), new Number("0b1010000110000101").valueOf());
|
||||||
|
assert.equal(new Number("0o0_6_6_6").valueOf(), new Number("0o0666").valueOf());
|
||||||
3
packages/babel-plugin-transform-numeric-separator/test/fixtures/number/options.json
vendored
Normal file
3
packages/babel-plugin-transform-numeric-separator/test/fixtures/number/options.json
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
{
|
||||||
|
"plugins": ["transform-numeric-separator"]
|
||||||
|
}
|
||||||
4
packages/babel-plugin-transform-numeric-separator/test/fixtures/removal/exec.js
vendored
Normal file
4
packages/babel-plugin-transform-numeric-separator/test/fixtures/removal/exec.js
vendored
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
assert.equal(1_000, 1000);
|
||||||
|
assert.equal(0xAE_BE_CE, 0xAEBECE);
|
||||||
|
assert.equal(0b1010_0001_1000_0101, 0b1010000110000101);
|
||||||
|
assert.equal(0o0_6_6_6, 0o0666);
|
||||||
3
packages/babel-plugin-transform-numeric-separator/test/fixtures/removal/options.json
vendored
Normal file
3
packages/babel-plugin-transform-numeric-separator/test/fixtures/removal/options.json
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
{
|
||||||
|
"plugins": ["transform-numeric-separator"]
|
||||||
|
}
|
||||||
@ -0,0 +1,4 @@
|
|||||||
|
1_000;
|
||||||
|
0xA0_B0_C0;
|
||||||
|
0b1010_0001_1000_0101;
|
||||||
|
0o0_6_6_6;
|
||||||
@ -0,0 +1,4 @@
|
|||||||
|
assert.equal(1_000, 1000);
|
||||||
|
assert.equal(0xAE_BE_CE, 11452110);
|
||||||
|
assert.equal(0b1010_0001_1000_0101, 41349);
|
||||||
|
assert.equal(0o0_6_6_6, 438);
|
||||||
@ -0,0 +1,4 @@
|
|||||||
|
1000;
|
||||||
|
10531008;
|
||||||
|
41349;
|
||||||
|
438;
|
||||||
@ -0,0 +1,3 @@
|
|||||||
|
{
|
||||||
|
"plugins": ["transform-numeric-separator", "transform-es2015-literals"]
|
||||||
|
}
|
||||||
@ -0,0 +1,3 @@
|
|||||||
|
import runner from "babel-helper-plugin-test-runner";
|
||||||
|
|
||||||
|
runner(__dirname);
|
||||||
@ -8,6 +8,7 @@
|
|||||||
"repository": "https://github.com/babel/babel/tree/master/packages/babel-preset-stage-1",
|
"repository": "https://github.com/babel/babel/tree/master/packages/babel-preset-stage-1",
|
||||||
"main": "lib/index.js",
|
"main": "lib/index.js",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
"babel-plugin-syntax-numeric-separator": "7.0.0-alpha.12",
|
||||||
"babel-plugin-transform-decorators": "7.0.0-alpha.10",
|
"babel-plugin-transform-decorators": "7.0.0-alpha.10",
|
||||||
"babel-plugin-transform-export-extensions": "7.0.0-alpha.10",
|
"babel-plugin-transform-export-extensions": "7.0.0-alpha.10",
|
||||||
"babel-preset-stage-2": "7.0.0-alpha.10"
|
"babel-preset-stage-2": "7.0.0-alpha.10"
|
||||||
|
|||||||
@ -2,6 +2,7 @@ import presetStage2 from "babel-preset-stage-2";
|
|||||||
|
|
||||||
import transformDecorators from "babel-plugin-transform-decorators";
|
import transformDecorators from "babel-plugin-transform-decorators";
|
||||||
import transformExportExtensions from "babel-plugin-transform-export-extensions";
|
import transformExportExtensions from "babel-plugin-transform-export-extensions";
|
||||||
|
import transformNumericSeparator from "babel-plugin-transform-numeric-separator";
|
||||||
|
|
||||||
export default function () {
|
export default function () {
|
||||||
return {
|
return {
|
||||||
@ -11,6 +12,7 @@ export default function () {
|
|||||||
plugins: [
|
plugins: [
|
||||||
transformDecorators,
|
transformDecorators,
|
||||||
transformExportExtensions,
|
transformExportExtensions,
|
||||||
|
transformNumericSeparator,
|
||||||
],
|
],
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@ -8,7 +8,7 @@
|
|||||||
"repository": "https://github.com/babel/babel/tree/master/packages/babel-template",
|
"repository": "https://github.com/babel/babel/tree/master/packages/babel-template",
|
||||||
"main": "lib/index.js",
|
"main": "lib/index.js",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"babylon": "7.0.0-beta.11",
|
"babylon": "7.0.0-beta.12",
|
||||||
"babel-traverse": "7.0.0-alpha.10",
|
"babel-traverse": "7.0.0-alpha.10",
|
||||||
"babel-types": "7.0.0-alpha.10",
|
"babel-types": "7.0.0-alpha.10",
|
||||||
"lodash": "^4.2.0"
|
"lodash": "^4.2.0"
|
||||||
|
|||||||
@ -12,7 +12,7 @@
|
|||||||
"babel-helper-function-name": "7.0.0-alpha.7",
|
"babel-helper-function-name": "7.0.0-alpha.7",
|
||||||
"babel-messages": "7.0.0-alpha.10",
|
"babel-messages": "7.0.0-alpha.10",
|
||||||
"babel-types": "7.0.0-alpha.10",
|
"babel-types": "7.0.0-alpha.10",
|
||||||
"babylon": "7.0.0-beta.11",
|
"babylon": "7.0.0-beta.12",
|
||||||
"debug": "^2.2.0",
|
"debug": "^2.2.0",
|
||||||
"globals": "^9.0.0",
|
"globals": "^9.0.0",
|
||||||
"invariant": "^2.2.0",
|
"invariant": "^2.2.0",
|
||||||
|
|||||||
@ -14,6 +14,6 @@
|
|||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"babel-generator": "7.0.0-alpha.10",
|
"babel-generator": "7.0.0-alpha.10",
|
||||||
"babylon": "^7.0.0-beta.8"
|
"babylon": "^7.0.0-beta.12"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user