diff options
author | Sven Gothel <[email protected]> | 2019-09-08 12:56:57 +0200 |
---|---|---|
committer | Sven Gothel <[email protected]> | 2019-09-08 12:56:57 +0200 |
commit | 534d764474cacf8bc380123cbfd164c7c55f236a (patch) | |
tree | f87a883e0962df6a8e6d9270967527fba943e37c /src/nativewindow/classes/com | |
parent | 125e4bd1c8e0a8f4b434209b155e6cd0d8f09092 (diff) |
Buig 1389: Fix SIGSEGV on OpenJDK11 on [NSApplicationAWT sendEvent:]
Culprit of the crash and the non propagated action on NSApp main-thread
was _simply_ our OSXUtil_KickNSApp() 'kick alive'
NSApplicationDefined NSEvent sent to the NSApp.
Java11's NSApp code overrides sendEvent and handles
NSApplicationDefined + subtype=ExecuteBlockEvent
using the given data1 as a function pointer. 8-O
ExecuteBlockEvent defined as 0, which we have sent.
Simply passing subtype=8888 avoids this side-effect.
Whether it is still required to KickNSApp() is another question.
+++
Further, make code a bit more robuts regarding the offscreenSurfaceLayer
at JAWTWindow invalidate. I.e. if still not detached, do the late cleanup there.
This just in case the OSX Context callback to disassociate the drawable
has been missed.
Diffstat (limited to 'src/nativewindow/classes/com')
-rw-r--r-- | src/nativewindow/classes/com/jogamp/nativewindow/awt/JAWTWindow.java | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/src/nativewindow/classes/com/jogamp/nativewindow/awt/JAWTWindow.java b/src/nativewindow/classes/com/jogamp/nativewindow/awt/JAWTWindow.java index 71a7602e6..5b8171e96 100644 --- a/src/nativewindow/classes/com/jogamp/nativewindow/awt/JAWTWindow.java +++ b/src/nativewindow/classes/com/jogamp/nativewindow/awt/JAWTWindow.java @@ -270,6 +270,7 @@ public abstract class JAWTWindow implements NativeWindow, OffscreenLayerSurface, invalidateNative(); jawt = null; awtConfig = null; + offscreenSurfaceLayer = 0; // Bug 1389 isOffscreenLayerSurface = false; drawable= 0; drawable_old = 0; @@ -534,7 +535,7 @@ public abstract class JAWTWindow implements NativeWindow, OffscreenLayerSurface, throw new NativeWindowException("No offscreen layer attached: "+this); } if(DEBUG) { - System.err.println("JAWTWindow.detachSurfaceHandle(): osh "+toHexString(offscreenSurfaceLayer)); + System.err.println("JAWTWindow.detachSurfaceHandle(): osh "+toHexString(offscreenSurfaceLayer)+" - "+Thread.currentThread().getName()); } detachSurfaceLayerImpl(offscreenSurfaceLayer, detachSurfaceLayerNotify); } |