+import eBaseImpl
+import enigma
+enigma.eTimer = eBaseImpl.eTimer
+enigma.eSocketNotifier = eBaseImpl.eSocketNotifier
+
+from Tools.Profile import profile, profile_final
+
+profile("PYTHON_START")
+
from enigma import runMainloop, eDVBDB, eTimer, quitMainloop, eDVBVolumecontrol, \
getDesktop, ePythonConfigQuery, eAVSwitch, eWindow, eServiceEvent
from tools import *
+profile("LANGUAGE")
+
from Components.Language import language
def setEPGLanguage():
language.addCallback(setEPGLanguage)
from traceback import print_exc
+profile("LOAD:InfoBar")
import Screens.InfoBar
from Screens.SimpleSummary import SimpleSummary
from sys import stdout, exc_info
+profile("ParentalControl")
from Components.ParentalControl import InitParentalControl
InitParentalControl()
+profile("LOAD:Navigation")
from Navigation import Navigation
+profile("LOAD:skin")
from skin import readSkin, applyAllAttributes
+profile("LOAD:Tools")
from Tools.Directories import InitFallbackFiles, resolveFilename, SCOPE_PLUGINS, SCOPE_SKIN_IMAGE
from Components.config import config, configfile, ConfigText, ConfigSubsection, ConfigInteger
InitFallbackFiles()
+
+profile("ReloadProfiles")
eDVBDB.getInstance().reloadBouquets()
config.misc.radiopic = ConfigText(default = resolveFilename(SCOPE_SKIN_IMAGE)+"radio.mvi")
+profile("Twisted")
try:
import twisted.python.runtime
twisted.python.runtime.platform.supportsThreads = lambda: False
def runReactor():
runMainloop()
+profile("LOAD:Plugin")
+
# initialize autorun plugins and plugin menu entries
from Components.PluginComponent import plugins
+profile("LOAD:Wizard")
from Screens.Wizard import wizardManager
from Screens.ImageWizard import *
from Screens.StartWizard import *
from Tools.BoundFunction import boundFunction
from Plugins.Plugin import PluginDescriptor
+profile("misc")
had = dict()
def dump(dir, p = ""):
class OutputDevice:
def create(self, screen): pass
-# display: HTML
-
-class HTMLOutputDevice(OutputDevice):
- def create(self, comp):
- print comp.produceHTML()
-
-html = HTMLOutputDevice()
-
class GUIOutputDevice(OutputDevice):
parent = None
def create(self, comp, desktop):
comp.createGUIScreen(self.parent, desktop)
+profile("LOAD:ScreenGlobals")
from Screens.Globals import Globals
from Screens.SessionGlobals import SessionGlobals
from Screens.Screen import Screen
+profile("Screen")
Screen.global_screen = Globals()
# Session.open:
self.summary_desktop = summary_desktop
self.nav = navigation
self.delay_timer = eTimer()
- self.delay_timer.timeout.get().append(self.processDelay)
+ self.delay_timer.callback.append(self.processDelay)
self.current_dialog = None
from Screens.Mute import Mute
from GlobalActions import globalActionMap
+profile("VolumeControl")
#TODO .. move this to a own .py file
class VolumeControl:
"""Volume control, handles volUp, volDown, volMute actions and display
self.muteDialog = session.instantiateDialog(Mute)
self.hideVolTimer = eTimer()
- self.hideVolTimer.timeout.get().append(self.volHide)
+ self.hideVolTimer.callback.append(self.volHide)
vol = config.audio.volume.value
self.volumeDialog.setValue(vol)
self.muteDialog.hide()
self.volumeDialog.setValue(vol)
+profile("Standby,PowerKey")
import Screens.Standby
from Screens.Menu import MainMenu, mdom
import xml.dom.minidom
if not Screens.Standby.inStandby and self.session.current_dialog and self.session.current_dialog.ALLOW_SUSPEND:
self.session.open(Screens.Standby.Standby)
+profile("Scart")
from Screens.Scart import Scart
class AutoScartControl:
else:
self.scartDialog.switchToTV()
+profile("Load:CI")
from enigma import eDVBCIInterfaces
+from Screens.Ci import CiHandler
def runScreenTest():
+ profile("readPluginList")
plugins.readPluginList(resolveFilename(SCOPE_PLUGINS))
+ profile("Init:Session")
session = Session(desktop = getDesktop(0), summary_desktop = getDesktop(1), navigation = Navigation())
+ CiHandler.setSession(session)
+
screensToRun = [ ]
for p in plugins.getPlugins(PluginDescriptor.WHERE_WIZARD):
screensToRun.append(p.__call__)
+ profile("wizards")
screensToRun += wizardManager.getWizards()
- screensToRun.append(Screens.InfoBar.InfoBar)
+ screensToRun.append((100, Screens.InfoBar.InfoBar))
+
+ screensToRun.sort()
ePythonConfigQuery.setQueryFunc(configfile.getResolvedKey)
quitMainloop(*result)
return
- screen = screensToRun[0]
+ screen = screensToRun[0][1]
if len(screensToRun):
session.openWithCallback(boundFunction(runNextScreen, session, screensToRun[1:]), screen)
runNextScreen(session, screensToRun)
+ profile("Init:VolumeControl")
vol = VolumeControl(session)
+ profile("Init:PowerKey")
power = PowerKey(session)
# we need session.scart to access it from within menu.xml
session.scart = AutoScartControl(session)
+ profile("RunReactor")
+ profile_final()
runReactor()
-
+ profile("configfile.save")
configfile.save()
+ profile("wakeup")
from time import time
from Tools.DreamboxHardware import setFPWakeuptime
- #get next record timer start time
- nextRecordingTime = session.nav.RecordTimer.getNextRecordingTime()
- #get next zap timer start time
- nextZapTime = session.nav.RecordTimer.getNextZapTime()
#get currentTime
nowTime = time()
- if nextZapTime != -1 and nextRecordingTime != -1:
- startTime = nextZapTime < nextRecordingTime and nextZapTime or nextRecordingTime
- else:
- startTime = nextZapTime != -1 and nextZapTime or nextRecordingTime
- if startTime != -1:
+ wakeupList = [
+ x for x in
+ [session.nav.RecordTimer.getNextRecordingTime(),
+ session.nav.RecordTimer.getNextZapTime(),
+ plugins.getNextWakeupTime()]
+ if x != -1
+ ]
+ wakeupList.sort()
+ if len(wakeupList):
+ startTime = wakeupList.pop(0)
if (startTime - nowTime < 330): # no time to switch box back on
setFPWakeuptime(nowTime + 30) # so switch back on in 30 seconds
else:
setFPWakeuptime(startTime - 300)
+ profile("stopService")
session.nav.stopService()
+ profile("nav shutdown")
session.nav.shutdown()
return 0
+profile("Init:skin")
import skin
skin.loadSkinData(getDesktop(0))
+profile("InputDevice")
import Components.InputDevice
Components.InputDevice.InitInputDevices()
+profile("AVSwitch")
import Components.AVSwitch
Components.AVSwitch.InitAVSwitch()
+profile("RecordingConfig")
import Components.RecordingConfig
Components.RecordingConfig.InitRecordingConfig()
+profile("UsageConfig")
import Components.UsageConfig
Components.UsageConfig.InitUsageConfig()
+profile("keymapparser")
import keymapparser
keymapparser.readKeymap(config.usage.keymap.value)
+profile("Network")
import Components.Network
Components.Network.InitNetwork()
+profile("LCD")
import Components.Lcd
Components.Lcd.InitLcd()
+profile("SetupDevices")
import Components.SetupDevices
Components.SetupDevices.InitSetupDevices()
+profile("RFMod")
import Components.RFmod
Components.RFmod.InitRFmod()
+profile("Init:CI")
import Screens.Ci
Screens.Ci.InitCiConfig()