-from Tools import RedirectOutput, RedirectTime
+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
-import ServiceReference
-
+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 e2reactor
- e2reactor.install()
-
import twisted.python.runtime
twisted.python.runtime.platform.supportsThreads = lambda: False
+ import e2reactor
+ e2reactor.install()
+
from twisted.internet import reactor
def runReactor():
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:
# * push current active dialog ('current_dialog') onto stack
# * call execEnd for this dialog
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
self.in_exec = False
+ self.screen = SessionGlobals(self)
+
for p in plugins.getPlugins(PluginDescriptor.WHERE_SESSIONSTART):
p(reason=0, session=self)
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
class PowerKey:
""" PowerKey stuff - handles the powerkey press and powerkey release actions"""
def __init__(self, session):
self.session = session
- self.powerKeyTimer = eTimer()
- self.powerKeyTimer.timeout.get().append(self.powertimer)
- globalActionMap.actions["powerdown"]=self.powerdown
- globalActionMap.actions["powerup"]=self.powerup
+ globalActionMap.actions["power_down"]=self.powerdown
+ globalActionMap.actions["power_up"]=self.powerup
+ globalActionMap.actions["power_long"]=self.powerlong
+ globalActionMap.actions["deepstandby"]=self.shutdown # frontpanel long power button press
self.standbyblocked = 1
-# self["PowerKeyActions"] = HelpableActionMap(self, "PowerKeyActions",
- #{
- #"powerdown": self.powerdown,
- #"powerup": self.powerup,
- #"discreteStandby": (self.standby, "Go standby"),
- #"discretePowerOff": (self.quit, "Go to deep standby"),
- #})
-
- def powertimer(self):
+
+ def MenuClosed(self, *val):
+ self.session.infobar = None
+
+ def shutdown(self):
print "PowerOff - Now!"
- if not Screens.Standby.inTryQuitMainloop:
+ if not Screens.Standby.inTryQuitMainloop and self.session.current_dialog and self.session.current_dialog.ALLOW_SUSPEND:
self.session.open(Screens.Standby.TryQuitMainloop, 1)
+ def powerlong(self):
+ self.standbyblocked = 1
+ action = config.usage.on_long_powerpress.value
+ if action == "shutdown":
+ self.shutdown()
+ elif action == "show_menu":
+ print "Show shutdown Menu"
+ menu = mdom.childNodes[0]
+ for x in menu.childNodes:
+ if x.nodeType != xml.dom.minidom.Element.nodeType:
+ continue
+ elif x.tagName == 'menu':
+ for y in x.childNodes:
+ if y.nodeType != xml.dom.minidom.Element.nodeType:
+ continue
+ elif y.tagName == 'id':
+ id = y.getAttribute("val")
+ if id and id == "shutdown":
+ self.session.infobar = self
+ menu_screen = self.session.openWithCallback(self.MenuClosed, MainMenu, x, x.childNodes)
+ menu_screen.setTitle(_("Standby / Restart"))
+ return
+
def powerdown(self):
self.standbyblocked = 0
- self.powerKeyTimer.start(3000, True)
def powerup(self):
- self.powerKeyTimer.stop()
if self.standbyblocked == 0:
self.standbyblocked = 1
self.standby()
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
-import keymapparser
-keymapparser.readKeymap()
+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()
-import Components.NimManager
-
+profile("Init:CI")
import Screens.Ci
Screens.Ci.InitCiConfig()