From b70f0fdf15615e5ee735525e8eed32a4cf4ca718 Mon Sep 17 00:00:00 2001
From: Grzegorz Grzybek
Date: Fri, 26 Aug 2016 10:44:23 +0200
Subject: [PATCH] Issue #868 - Use static Throwables without
backtrace/stackTrace
Signed-off-by: Grzegorz Grzybek
---
.../continuation/ContinuationThrowable.java | 7 ++-
.../eclipse/jetty/util/BlockingCallback.java | 6 +--
.../eclipse/jetty/util/ConstantThrowable.java | 43 +++++++++++++++++++
.../eclipse/jetty/util/FutureCallback.java | 2 +-
.../org/eclipse/jetty/util/FuturePromise.java | 2 +-
.../jetty/util/SharedBlockingCallback.java | 31 +++----------
6 files changed, 57 insertions(+), 34 deletions(-)
create mode 100644 jetty-util/src/main/java/org/eclipse/jetty/util/ConstantThrowable.java
diff --git a/jetty-continuation/src/main/java/org/eclipse/jetty/continuation/ContinuationThrowable.java b/jetty-continuation/src/main/java/org/eclipse/jetty/continuation/ContinuationThrowable.java
index e32717cabec..a6be363f136 100644
--- a/jetty-continuation/src/main/java/org/eclipse/jetty/continuation/ContinuationThrowable.java
+++ b/jetty-continuation/src/main/java/org/eclipse/jetty/continuation/ContinuationThrowable.java
@@ -43,4 +43,9 @@ package org.eclipse.jetty.continuation;
*
*/
public class ContinuationThrowable extends Error
-{}
+{
+ public ContinuationThrowable()
+ {
+ super(null, null, false, false);
+ }
+}
diff --git a/jetty-util/src/main/java/org/eclipse/jetty/util/BlockingCallback.java b/jetty-util/src/main/java/org/eclipse/jetty/util/BlockingCallback.java
index 8601d8e9d16..74b77ffff9e 100644
--- a/jetty-util/src/main/java/org/eclipse/jetty/util/BlockingCallback.java
+++ b/jetty-util/src/main/java/org/eclipse/jetty/util/BlockingCallback.java
@@ -36,11 +36,7 @@ public class BlockingCallback implements Callback
{
private static final Logger LOG = Log.getLogger(BlockingCallback.class);
- private static Throwable SUCCEEDED=new Throwable()
- {
- @Override
- public String toString() { return "SUCCEEDED"; }
- };
+ private static Throwable SUCCEEDED = new ConstantThrowable("SUCCEEDED");
private final CountDownLatch _latch = new CountDownLatch(1);
private final AtomicReference _state = new AtomicReference<>();
diff --git a/jetty-util/src/main/java/org/eclipse/jetty/util/ConstantThrowable.java b/jetty-util/src/main/java/org/eclipse/jetty/util/ConstantThrowable.java
new file mode 100644
index 00000000000..b368c90f909
--- /dev/null
+++ b/jetty-util/src/main/java/org/eclipse/jetty/util/ConstantThrowable.java
@@ -0,0 +1,43 @@
+//
+// ========================================================================
+// Copyright (c) 1995-2016 Mort Bay Consulting Pty. Ltd.
+// ------------------------------------------------------------------------
+// All rights reserved. This program and the accompanying materials
+// are made available under the terms of the Eclipse Public License v1.0
+// and Apache License v2.0 which accompanies this distribution.
+//
+// The Eclipse Public License is available at
+// http://www.eclipse.org/legal/epl-v10.html
+//
+// The Apache License v2.0 is available at
+// http://www.opensource.org/licenses/apache2.0.php
+//
+// You may elect to redistribute this code under either of these licenses.
+// ========================================================================
+//
+
+package org.eclipse.jetty.util;
+
+/**
+ * A {@link Throwable} that may be used in static contexts. It uses Java 7
+ * constructor that prevents setting stackTrace inside exception object.
+ */
+public class ConstantThrowable extends Throwable {
+
+ private String name;
+
+ public ConstantThrowable() {
+ this(null);
+ }
+
+ public ConstantThrowable(String name) {
+ super(null, null, false, false);
+ this.name = name;
+ }
+
+ @Override
+ public String toString() {
+ return name;
+ }
+
+}
diff --git a/jetty-util/src/main/java/org/eclipse/jetty/util/FutureCallback.java b/jetty-util/src/main/java/org/eclipse/jetty/util/FutureCallback.java
index 247535cb284..72ea4828a53 100644
--- a/jetty-util/src/main/java/org/eclipse/jetty/util/FutureCallback.java
+++ b/jetty-util/src/main/java/org/eclipse/jetty/util/FutureCallback.java
@@ -29,7 +29,7 @@ import java.util.concurrent.atomic.AtomicBoolean;
public class FutureCallback implements Future,Callback
{
- private static Throwable COMPLETED=new Throwable();
+ private static Throwable COMPLETED=new ConstantThrowable();
private final AtomicBoolean _done=new AtomicBoolean(false);
private final CountDownLatch _latch=new CountDownLatch(1);
private Throwable _cause;
diff --git a/jetty-util/src/main/java/org/eclipse/jetty/util/FuturePromise.java b/jetty-util/src/main/java/org/eclipse/jetty/util/FuturePromise.java
index 09a770b2a0a..a471407f86c 100644
--- a/jetty-util/src/main/java/org/eclipse/jetty/util/FuturePromise.java
+++ b/jetty-util/src/main/java/org/eclipse/jetty/util/FuturePromise.java
@@ -29,7 +29,7 @@ import java.util.concurrent.atomic.AtomicBoolean;
public class FuturePromise implements Future,Promise
{
- private static Throwable COMPLETED=new Throwable();
+ private static Throwable COMPLETED=new ConstantThrowable();
private final AtomicBoolean _done=new AtomicBoolean(false);
private final CountDownLatch _latch=new CountDownLatch(1);
private Throwable _cause;
diff --git a/jetty-util/src/main/java/org/eclipse/jetty/util/SharedBlockingCallback.java b/jetty-util/src/main/java/org/eclipse/jetty/util/SharedBlockingCallback.java
index 5b4e5a312eb..feebed87dcd 100644
--- a/jetty-util/src/main/java/org/eclipse/jetty/util/SharedBlockingCallback.java
+++ b/jetty-util/src/main/java/org/eclipse/jetty/util/SharedBlockingCallback.java
@@ -54,33 +54,12 @@ public class SharedBlockingCallback
final Condition _idle = _lock.newCondition();
final Condition _complete = _lock.newCondition();
-
- private static Throwable IDLE = new Throwable()
- {
- @Override
- public String toString()
- {
- return "IDLE";
- }
- };
- private static Throwable SUCCEEDED = new Throwable()
- {
- @Override
- public String toString()
- {
- return "SUCCEEDED";
- }
- };
-
- private static Throwable FAILED = new Throwable()
- {
- @Override
- public String toString()
- {
- return "FAILED";
- }
- };
+ private static Throwable IDLE = new ConstantThrowable("IDLE");
+
+ private static Throwable SUCCEEDED = new ConstantThrowable("SUCCEEDED");
+
+ private static Throwable FAILED = new ConstantThrowable("FAILED");
Blocker _blocker;