From 0474d73c97398a012d978e6b655375ce6d4cff2e Mon Sep 17 00:00:00 2001 From: Reinhard Pointner Date: Sat, 14 Nov 2015 15:47:20 +0000 Subject: [PATCH] * use autoReleasePool as per example: https://gist.github.com/shannah/65007754c2b0f8add4f7 --- source/net/filebot/mac/MacAppUtilities.java | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/source/net/filebot/mac/MacAppUtilities.java b/source/net/filebot/mac/MacAppUtilities.java index 9ebfb0fe..b7ecdc5e 100644 --- a/source/net/filebot/mac/MacAppUtilities.java +++ b/source/net/filebot/mac/MacAppUtilities.java @@ -20,6 +20,8 @@ import javax.swing.UIManager; import ca.weblite.objc.Client; import ca.weblite.objc.Proxy; +import com.sun.jna.Pointer; + public class MacAppUtilities { private static Client _objc; @@ -52,9 +54,11 @@ public class MacAppUtilities { // WARNING: dispatch_sync seems to work on most Mac always causes a deadlock and freezes the application on others (in particular MBP with 2 graphics chips) dispatch_async(new Runnable() { - @Override public void run() { + Pointer pool = createAutoreleasePool(); Proxy peer = objc().sendProxy("NSOpenPanel", "openPanel"); + peer.send("retain"); + peer.send("setTitle:", title); peer.send("setAllowsMultipleSelection:", multipleMode ? 1 : 0); peer.send("setCanChooseDirectories:", canChooseDirectories ? 1 : 0); @@ -78,6 +82,7 @@ public class MacAppUtilities { } } + drainAutoreleasePool(pool); secondaryLoop.exit(); } });