aboutsummaryrefslogtreecommitdiff
path: root/lib
AgeCommit message (Expand)Author
2012-09-10adaptive base54 digits depending on char frequency (WIP)Mihai Bazon
2012-09-10more progress on the compressor (WIP)Mihai Bazon
2012-09-08minorMihai Bazon
2012-09-08fix output for division followed by regexp...( v1 report: https://github.com/mishoo/UglifyJS/pull/458 ) Mihai Bazon
2012-09-07checkpointMihai Bazon
2012-09-07fix bug (forgot arg name)Mihai Bazon
2012-09-07always keep declarations found in unreachable code...a few more tests and some cleanups. Mihai Bazon
2012-09-07fixed tests (need to drop the toplevel block in "expected" if it's a single s...Mihai Bazon
2012-09-05don't duplicate argument namesMihai Bazon
2012-09-05fix for variable names like `toString`Mihai Bazon
2012-09-05support for hoisting declarations...and finally it seems we beat v1 in terms of compression Mihai Bazon
2012-09-05cleaned up usage of AST_BlockStatement...The following nodes were instances of AST_BlockStatement: AST_Scope, AST_SwitchBlock, AST_SwitchBranch. Also, AST_Try, AST_Catch, AST_Finally were having a body instanceof AST_BlockStatement. Overloading the meaning of AST_BlockStatement this way turned out to be a mess; we now have an AST_Block class that is the base class for things having a block of statements (might or might not be bracketed). The `this.body` of AST_Scope, AST_Try, AST_Catch, AST_Finally is now an array of statements (as they inherit from AST_Block). Avoiding calling superclass's _walk function in walkers (turns out we walked a node multiple times). Mihai Bazon
2012-09-04checkpointMihai Bazon
2012-09-04more fiddling with boolean expressions, etc....optimize away while(false), and transform while(true) ==> for(;;). UNSAFE: some expressions are optimized away when we're in boolean context and can determine that the value will always be true or false. For example: x() || true ==> always `true` in boolean context x() && false ==> always `false` in boolean context It's not technically correct to drop these expressions since we drop the function call too (that might have side effects); on the other hand, I can't see any legitimate use for such expressions and they might simply indicate a bug (we do warn about it). Mihai Bazon
2012-09-04if present, the `else` in an `if` should always be forced statementMihai Bazon
2012-09-03boolean and if/exit optimizationsMihai Bazon
2012-09-03minorMihai Bazon
2012-09-03more optimizations for ifs/conditionals...(XXX: should add tests before anything else) Mihai Bazon
2012-09-03resolve constant expressionsMihai Bazon
2012-09-03jumps, try and definitions are statements tooMihai Bazon
2012-09-03an AST_If is too a StatementWithBodyMihai Bazon
2012-09-03a LabeledStatement should be in fact a StatementWithBody...This fixes output for: if (foo) { moo: if (bar) { break moo; } } else { baz(); } (the labeled statement must be outputted inside brackets) Mihai Bazon
2012-09-03switch branches must be declared `required` so that the compressor doesn't...replace nodes with a single statement. looks stable for now, though mess begins to sink in. need to review the AST hierarchy. Mihai Bazon
2012-09-03Reverting "minor perf. improvements"...Revert "minor perf. improvements" This reverts commit 24bfd55a22afd791d4a97694641831cfbd27fb14. broke the parser somehow; too early to optimize, let's get the other stuff running. Mihai Bazon
2012-09-02add source mappings for more node types; started CLI utilityMihai Bazon
2012-09-02minor perf. improvementsMihai Bazon
2012-08-29started support for generating source maps (WIP)...plugged in @fitzgen's source-map library Mihai Bazon
2012-08-29don't mangle names of setters/gettersMihai Bazon
2012-08-28docstring for AST_StatementWithBodyMihai Bazon
2012-08-28fix output for arrays containing undefined values...[1,,2,] ==> [1,,2] instead of [1,undefined,2] Mihai Bazon
2012-08-28fix code generator for this case:...if (foo) { with (bar) if (baz) x(); } else y(); (the compressor removes the brackets since the consequent consists of a single statement, but the codegen must include the brackets because otherwise the `else` would refer to the inner `if`) Mihai Bazon
2012-08-27update (c) yearsMihai Bazon
2012-08-27fix compressing `a,b; return c;` into `return a,b,c;`Mihai Bazon
2012-08-27added print_to_string helper methodMihai Bazon
2012-08-23fix current_col and force a newline every 32K (support options.max_line_len)Mihai Bazon
2012-08-22added licenseMihai Bazon
2012-08-22wrote more of the compressor and added some testsMihai Bazon
2012-08-22fix output for certain edge cases...the statements if, for, do, while and with might have an AST_EmptyStatement as body; if that's the case, we need to make sure that the semicolon gets in the output. Mihai Bazon
2012-08-22declare some properties in the node constructor so that they're copied in cloneMihai Bazon
2012-08-21hint that brackets may be required in AST_BlockStatementMihai Bazon
2012-08-21cleaned up some mess and started the actual compressorMihai Bazon
2012-08-21some reorganization...(moved pretty much everything that relates to scope in scope.js, added a module for NodeJS that can be used with require() and exports everything.) Mihai Bazon
2012-08-21handle labels properly...(they can't be handled the same way as variables in a scope) Mihai Bazon
2012-08-21warn about unreferenced symbolsMihai Bazon
2012-08-21more fixes:...- added walker for AST_ObjectProperty - handle redefinitions properly (only mangle one symbol, make them all point to a single definition) DynarchLIB seems to run fine after mangling + compressed output. Mihai Bazon
2012-08-20added mangler and other stuffMihai Bazon
2012-08-20doc (WIP)Mihai Bazon
2012-08-19simple visitor API and code to figure out scope and referencesMihai Bazon
2012-08-18some fixes (need testing) in AST_If codegenMihai Bazon
2012-08-17minor whitespace issuesMihai Bazon