Age | Commit message (Expand) | Author |
2013-03-11 | Disable `unsafe` by default...Close #147
| Mihai Bazon |
2013-03-04 | Fix reordering comparisons...Close #143
| Mihai Bazon |
2013-03-01 | Drop last `default:` if it's the last branch and empty...Close #141
| Mihai Bazon |
2013-03-01 | Compress boolean constants after evaluation...Close #137
| Mihai Bazon |
2013-02-19 | Fix compressing `do {...} while (false)`...It's not safe to transform it to {...} because the body might contain
`break`. The solution could be more elaborate (detect if body contains
`break`) but I don't think it's worth the trouble.
Close #129
| Mihai Bazon |
2013-02-06 | Give up evaluating (unary-prefix '-' 0)...Close #117
------
JS, WHY YOU SUCK SO BADLY? ;-(
| Mihai Bazon |
2013-02-06 | Fix handling of constants...Close #113
| Mihai Bazon |
2013-01-23 | Fix #105: property comparison to undefined is not always safe | Richard Gibson |
2013-01-17 | Handle String() with no arguments....Fix #91
| Mihai Bazon |
2012-12-21 | Optimize new Array(1, 2, 3) → [1, 2, 3]...Close #74
| Mihai Bazon |
2012-12-05 | small improvement on merging assignments into hoisted vars | Mihai Bazon |
2012-12-05 | When hoisting variables, try to merge in assignments that follow. | Mihai Bazon |
2012-11-30 | Don't messup compressor stack while optimizing Switch...Fix #59
| Mihai Bazon |
2012-11-23 | fix for https://github.com/mishoo/UglifyJS/issues/474 | Mihai Bazon |
2012-11-17 | retain (1,eval) as is when it's the expression of an AST_Call...otherwise we change the meaning of eval from global to lexical.
| Mihai Bazon |
2012-11-14 | better solution for the last test in constant switch folding | Mihai Bazon |
2012-11-14 | optimize constant switch blocks...ref. mishoo/UglifyJS#441
| Mihai Bazon |
2012-11-13 | Merge branch 'optimize_concat' of https://github.com/rvanvelzen/UglifyJS2 int... | Mihai Bazon |
2012-11-13 | don't change order in binary expressions if both operands have side effects | Mihai Bazon |
2012-11-12 | Add simple optimization for empty-string concats....ref. #43
| Richard van Velzen |
2012-11-12 | fix invalid AST produced by dropping unused variable...close #44
| Mihai Bazon |
2012-11-11 | convert x.toString() to ""+x instead of x+""...In some places this can save one byte in whitespace, e.g. after return.
Example:
function f(arg) {
// return""+arg - no space between return and ""
return arg.toString();
}
| Dan Wolff |
2012-11-08 | AST_LabelRef no longer inherits from AST_SymbolRef | Mihai Bazon |
2012-11-08 | optimization for if/break as first statement in a loop body... for(...; x; ...) if (y) break; → for(...; x&&!y; ...);
similarly for `while` and some combinations (i.e. the `break` appears in the
`else` clause, etc.)
| Mihai Bazon |
2012-11-05 | convert `while` into `for` | Mihai Bazon |
2012-11-05 | minor | Mihai Bazon |
2012-11-05 | minor optimization...for `==` or `!=` against a constant, prefer to display the constant first.
should help a bit after gzip, i.e.:
typeof foo=="undefined"
^^^^^^ ^^^^^^^^^^^^^
vs:
"undefined"==typeof foo
^^^^^^^^^^^^^^^^^^^ (longer sequence that could repeat)
idea stolen from closure.
| Mihai Bazon |
2012-11-02 | use a Dictionary object instead of plain object for hashes...to mitigate the `__proto__` issue
related to #30
| Mihai Bazon |
2012-11-01 | it's safe to negate expression in !EXP only in boolean context...#kendo
| Mihai Bazon |
2012-11-01 | added unsafe_comps for negating `<=` with `>`...since it has the potential to break code, let's keep it disabled by default
| Mihai Bazon |
2012-11-01 | fix compressing UnaryPrefix...only try negating the expression if the operator is `!`
#kendo
| Mihai Bazon |
2012-10-30 | don't move expressions containing the binary `in` operator into the `for` ini......(opera can't parse it)
close #25
| Mihai Bazon |
2012-10-24 | fix for `if (...) return; else return ...;`...(it was assumed that the first `return` always contains a value)
close #22
| Mihai Bazon |
2012-10-22 | more sequence optimizations (lift some sequences above binary/unary expressio... | Mihai Bazon |
2012-10-19 | minor fix for dropping unused definitions.... function f(x, y) {
var g = function() { return h() };
var h = function() { return g() };
return x + y;
}
now compresses to `function f(x, y) { return x + y }`
| Mihai Bazon |
2012-10-18 | more optimizations for some break/continue cases | Mihai Bazon |
2012-10-17 | more small optimizations...(unlikely to help for hand-written code)
| Mihai Bazon |
2012-10-17 | define aborts on AST_If: true if both branches abort | Mihai Bazon |
2012-10-17 | employ a better parser for command-line arguments...to support passing commas in strings in for example:
uglifyjs2 -cd TEST="'a,b'" <<EOF
console.log(TEST);
EOF
→ console.log("a,b")
close #14
| Mihai Bazon |
2012-10-13 | drop unused function arguments...also add test for "drop_unused" (the last one fails for now)
| Mihai Bazon |
2012-10-13 | fix compressing benchmark.js (it tried to evaluate a statement)...the following code in benchmark.js triggered the issue:
support.decompilation = Function(
'return (' + (function(x) { return { 'x': '' + (1 + x) + '', 'y': 0 }; }) + ')'
)()(0).x === '1';
technically that could be resolved into a constant expression, but seems
it's being used here for browser bugs detection :-\
| Mihai Bazon |
2012-10-12 | remove the $self hack...operations are destructive anyway, so there's no point to clone the nodes in
the transformer. speed++
| Mihai Bazon |
2012-10-11 | cleanup...- use prototype-less objects where feasible (minor speed improvement)
- get rid of HOP
| Mihai Bazon |
2012-10-10 | drop unused variable | Mihai Bazon |
2012-10-09 | minor | Mihai Bazon |
2012-10-09 | add AST_Infinity node | Mihai Bazon |
2012-10-09 | added $propdoc to AST nodes and some cleanups...hopefully we can make the AST documentation self-generating
| Mihai Bazon |
2012-10-09 | minor AST cleanup (AST_BlockStatement may inherit from AST_Block) | Mihai Bazon |
2012-10-09 | fix detecting symbols in use | Mihai Bazon |
2012-10-08 | eliminate redundant directives in the same scope | Mihai Bazon |