Fábio Santos
46158d5114
Make AST_Class inherit AST_Scope instead of AST_Object
...
This is one of those days I'd love to use multiple inheritance.
An AST_Class has lots of common with AST_Object, but unfortunately
`instanceof AST_Scope` is used very, very much, and a class has its name
inside its own special pocket scope. This compels me to make AST_Class
inherit Scope instead.
It looks like, although there is much in common with AST_Object,
`instanceof AST_Object` seldom are made, perhaps because it is less
often necessary to traverse an object than a scope.
2016-03-22 11:42:05 +02:00
Fábio Santos
7ea3ab6b58
static properties
2016-03-22 11:41:01 +02:00
Fábio Santos
a9a38ade1d
Starting ES6 classes
2016-03-22 11:41:01 +02:00
Fábio Santos
44ecbdf5f0
Accept keyword names as concise method names
2016-03-22 11:41:01 +02:00
Fábio Santos
858d763e62
Make concise methods work with propmangle
2016-03-22 11:41:01 +02:00
Fábio Santos
24b8e1203e
Create a new symbol for methods' names
2016-03-22 11:41:01 +02:00
Fábio Santos
e4f0db47ed
Just making sure that concise methods are separated by commas. When classes come, they won't be necessary.
2016-03-22 11:41:01 +02:00
Fábio Santos
8c05450ce0
start concise methods
2016-03-22 11:41:01 +02:00
Fábio Santos
5e1c89db44
Allow 'of' to be a name.
2016-03-22 11:41:01 +02:00
Fábio Santos
292c131743
Using single quotes
2016-03-22 11:41:01 +02:00
Fábio Santos
bfeb1afad0
computed properties
2016-03-22 11:41:01 +02:00
Fábio Santos
bd3a9d3066
Add a test to make sure future generations don't hoist lets
2016-03-22 11:41:00 +02:00
Fábio Santos
4ec5d8f644
parse, output the let statement
2016-03-22 11:41:00 +02:00
Fábio Santos
a92a14d171
Remove unused state variable in_parameters, and also remove unreachable code (try_an_object always returned an object!)
2016-03-22 11:41:00 +02:00
Fábio Santos
2a24fa8d2b
prefixed template strings, like "String.rawfoo\nbar".
2016-03-22 11:41:00 +02:00
Fábio Santos
e0b78bfa5f
Parse and output ES6 template strings. Yikes!
2016-03-22 11:41:00 +02:00
Fábio Santos
a54b64d660
What about --mangle-props being on and --mangle being off?
2016-03-22 11:41:00 +02:00
Fábio Santos
2d74aca46a
play nice with propmangle
2016-03-22 11:41:00 +02:00
Fábio Santos
cfb1b5d848
Starting destructuring expressions
2016-03-22 11:41:00 +02:00
Fábio Santos
048eac6b29
Tolerate expansions in vardefs, too!
2016-03-22 11:41:00 +02:00
Fábio Santos
a170ad9d0d
Destructuring vardef in for..of and for..in
2016-03-22 11:41:00 +02:00
Fábio Santos
d757202b74
Do not mangle a name if it is in a destructuring vardef.
2016-03-22 11:41:00 +02:00
Fábio Santos
a3a4ae5ef8
Add holes in destructuring defs, also make them nestable
2016-03-22 11:40:44 +02:00
Fábio Santos
3b189f86ff
Parse and compress destructuring VarDefs
2016-03-22 11:40:44 +02:00
Fábio Santos
5efbe1604e
A little refactoring. Add a new function to get all symbols in a destructuring.
2016-03-22 11:40:44 +02:00
Fábio Santos
16e928348b
prepare AST_Destructuring for the Ents
2016-03-22 11:40:44 +02:00
Fábio Santos
046e303669
s/binary/number/g
2016-03-22 11:40:44 +02:00
Fábio Santos
ebd0682376
Add new-style octal literals and make the B and the O case insensitive.
2016-03-22 11:40:44 +02:00
Fábio Santos
ac1d3f0e88
remove Symbol's argument when we're unsafe and it's undeclared
2016-03-22 11:40:44 +02:00
Fábio Santos
6f93a8d4a1
Fix evaluating the typeof an arrow function. Using evaluate on used to cause a crash.
2016-03-22 11:40:44 +02:00
Fábio Santos
a4d6ed076a
Parse binary number literals
2016-03-22 11:40:44 +02:00
Fábio Santos
0a4270b358
Super!
2016-03-22 11:40:26 +02:00
Fábio Santos
7f825c8244
expand parameters
...
Conflicts:
test/compress/harmony.js
2016-03-22 11:40:26 +02:00
Fábio Santos
7112c49c92
Uglifyjs already supports super as an implicit global! Just adding a test to indicate that.
2016-03-22 11:40:26 +02:00
Fábio Santos
df95318e8b
=> with destructuring arguments. Requires a lot of parser changes
2016-03-22 11:40:26 +02:00
Fábio Santos
aa127457d5
Adding arrow functions
2016-03-22 11:40:26 +02:00
Fábio Santos
e4b87bface
for...of
2016-03-22 11:39:49 +02:00
Fábio Santos
8ca033e7f2
Add a test to verify that destructuring arguments work with #203 code
2016-03-22 11:39:49 +02:00
Fábio Santos
3f87afdb2c
test that names used in destructurings don't get hoisted
2016-03-22 11:39:49 +02:00
Fábio Santos
708001d2f5
do not support destructuring arguments and ngInject
2016-03-22 11:39:49 +02:00
Fábio Santos
6645da0ea2
remove trace statement
2016-03-22 11:39:49 +02:00
Fábio Santos
aaa8f25bf0
Starting destructuring.
2016-03-22 11:39:49 +02:00
philippsimon
ee6c9fabb7
Fix: Uglified Number.prototype functions on big numbers
2016-03-14 12:41:06 +01:00
kzc
102d1b9137
#877 Ignore mangle sort option
2016-02-27 15:33:10 -05:00
Mihai Bazon
294861ba96
v2.6.2
2016-02-22 21:39:14 +02:00
kzc
11b0efdf84
boolean_expression ? true : false --> boolean_expression
2016-02-22 17:59:36 +01:00
kzc
5486b68850
Take operator || precendence into account for AST_If optimization.
...
Fixes #979 .
2016-02-21 12:05:02 -05:00
Richard van Velzen
bdd8e34f63
Allow --no-* options to disable their respective parameter
...
Fixes #974 and #972
2016-02-17 20:04:45 +01:00
alexlamsl
6547437725
preserve ThisBinding for side_effects
2016-02-17 19:34:01 +01:00
Richard van Velzen
9662228f6a
Don't compress (0, eval)() to eval()
2016-02-16 19:00:48 +01:00