from skin import readSkin, applyAllAttributes
from Components.config import configfile
-from Tools.Directories import InitFallbackFiles
+from Tools.Directories import InitFallbackFiles, resolveFilename, SCOPE_PLUGINS
InitFallbackFiles()
eDVBDB.getInstance().reloadBouquets()
# initialize autorun plugins and plugin menu entries
from Components.PluginComponent import plugins
-plugins.readPluginList()
+plugins.readPluginList(resolveFilename(SCOPE_PLUGINS))
from Screens.Wizard import wizardManager
from Screens.StartWizard import *
self.currentDialog.execEnd()
self.currentDialog.hide()
- def create(self, screen, arguments):
+ def create(self, screen, arguments, **kwargs):
# creates an instance of 'screen' (which is a class)
try:
- return screen(self, *arguments)
+ return screen(self, *arguments, **kwargs)
except:
- errstr = "Screen %s(%s): %s" % (str(screen), str(arguments), sys.exc_info()[0])
+ errstr = "Screen %s(%s, %s): %s" % (str(screen), str(arguments), str(kwargs), sys.exc_info()[0])
print errstr
traceback.print_exc(file=sys.stdout)
quitMainloop(5)
- def instantiateDialog(self, screen, *arguments):
+ def instantiateDialog(self, screen, *arguments, **kwargs):
# create dialog
try:
- dlg = self.create(screen, arguments)
+ dlg = self.create(screen, arguments, **kwargs)
except:
print 'EXCEPTION IN DIALOG INIT CODE, ABORTING:'
print '-'*60
self.currentDialog.callback = None # would cause re-entrancy problems.
self.execBegin()
- def openWithCallback(self, callback, screen, *arguments):
- dlg = self.open(screen, *arguments)
+ def openWithCallback(self, callback, screen, *arguments, **kwargs):
+ dlg = self.open(screen, *arguments, **kwargs)
dlg.callback = callback
- def open(self, screen, *arguments):
+ def open(self, screen, *arguments, **kwargs):
self.pushCurrent()
- dlg = self.currentDialog = self.instantiateDialog(screen, *arguments)
+ dlg = self.currentDialog = self.instantiateDialog(screen, *arguments, **kwargs)
dlg.isTmp = True
dlg.callback = None
self.execBegin()
configfile.save()
+ from Tools.DreamboxHardware import setFPWakeuptime
+ from time import time
+ nextRecordingTime = session.nav.RecordTimer.getNextRecordingTime()
+ if nextRecordingTime != -1:
+ if (nextRecordingTime < 330): # no time to switch box back on
+ setFPWakeuptime(time() + 30) # so switch back on in 30 seconds
+ else:
+ setFPWakeuptime(nextRecordingTime - (300))
+
session.nav.shutdown()
return 0
# first, setup a screen
try:
runScreenTest()
+
plugins.shutdown()
except:
print 'EXCEPTION IN PYTHON STARTUP CODE:'