Tags:
- [Breaking Change]
- [Spec Compliancy]
- [New Feature]
- [Bug Fix]
- [Documentation]
- [Internal]
- [Polish]
Semver Policy: https://github.com/babel/babylon#semver
Note: Gaps between patch versions are faulty, broken or test releases.
See the Babel Changelog for the pre-6.8.0 version Changelog.
Add static errors for object rest (#149) (@danez)
Object rest copies the rest of properties from the right hand side obj
starting from the left to right.
let { x, y, ...z } = { x: 1, y: 2, z: 3 };
// x = 1
// y = 2
// z = { z: 3 }
SyntaxError: The rest element has to be the last element when destructuring (1:10)
> 1 | let { ...x, y, z } = { x: 1, y: 2, z: 3};
| ^
# Previous behavior:
# x = { x: 1, y: 2, z: 3 }
# y = 2
# z = 3
Before, this was just a more verbose way of shallow copying obj
since it doesn't actually do what you think.
SyntaxError: Cannot have multiple rest elements when destructuring (1:13)
> 1 | let { x, ...y, ...z } = { x: 1, y: 2, z: 3};
| ^
# Previous behavior:
# x = 1
# y = { y: 2, z: 3 }
# z = { y: 2, z: 3 }
Before y and z would just be the same value anyway so there is no reason to need to have both.
SyntaxError: A trailing comma is not permitted after the rest element (1:16)
let { x, y, ...z, } = obj;
The rationale for this is that the use case for trailing comma is that you can add something at the end without affecting the line above. Since a RestProperty always has to be the last property it doesn't make sense.
get / set are valid property names in default assignment (#142) (@jezell)
// valid
function something({ set = null, get = null }) {}
- #139 Don't do the duplicate check if not an identifier (#140) @hzoo
// regression with duplicate export check
SyntaxError: ./typography.js: `undefined` has already been exported. Exported identifiers must be unique. (22:13)
20 |
21 | export const { rhythm } = typography;
> 22 | export const { TypographyStyle } = typography
Bail out for now, and make a change to account for destructuring in the next release.
- #137 - Fix a regression with duplicate exports - it was erroring on all keys in
Object.prototype
. @danez
export toString from './toString';
`toString` has already been exported. Exported identifiers must be unique. (1:7)
> 1 | export toString from './toString';
| ^
2 |
- Disallow duplicate named exports (#107) @kaicataldo
// Only one default export allowed per module. (2:9)
export default function() {};
export { foo as default };
// Only one default export allowed per module. (2:0)
export default {};
export default function() {};
// `Foo` has already been exported. Exported identifiers must be unique. (2:0)
export { Foo };
export class Foo {};
- Add support for computed class property names (#121) @motiz88
// AST
interface ClassProperty <: Node {
type: "ClassProperty";
key: Identifier;
value: Expression;
computed: boolean; // added
}
// with "plugins": ["classProperties"]
class Foo {
[x]
['y']
}
class Bar {
[p]
[m] () {}
}
- Fix
static
property falling through in the declare class Flow AST (#135) @danharper
declare class X {
a: number;
static b: number; // static
c: number; // this was being marked as static in the AST as well
}
- Rephrase "assigning/binding to rvalue" errors to include context (#119) @motiz88
// Used to error with:
// SyntaxError: Assigning to rvalue (1:0)
// Now:
// Invalid left-hand side in assignment expression (1:0)
3 = 4
// Invalid left-hand side in for-in statement (1:5)
for (+i in {});
- Fix call to
this.parseMaybeAssign
with correct arguments (#133) @danez - Add semver note to changelog (#131) @hzoo
We plan to include some spec compliancy bugs in patch versions. An example was the multiple default exports issue.
- Implement ES2016 check for simple parameter list in strict mode (#106) (Timothy Gu)
It is a Syntax Error if ContainsUseStrict of FunctionBody is true and IsSimpleParameterList of FormalParameters is false. https://tc39.github.io/ecma262/2016/#sec-function-definitions-static-semantics-early-errors
More Context: tc39-notes
For example:
// this errors because it uses destructuring and default parameters
// in a function with a "use strict" directive
function a([ option1, option2 ] = []) {
"use strict";
}
The solution would be to use a top level "use strict" or to remove the destructuring or default parameters when using a function + "use strict" or to.
- Exact object type annotations for Flow plugin (#104) (Basil Hosmer)
Added to flow in https://github.com/facebook/flow/commit/c710c40aa2a115435098d6c0dfeaadb023cd39b8
Looks like:
var a : {| x: number, y: string |} = { x: 0, y: 'foo' };
- Include
typeParameter
location inArrowFunctionExpression
(#126) (Daniel Tschinder) - Error on invalid flow type annotation with default assignment (#122) (Dan Harper)
- Fix Flow return types on arrow functions (#124) (Dan Harper)
- Add tests for export extensions (#127) (Daniel Tschinder)
- Fix Contributing guidelines [skip ci] (Daniel Tschinder)
The only change is to remove the babel-runtime
dependency by compiling with Babel's ES2015 loose mode. So using babylon standalone should be smaller.
This release contains mainly small bugfixes but also updates babylons default mode to es2017. The features for exponentiationOperator
, asyncFunctions
and trailingFunctionCommas
which previously needed to be activated via plugin are now enabled by default and the plugins are now no-ops.
- Fix issues with default object params in async functions (#96) @danez
- Fix issues with flow-types and async function (#95) @danez
- Fix arrow functions with destructuring, types & default value (#94) @danharper
- Fix declare class with qualified type identifier (#97) @danez
- Remove exponentiationOperator, asyncFunctions, trailingFunctionCommas plugins and enable them by default (#98) @danez
- Add JSX spread children (#42) @calebmer
(Be aware that React is not going to support this syntax)
<div>
{...todos.map(todo => <Todo key={todo.id} todo={todo}/>)}
</div>
- Add support for declare module.exports (#72) @danez
declare module "foo" {
declare module.exports: {}
}
- If supplied, attach filename property to comment node loc. (#80) @divmain
- Add identifier name to node loc field (#90) @kittens
- Fix exponential operator to behave according to spec (#75) @danez
- Fix lookahead to not add comments to arrays which are not cloned (#76) @danez
- Fix accidental fall-through in Flow type parsing. (#82) @xiemaisi
- Only allow declares inside declare module (#73) @danez
- Small fix for parsing type parameter declarations (#83) @gabelevi
- Fix arrow param locations with flow types (#57) @danez
- Fixes SyntaxError position with flow optional type (#65) @danez
- Add codecoverage to tests @danez
- Fix tests to not save expected output if we expect the test to fail @danez
- Make a shallow clone of babel for testing @danez
- chore(package): update cross-env to version 2.0.0 (#77) @greenkeeperio-bot
- chore(package): update ava to version 0.16.0 (#86) @greenkeeperio-bot
- chore(package): update babel-plugin-istanbul to version 2.0.0 (#89) @greenkeeperio-bot
- chore(package): update nyc to version 8.0.0 (#88) @greenkeeperio-bot
- Fix the location of params, when flow and default value used (#68) @danez
- Fix performance regression introduced in 6.8.2 with conditionals (#63) @danez
- Fix parse error with yielding jsx elements in generators
function* it() { yield <a></a>; }
(#31) @eldereal - When cloning nodes do not clone its comments (#24) @danez
- Fix parse errors when using arrow functions with an spread element and return type
(...props): void => {}
(#10) @danez - Fix leading comments added from previous node (#23) @danez
- Fix parse errors with flow's optional arguments
(arg?) => {}
(#19) @danez - Support negative numeric type literals @kittens
- Remove line terminator restriction after await keyword @kittens
- Remove grouped type arrow restriction as it seems flow no longer has it @kittens
- Fix parse error with generic methods that have the name
get
orset
class foo { get() {} }
(#55) @vkurchatkin - Fix parse error with arrow functions that have flow type parameter declarations
<T>(x: T): T => x;
(#54) @gabelevi
- Enable skipped tests (#16) @danez
- Add script to test latest version of babylon with babel (#21) @danez
- Upgrade test runner ava @kittens
- Add missing generate-identifier-regex script @kittens
- Rename parser context types @kittens
- Add node v6 to travis testing @hzoo
- Update to Unicode v9 (#45) @mathiasbynens
- Parse type parameter declarations with defaults like
type Foo<T = string> = T
- Type parameter declarations need 1 or more type parameters.
- The existential type
*
is not a valid type parameter. - The existential type
*
is a primary type
- The param list for type parameter declarations now consists of
TypeParameter
nodes - New
TypeParameter
AST Node (replaces using theIdentifier
node before)
interface TypeParameter <: Node {
bound: TypeAnnotation;
default: TypeAnnotation;
name: string;
variance: "plus" | "minus";
}
Parse Method Parameter Decorators (#12)
Method Parameter Decorators is now a TC39 stage 0 proposal.
Examples:
class Foo {
constructor(@foo() x, @bar({ a: 123 }) @baz() y) {}
}
export default function func(@foo() x, @bar({ a: 123 }) @baz() y) {}
var obj = {
method(@foo() x, @bar({ a: 123 }) @baz() y) {}
};
Parse for-await statements (w/ asyncGenerators
plugin) (#17)
There is also a new node type, ForAwaitStatement
.
Async generators and for-await are now a stage 2 proposal.
Example:
async function f() {
for await (let x of y);
}