aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/scope.js5
-rw-r--r--test/compress/asm.js66
2 files changed, 71 insertions, 0 deletions
diff --git a/lib/scope.js b/lib/scope.js
index edefc29b..896efacc 100644
--- a/lib/scope.js
+++ b/lib/scope.js
@@ -428,6 +428,11 @@ AST_Toplevel.DEFMETHOD("mangle_names", function(options) {
if (options.cache && node instanceof AST_Toplevel) {
node.globals.each(mangle);
}
+ if (node instanceof AST_Defun && tw.has_directive("use asm")) {
+ var sym = new AST_SymbolRef(node.name);
+ sym.scope = node;
+ sym.reference(options);
+ }
node.variables.each(function(def) {
if (!defer_redef(def)) mangle(def);
});
diff --git a/test/compress/asm.js b/test/compress/asm.js
index 1f00f8f2..0ea60874 100644
--- a/test/compress/asm.js
+++ b/test/compress/asm.js
@@ -166,3 +166,69 @@ asm_nested_functions: {
}
expect_exact: '0;function a(){"use asm";0.0}0;function b(){0;function c(){"use asm";0.0}0;function d(){0}0}0;'
}
+
+issue_3636_1: {
+ mangle = {}
+ input: {
+ function n(stdlib, foreign, buffer) {
+ "use asm";
+ function add(x, y) {
+ x = x | 0;
+ y = y | 0;
+ return x + y | 0;
+ }
+ return {
+ add: add
+ };
+ }
+ console.log(new n().add("foo", 42));
+ }
+ expect: {
+ function n(o, e, u) {
+ "use asm";
+ function d(n, o) {
+ n = n | 0;
+ o = o | 0;
+ return n + o | 0;
+ }
+ return {
+ add: d
+ };
+ }
+ console.log(new n().add("foo", 42));
+ }
+ expect_stdout: "42"
+}
+
+issue_3636_2: {
+ mangle = {}
+ input: {
+ var n = function(stdlib, foreign, buffer) {
+ "use asm";
+ function add(x, y) {
+ x = x | 0;
+ y = y | 0;
+ return x + y | 0;
+ }
+ return {
+ add: add
+ };
+ };
+ console.log(new n().add("foo", 42));
+ }
+ expect: {
+ var n = function(n, o, e) {
+ "use asm";
+ function r(n, o) {
+ n = n | 0;
+ o = o | 0;
+ return n + o | 0;
+ }
+ return {
+ add: r
+ };
+ };
+ console.log(new n().add("foo", 42));
+ }
+ expect_stdout: "42"
+}