[Pkg-javascript-commits] [uglifyjs] 160/190: Don't drop unused if scope uses with statement
Antonio Terceiro
terceiro at moszumanska.debian.org
Sun Aug 7 23:17:22 UTC 2016
This is an automated email from the git hooks/post-receive script.
terceiro pushed a commit to annotated tag upstream/2.7.0
in repository uglifyjs.
commit ea31da24559b095a18f7615cfd3c992ecaf495a3
Author: Anthony Van de Gejuchte <anthonyvdgent at gmail.com>
Date: Fri Jun 10 00:34:20 2016 +0200
Don't drop unused if scope uses with statement
Fix provided by @kzc
---
lib/compress.js | 1 +
test/compress/issue-1105.js | 147 ++++++++++++++++++++++++++++++++++++++++++++
2 files changed, 148 insertions(+)
diff --git a/lib/compress.js b/lib/compress.js
index 461c3c4..4e04e96 100644
--- a/lib/compress.js
+++ b/lib/compress.js
@@ -1326,6 +1326,7 @@ merge(Compressor.prototype, {
if (compressor.option("unused")
&& !(self instanceof AST_Toplevel)
&& !self.uses_eval
+ && !self.uses_with
) {
var in_use = [];
var in_use_ids = {}; // avoid expensive linear scans of in_use
diff --git a/test/compress/issue-1105.js b/test/compress/issue-1105.js
new file mode 100644
index 0000000..4205fdf
--- /dev/null
+++ b/test/compress/issue-1105.js
@@ -0,0 +1,147 @@
+with_in_global_scope: {
+ options = {
+ unused: true
+ }
+ input: {
+ var o = 42;
+ with(o) {
+ var foo = 'something'
+ }
+ doSomething(o);
+ }
+ expect: {
+ var o=42;
+ with(o)
+ var foo = "something";
+ doSomething(o);
+ }
+}
+with_in_function_scope: {
+ options = {
+ unused: true
+ }
+ input: {
+ function foo() {
+ var o = 42;
+ with(o) {
+ var foo = "something"
+ }
+ doSomething(o);
+ }
+ }
+ expect: {
+ function foo() {
+ var o=42;
+ with(o)
+ var foo = "something";
+ doSomething(o)
+ }
+ }
+}
+compress_with_with_in_other_scope: {
+ options = {
+ unused: true
+ }
+ input: {
+ function foo() {
+ var o = 42;
+ with(o) {
+ var foo = "something"
+ }
+ doSomething(o);
+ }
+ function bar() {
+ var unused = 42;
+ return something();
+ }
+ }
+ expect: {
+ function foo() {
+ var o = 42;
+ with(o)
+ var foo = "something";
+ doSomething(o)
+ }
+ function bar() {
+ return something()
+ }
+ }
+}
+with_using_existing_variable_outside_scope: {
+ options = {
+ unused: true
+ }
+ input: {
+ function f() {
+ var o = {};
+ var unused = {}; // Doesn't get removed because upper scope uses with
+ function foo() {
+ with(o) {
+ var foo = "something"
+ }
+ doSomething(o);
+ }
+ foo()
+ }
+ }
+ expect: {
+ function f() {
+ var o = {};
+ var unused = {};
+ function foo() {
+ with(o)
+ var foo = "something";
+ doSomething(o)
+ }
+ foo()
+ }
+ }
+}
+check_drop_unused_in_peer_function: {
+ options = {
+ unused: true
+ }
+ input: {
+ function outer() {
+ var o = {};
+ var unused = {}; // should be kept
+ function foo() { // should be kept
+ function not_in_use() {
+ var nested_unused = "foo"; // should be dropped
+ return 24;
+ }
+ var unused = {}; // should be kept
+ with (o) {
+ var foo = "something";
+ }
+ doSomething(o);
+ }
+ function bar() {
+ var unused = {}; // should be dropped
+ doSomethingElse();
+ }
+ foo();
+ bar();
+ }
+ }
+ expect: {
+ function outer() {
+ var o = {};
+ var unused = {}; // should be kept
+ function foo() { // should be kept
+ function not_in_use() {
+ return 24;
+ }
+ var unused = {}; // should be kept
+ with (o)
+ var foo = "something";
+ doSomething(o);
+ }
+ function bar() {
+ doSomethingElse();
+ }
+ foo();
+ bar();
+ }
+ }
+}
\ No newline at end of file
--
Alioth's /usr/local/bin/git-commit-notice on /srv/git.debian.org/git/pkg-javascript/uglifyjs.git
More information about the Pkg-javascript-commits
mailing list