Merged branch 'jetty-9.4.x' into 'master'.
This commit is contained in:
commit
7bb0a00ff4
|
@ -117,7 +117,7 @@ public abstract class HTTP2Session extends ContainerLifeCycle implements ISessio
|
||||||
protected void doStop() throws Exception
|
protected void doStop() throws Exception
|
||||||
{
|
{
|
||||||
super.doStop();
|
super.doStop();
|
||||||
close(ErrorCode.NO_ERROR.code, "stop", new Callback.NonBlocking()
|
close(ErrorCode.NO_ERROR.code, "stop", new Callback()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
public void succeeded()
|
public void succeeded()
|
||||||
|
@ -130,6 +130,12 @@ public abstract class HTTP2Session extends ContainerLifeCycle implements ISessio
|
||||||
{
|
{
|
||||||
disconnect();
|
disconnect();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public InvocationType getInvocationType()
|
||||||
|
{
|
||||||
|
return InvocationType.NON_BLOCKING;
|
||||||
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -21,15 +21,21 @@ package org.eclipse.jetty.util.thread;
|
||||||
import java.util.concurrent.Callable;
|
import java.util.concurrent.Callable;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* An object (typically either a {@link Runnable} or {@link Callable}
|
* <p>A task (typically either a {@link Runnable} or {@link Callable}
|
||||||
* that can declare how it will behaive when invoked: blocking, non-blocking
|
* that declares how it will behave when invoked:</p>
|
||||||
* or either.
|
* <ul>
|
||||||
*
|
* <li>blocking, the invocation will certainly block (e.g. performs blocking I/O)</li>
|
||||||
|
* <li>non-blocking, the invocation will certainly <strong>not</strong> block</li>
|
||||||
|
* <li>either, the invocation <em>may</em> block</li>
|
||||||
|
* </ul>
|
||||||
*/
|
*/
|
||||||
public interface Invocable
|
public interface Invocable
|
||||||
{
|
{
|
||||||
enum InvocationType { BLOCKING, NON_BLOCKING, EITHER };
|
enum InvocationType
|
||||||
|
{
|
||||||
|
BLOCKING, NON_BLOCKING, EITHER
|
||||||
|
}
|
||||||
|
|
||||||
static ThreadLocal<Boolean> __nonBlocking = new ThreadLocal<Boolean>()
|
static ThreadLocal<Boolean> __nonBlocking = new ThreadLocal<Boolean>()
|
||||||
{
|
{
|
||||||
@Override
|
@Override
|
||||||
|
@ -38,7 +44,7 @@ public interface Invocable
|
||||||
return Boolean.FALSE;
|
return Boolean.FALSE;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
public static boolean isNonBlockingInvocation()
|
public static boolean isNonBlockingInvocation()
|
||||||
{
|
{
|
||||||
return __nonBlocking.get();
|
return __nonBlocking.get();
|
||||||
|
@ -58,34 +64,16 @@ public interface Invocable
|
||||||
__nonBlocking.set(was_non_blocking);
|
__nonBlocking.set(was_non_blocking);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void invokeOnlyNonBlocking(Runnable task)
|
|
||||||
{
|
|
||||||
switch(getInvocationType(task))
|
|
||||||
{
|
|
||||||
case BLOCKING:
|
|
||||||
throw new IllegalArgumentException("Cannot invoke nonblocking: "+task);
|
|
||||||
|
|
||||||
case NON_BLOCKING:
|
|
||||||
task.run();
|
|
||||||
break;
|
|
||||||
|
|
||||||
case EITHER:
|
|
||||||
// a Choice exists, so we must indicate NonBlocking
|
|
||||||
invokeNonBlocking(task);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void invokePreferNonBlocking(Runnable task)
|
public static void invokePreferNonBlocking(Runnable task)
|
||||||
{
|
{
|
||||||
switch(getInvocationType(task))
|
switch (getInvocationType(task))
|
||||||
{
|
{
|
||||||
case BLOCKING:
|
case BLOCKING:
|
||||||
case NON_BLOCKING:
|
case NON_BLOCKING:
|
||||||
task.run();
|
task.run();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case EITHER:
|
case EITHER:
|
||||||
// a Choice exists, so we must indicate NonBlocking
|
// a Choice exists, so we must indicate NonBlocking
|
||||||
invokeNonBlocking(task);
|
invokeNonBlocking(task);
|
||||||
|
@ -95,66 +83,48 @@ public interface Invocable
|
||||||
|
|
||||||
public static void invokePreferred(Runnable task, InvocationType preferredInvocationType)
|
public static void invokePreferred(Runnable task, InvocationType preferredInvocationType)
|
||||||
{
|
{
|
||||||
switch(getInvocationType(task))
|
switch (getInvocationType(task))
|
||||||
{
|
{
|
||||||
case BLOCKING:
|
case BLOCKING:
|
||||||
case NON_BLOCKING:
|
case NON_BLOCKING:
|
||||||
task.run();
|
task.run();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case EITHER:
|
case EITHER:
|
||||||
if (getInvocationType(task)==InvocationType.EITHER && preferredInvocationType==InvocationType.NON_BLOCKING)
|
if (getInvocationType(task) == InvocationType.EITHER && preferredInvocationType == InvocationType.NON_BLOCKING)
|
||||||
invokeNonBlocking(task);
|
invokeNonBlocking(task);
|
||||||
else
|
else
|
||||||
task.run();
|
task.run();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Runnable asPreferred(Runnable task, InvocationType preferredInvocationType)
|
public static Runnable asPreferred(Runnable task, InvocationType preferredInvocationType)
|
||||||
{
|
{
|
||||||
switch(getInvocationType(task))
|
switch (getInvocationType(task))
|
||||||
{
|
{
|
||||||
case BLOCKING:
|
case BLOCKING:
|
||||||
case NON_BLOCKING:
|
case NON_BLOCKING:
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case EITHER:
|
case EITHER:
|
||||||
if (getInvocationType(task)==InvocationType.EITHER && preferredInvocationType==InvocationType.NON_BLOCKING)
|
if (getInvocationType(task) == InvocationType.EITHER && preferredInvocationType == InvocationType.NON_BLOCKING)
|
||||||
return new Runnable()
|
return () -> invokeNonBlocking(task);
|
||||||
{
|
|
||||||
@Override
|
|
||||||
public void run()
|
|
||||||
{
|
|
||||||
invokeNonBlocking(task);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
return task;
|
return task;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public static void invokePreferBlocking(Runnable task)
|
|
||||||
{
|
|
||||||
task.run();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public static InvocationType getInvocationType(Object o)
|
public static InvocationType getInvocationType(Object o)
|
||||||
{
|
{
|
||||||
if (o instanceof Invocable)
|
if (o instanceof Invocable)
|
||||||
return ((Invocable)o).getInvocationType();
|
return ((Invocable)o).getInvocationType();
|
||||||
return InvocationType.BLOCKING;
|
return InvocationType.BLOCKING;
|
||||||
}
|
}
|
||||||
|
|
||||||
default InvocationType getInvocationType()
|
default InvocationType getInvocationType()
|
||||||
{
|
{
|
||||||
return InvocationType.BLOCKING;
|
return InvocationType.BLOCKING;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue