Fix invokeExact(...) usage in JdkAlpnSslUtils (#10471)
Motivation: fd0d06e introduced the usage of MethodHandles and so also introduced some usages of invokeExact(...). Unfortunally when calling this method we missed to also cast the return value in the static init block of JdkAlpnSslUtils which lead to an exception to be thrown as the JVM did assume the return value is void which is not true. Modifications: Correctly cast the return value of invokeExact(...) Result: ALPN can be used in master with JDK again
This commit is contained in:
parent
1208f27070
commit
6aa30b2b6e
@ -56,12 +56,14 @@ final class JdkAlpnSslUtils {
|
||||
AccessController.doPrivileged((PrivilegedExceptionAction<MethodHandle>) () ->
|
||||
lookup.findVirtual(SSLEngine.class, "getHandshakeApplicationProtocol",
|
||||
MethodType.methodType(String.class)));
|
||||
getHandshakeApplicationProtocol.invokeExact(engine);
|
||||
// Invoke and specify the return type so the compiler doesnt try to use void
|
||||
String getHandshakeApplicationProtocolRes = (String) getHandshakeApplicationProtocol.invokeExact(engine);
|
||||
|
||||
getApplicationProtocol = AccessController.doPrivileged((PrivilegedExceptionAction<MethodHandle>) () ->
|
||||
lookup.findVirtual(SSLEngine.class, "getApplicationProtocol",
|
||||
MethodType.methodType(String.class)));
|
||||
getApplicationProtocol.invokeExact(engine);
|
||||
// Invoke and specify the return type so the compiler doesnt try to use void
|
||||
String getApplicationProtocolRes = (String) getApplicationProtocol.invokeExact(engine);
|
||||
|
||||
setApplicationProtocols = AccessController.doPrivileged((PrivilegedExceptionAction<MethodHandle>) () ->
|
||||
lookup.findVirtual(SSLParameters.class, "setApplicationProtocols",
|
||||
@ -79,6 +81,10 @@ final class JdkAlpnSslUtils {
|
||||
AccessController.doPrivileged((PrivilegedExceptionAction<MethodHandle>) () ->
|
||||
lookup.findVirtual(SSLEngine.class, "getHandshakeApplicationProtocolSelector",
|
||||
MethodType.methodType(BiFunction.class)));
|
||||
// Invoke and specify the return type so the compiler doesnt try to use void
|
||||
@SuppressWarnings("unchecked")
|
||||
BiFunction<SSLEngine, List<String>, String> getHandshakeApplicationProtocolSelectorRes =
|
||||
(BiFunction<SSLEngine, List<String>, String>)
|
||||
getHandshakeApplicationProtocolSelector.invokeExact(engine);
|
||||
} catch (Throwable t) {
|
||||
int version = PlatformDependent.javaVersion();
|
||||
|
Loading…
x
Reference in New Issue
Block a user