aboutsummaryrefslogtreecommitdiff
path: root/tools/js-optimizer.js
diff options
context:
space:
mode:
Diffstat (limited to 'tools/js-optimizer.js')
-rw-r--r--tools/js-optimizer.js24
1 files changed, 16 insertions, 8 deletions
diff --git a/tools/js-optimizer.js b/tools/js-optimizer.js
index 8cd357cd..c779b4e6 100644
--- a/tools/js-optimizer.js
+++ b/tools/js-optimizer.js
@@ -2154,13 +2154,26 @@ function prepDotZero(ast) {
traverse(ast, function(node, type) {
if (type == 'unary-prefix' && node[1] == '+') {
if (node[2][0] == 'num') {
- return ['call', ['name', 'DOT$ZERO'], [['num', node[2][1]]]];
+ return ['call', ['name', 'DOT$ZERO'], [node[2]]];
} else if (node[2][0] == 'unary-prefix' && node[2][1] == '-' && node[2][2][0] == 'num') {
- return ['call', ['name', 'DOT$ZERO'], [['num', -node[2][2][1]]]];
+ node[2][2][1] = -node[2][2][1];
+ return ['call', ['name', 'DOT$ZERO'], [node[2][2]]];
}
}
});
}
+function fixDotZero(js) {
+ return js.replace(/DOT\$ZERO\(((0x)?[-+]?[0-9]*\.?[0-9]+([eE][-+]?[0-9]+)?)\)/g, function(m, num) {
+ if (num.substr(0, 2) == '0x') {
+ if (num[2] == '-') num = '-0x' + num.substr(3); // uglify generates 0x-8000 for some reason
+ return eval(num) + '.0';
+ }
+ if (num.indexOf('.') >= 0) return num;
+ var e = num.indexOf('e');
+ if (e < 0) return num + '.0';
+ return num.substr(0, e) + '.0' + num.substr(e);
+ });
+}
// Passes table
@@ -2204,12 +2217,7 @@ if (asm && last) {
}
var js = astToSrc(ast, compress), old;
if (asm && last) {
- js = js.replace(/DOT\$ZERO\(([-+]?[0-9]*\.?[0-9]+([eE][-+]?[0-9]+)?)\)/g, function(m, num) {
- if (num.indexOf('.') >= 0) return num;
- var e = num.indexOf('e');
- if (e < 0) return num + '.0';
- return num.substr(0, e) + '.0' + num.substr(e);
- });
+ js = fixDotZero(js);
}
// remove unneeded newlines+spaces, and print