mirror of
https://github.com/Ryujinx/Opentk.git
synced 2025-01-23 16:31:10 +00:00
Merge pull request #178 from thefiddler/mac_crash
[Mac] Avoid crash when combining with MonoMac/Xamarin.Mac
This commit is contained in:
commit
d6d6842730
|
@ -39,7 +39,6 @@ namespace OpenTK.Platform.MacOS
|
|||
static class NSApplication
|
||||
{
|
||||
internal static IntPtr Handle;
|
||||
internal static IntPtr AutoreleasePool;
|
||||
|
||||
static readonly IntPtr selQuit = Selector.Get("quit");
|
||||
|
||||
|
@ -52,9 +51,6 @@ namespace OpenTK.Platform.MacOS
|
|||
{
|
||||
Cocoa.Initialize();
|
||||
|
||||
// Create the NSAutoreleasePool
|
||||
AutoreleasePool = Cocoa.SendIntPtr(Cocoa.SendIntPtr(Class.NSAutoreleasePool, Selector.Alloc), Selector.Init);
|
||||
|
||||
// Register a Quit method to be called on cmd-q
|
||||
IntPtr nsapp = Class.Get("NSApplication");
|
||||
Class.RegisterMethod(nsapp, OnQuitHandler, "quit", "v@:");
|
||||
|
@ -66,6 +62,8 @@ namespace OpenTK.Platform.MacOS
|
|||
Cocoa.SendBool(Handle, Selector.Get("setActivationPolicy:"), (int)NSApplicationActivationPolicy.Regular);
|
||||
Cocoa.SendVoid(Handle, Selector.Get("activateIgnoringOtherApps:"), true);
|
||||
|
||||
if (Cocoa.SendIntPtr(Handle, Selector.Get("mainMenu")) == IntPtr.Zero)
|
||||
{
|
||||
// Create the menu bar
|
||||
var menubar = Cocoa.SendIntPtr(Class.Get("NSMenu"), Selector.Alloc);
|
||||
var menuItem = Cocoa.SendIntPtr(Class.Get("NSMenuItem"), Selector.Alloc);
|
||||
|
@ -83,7 +81,11 @@ namespace OpenTK.Platform.MacOS
|
|||
Cocoa.SendIntPtr(menuItem, Selector.Get("setSubmenu:"), appMenu);
|
||||
|
||||
// Tell cocoa we're ready to run the application (usually called by [NSApp run]).
|
||||
// Note: if a main menu exists, then this method has already been called and
|
||||
// calling it again will result in a crash. For this reason, we only call it
|
||||
// when we create our own main menu.
|
||||
Cocoa.SendVoid(Handle, Selector.Get("finishLaunching"));
|
||||
}
|
||||
|
||||
// Disable momentum scrolling and long-press key pop-ups
|
||||
IntPtr settings = Cocoa.SendIntPtr(Class.NSDictionary, Selector.Alloc);
|
||||
|
|
Loading…
Reference in a new issue