X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/2e8b8c758c9b9544d0771c06ca91b228bf1147bf..a9e03c73e9b7c9e2bda1418bde9f81dc056f34f8:/lib/python/Plugins/Extensions/MediaScanner/plugin.py diff --git a/lib/python/Plugins/Extensions/MediaScanner/plugin.py b/lib/python/Plugins/Extensions/MediaScanner/plugin.py index 4b2b9370..c5f6043e 100644 --- a/lib/python/Plugins/Extensions/MediaScanner/plugin.py +++ b/lib/python/Plugins/Extensions/MediaScanner/plugin.py @@ -22,6 +22,8 @@ def mountpoint_choosen(option): if list == [ ]: print "nothing found" + from Screens.MessageBox import MessageBox + session.open(MessageBox, "No displayable files on this medium found!", MessageBox.TYPE_ERROR) return session.openWithCallback(execute, ChoiceBox, @@ -43,14 +45,41 @@ def main(session, **kwargs): def menuEntry(*args): mountpoint_choosen(args) +from Components.Harddisk import harddiskmanager + def menuHook(menuid): if menuid != "mainmenu": return [ ] - from Components.Harddisk import harddiskmanager from Tools.BoundFunction import boundFunction - return [(_("Show files from %s") % r.description, boundFunction(menuEntry, r.description, r.mountpoint), "hotplug", None) for r in harddiskmanager.getMountedPartitions(onlyhotplug = True)] + return [(("%s (files)") % r.description, boundFunction(menuEntry, r.description, r.mountpoint), "hotplug_%s" % r.mountpoint, None) for r in harddiskmanager.getMountedPartitions(onlyhotplug = True)] + +global_session = None + +def partitionListChanged(action, device): + pass +# if action == 'add' and device.is_hotplug: +# print "mountpoint", device.mountpoint +# print "description", device.description +# print "force_mounted", device.force_mounted +# mountpoint_choosen((device.description, device.mountpoint, global_session)) + +def sessionstart(reason, session): + global global_session + global_session = session + +def autostart(reason, **kwargs): + global global_session + if reason == 0: + harddiskmanager.on_partition_list_change.append(partitionListChanged) + elif reason == 1: + harddiskmanager.on_partition_list_change.remove(partitionListChanged) + global_session = None def Plugins(**kwargs): - return [ PluginDescriptor(name="MediaScanner", description="Scan Files...", where = PluginDescriptor.WHERE_PLUGINMENU, fnc=main), - PluginDescriptor(where = PluginDescriptor.WHERE_MENU, fnc=menuHook)] + return [ + PluginDescriptor(name="MediaScanner", description="Scan Files...", where = PluginDescriptor.WHERE_PLUGINMENU, fnc=main), +# PluginDescriptor(where = PluginDescriptor.WHERE_MENU, fnc=menuHook), + PluginDescriptor(where = PluginDescriptor.WHERE_SESSIONSTART, fnc = sessionstart), + PluginDescriptor(where = PluginDescriptor.WHERE_AUTOSTART, fnc = autostart) + ]