summaryrefslogtreecommitdiff
path: root/src/nsterm.m
diff options
context:
space:
mode:
authorJan D <jan.h.d@swipnet.se>2014-11-15 19:09:58 +0100
committerJan D <jan.h.d@swipnet.se>2014-11-15 19:09:58 +0100
commit0d9bf9725af8d819709ab775c380cc6cadddc5b5 (patch)
tree00e10219d1c3fee661525ceebd7675a1c843e281 /src/nsterm.m
parent788bc73c80bcd1e748a389692963c1464ba963df (diff)
downloademacs-0d9bf9725af8d819709ab775c380cc6cadddc5b5.tar.gz
Redo the fix, the old takes too much CPU.
Fixes: 18993 * nsterm.m (ns_send_appdefined): Check for application defined event on Cocoa (Bug#18993). (run): Restore code before the previous 18993 fix.
Diffstat (limited to 'src/nsterm.m')
-rw-r--r--src/nsterm.m37
1 files changed, 26 insertions, 11 deletions
diff --git a/src/nsterm.m b/src/nsterm.m
index 539f77e512e..c36b9ed4554 100644
--- a/src/nsterm.m
+++ b/src/nsterm.m
@@ -3377,6 +3377,21 @@ ns_send_appdefined (int value)
/* Only post this event if we haven't already posted one. This will end
the [NXApp run] main loop after having processed all events queued at
this moment. */
+
+#ifdef NS_IMPL_COCOA
+ if (! send_appdefined)
+ {
+ /* OSX 10.10.1 swallows the AppDefined event we are sending ourselves
+ in certain situations (rapid incoming events).
+ So check if we have one, if not add one. */
+ NSEvent *appev = [NSApp nextEventMatchingMask:NSApplicationDefinedMask
+ untilDate:[NSDate distantPast]
+ inMode:NSDefaultRunLoopMode
+ dequeue:NO];
+ if (! appev) send_appdefined = YES;
+ }
+#endif
+
if (send_appdefined)
{
NSEvent *nxev;
@@ -4511,6 +4526,15 @@ ns_term_shutdown (int sig)
#ifdef NS_IMPL_COCOA
- (void)run
{
+#ifndef NSAppKitVersionNumber10_9
+#define NSAppKitVersionNumber10_9 1265
+#endif
+
+ if ((int)NSAppKitVersionNumber != NSAppKitVersionNumber10_9)
+ {
+ [super run];
+ return;
+ }
NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init];
@@ -4523,22 +4547,13 @@ ns_term_shutdown (int sig)
[pool release];
pool = [[NSAutoreleasePool alloc] init];
- /* OSX 10.10.1 swallows the AppDefined event we are sending ourselves
- in certain situations (rapid incoming events).
- The timeout we set with untilDate is necessary to prevent a hang.
- Bug #18993 */
-
NSEvent *event =
[self nextEventMatchingMask:NSAnyEventMask
- untilDate:[NSDate dateWithTimeIntervalSinceNow:0.5]
+ untilDate:[NSDate distantFuture]
inMode:NSDefaultRunLoopMode
dequeue:YES];
- if (event == nil) // timeout
- shouldKeepRunning = NO;
- else
- [self sendEvent:event];
-
+ [self sendEvent:event];
[self updateWindows];
} while (shouldKeepRunning);