This commit is contained in:
@@ -153,7 +153,9 @@ public class SocksRunner implements Runnable {
|
|||||||
new StreamCompletionHandler(remoteChannel, channel).completed(0, null);
|
new StreamCompletionHandler(remoteChannel, channel).completed(0, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
public synchronized void closeRunner(final Throwable e) {
|
public void closeRunner(final Throwable e) {
|
||||||
|
if (closed) return;
|
||||||
|
synchronized (this) {
|
||||||
if (closed) return;
|
if (closed) return;
|
||||||
closed = true;
|
closed = true;
|
||||||
try {
|
try {
|
||||||
@@ -166,6 +168,7 @@ public class SocksRunner implements Runnable {
|
|||||||
logger.log(Level.FINEST, "close socks channel by error", e);
|
logger.log(Level.FINEST, "close socks channel by error", e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private class StreamCompletionHandler implements CompletionHandler<Integer, Void> {
|
private class StreamCompletionHandler implements CompletionHandler<Integer, Void> {
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user