diff --git a/lib/ast.js b/lib/ast.js index aa49a276..863406bc 100644 --- a/lib/ast.js +++ b/lib/ast.js @@ -1185,6 +1185,11 @@ var AST_Try = DEFNODE("Try", "bcatch bfinally", { bcatch: "[AST_Catch?] the catch block, or null if not present", bfinally: "[AST_Finally?] the finally block, or null if not present" }, + _equals: function(node) { + return all_equals(this.body, node.body) + && prop_equals(this.bcatch, node.bcatch) + && prop_equals(this.bfinally, node.bfinally); + }, walk: function(visitor) { var node = this; visitor.visit(node, function() { diff --git a/test/compress/conditionals.js b/test/compress/conditionals.js index 289ad6d8..cb96ea06 100644 --- a/test/compress/conditionals.js +++ b/test/compress/conditionals.js @@ -2243,3 +2243,110 @@ issue_5544_2: { } expect_stdout: "PASS" } + +issue_5546_1: { + options = { + conditionals: true, + } + input: { + var a; + if (a) + try { + console; + } finally { + console.log("FAIL"); + } + else + try { + console; + } finally { + console.log("PASS"); + } + } + expect: { + var a; + if (a) + try { + console; + } finally { + console.log("FAIL"); + } + else + try { + console; + } finally { + console.log("PASS"); + } + } + expect_stdout: "PASS" +} + +issue_5546_2: { + options = { + conditionals: true, + } + input: { + var a; + if (a) + try { + console; + } catch (e) {} + else + try { + console; + } finally { + console.log("PASS"); + } + } + expect: { + var a; + if (a) + try { + console; + } catch (e) {} + else + try { + console; + } finally { + console.log("PASS"); + } + } + expect_stdout: "PASS" +} + +issue_5546_3: { + options = { + conditionals: true, + } + input: { + var a; + if (a) + try { + FAIL; + } catch (e) { + console.log("FAIL"); + } + else + try { + FAIL; + } catch (e) { + console.log("PASS"); + } + } + expect: { + var a; + if (a) + try { + FAIL; + } catch (e) { + console.log("FAIL"); + } + else + try { + FAIL; + } catch (e) { + console.log("PASS"); + } + } + expect_stdout: "PASS" +}