|
@@ -10,12 +10,16 @@ from direct.directnotify.DirectNotifyGlobal import *
|
|
|
from direct.showbase import ExceptionVarDump
|
|
from direct.showbase import ExceptionVarDump
|
|
|
from direct.showbase.PythonUtil import *
|
|
from direct.showbase.PythonUtil import *
|
|
|
from direct.showbase.MessengerGlobal import messenger
|
|
from direct.showbase.MessengerGlobal import messenger
|
|
|
-import signal
|
|
|
|
|
import types
|
|
import types
|
|
|
import time
|
|
import time
|
|
|
import random
|
|
import random
|
|
|
import string
|
|
import string
|
|
|
|
|
|
|
|
|
|
+try:
|
|
|
|
|
+ import signal
|
|
|
|
|
+except ImportError:
|
|
|
|
|
+ signal = None
|
|
|
|
|
+
|
|
|
from panda3d.core import *
|
|
from panda3d.core import *
|
|
|
|
|
|
|
|
def print_exc_plus():
|
|
def print_exc_plus():
|
|
@@ -149,7 +153,8 @@ class TaskManager:
|
|
|
def invokeDefaultHandler(self, signalNumber, stackFrame):
|
|
def invokeDefaultHandler(self, signalNumber, stackFrame):
|
|
|
print '*** allowing mid-frame keyboard interrupt.'
|
|
print '*** allowing mid-frame keyboard interrupt.'
|
|
|
# Restore default interrupt handler
|
|
# Restore default interrupt handler
|
|
|
- signal.signal(signal.SIGINT, signal.default_int_handler)
|
|
|
|
|
|
|
+ if signal:
|
|
|
|
|
+ signal.signal(signal.SIGINT, signal.default_int_handler)
|
|
|
# and invoke it
|
|
# and invoke it
|
|
|
raise KeyboardInterrupt
|
|
raise KeyboardInterrupt
|
|
|
|
|
|
|
@@ -454,7 +459,8 @@ class TaskManager:
|
|
|
# after task list processing is complete.
|
|
# after task list processing is complete.
|
|
|
self.fKeyboardInterrupt = 0
|
|
self.fKeyboardInterrupt = 0
|
|
|
self.interruptCount = 0
|
|
self.interruptCount = 0
|
|
|
- signal.signal(signal.SIGINT, self.keyboardInterruptHandler)
|
|
|
|
|
|
|
+ if signal:
|
|
|
|
|
+ signal.signal(signal.SIGINT, self.keyboardInterruptHandler)
|
|
|
|
|
|
|
|
startFrameTime = self.globalClock.getRealTime()
|
|
startFrameTime = self.globalClock.getRealTime()
|
|
|
|
|
|
|
@@ -465,7 +471,8 @@ class TaskManager:
|
|
|
self.doYield(startFrameTime, nextTaskTime)
|
|
self.doYield(startFrameTime, nextTaskTime)
|
|
|
|
|
|
|
|
# Restore default interrupt handler
|
|
# Restore default interrupt handler
|
|
|
- signal.signal(signal.SIGINT, signal.default_int_handler)
|
|
|
|
|
|
|
+ if signal:
|
|
|
|
|
+ signal.signal(signal.SIGINT, signal.default_int_handler)
|
|
|
if self.fKeyboardInterrupt:
|
|
if self.fKeyboardInterrupt:
|
|
|
raise KeyboardInterrupt
|
|
raise KeyboardInterrupt
|
|
|
|
|
|