X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/53f199c5a82bcd460d3153814f2e057c747e2a3a..0f2685f4c5daa1ced4fc9454ddb467e1396bcb91:/lib/python/Plugins/Extensions/DVDBurn/DVDProject.py diff --git a/lib/python/Plugins/Extensions/DVDBurn/DVDProject.py b/lib/python/Plugins/Extensions/DVDBurn/DVDProject.py index e7876e41..112a221e 100644 --- a/lib/python/Plugins/Extensions/DVDBurn/DVDProject.py +++ b/lib/python/Plugins/Extensions/DVDBurn/DVDProject.py @@ -1,20 +1,133 @@ +from Tools.Directories import fileExists +from Components.config import config, ConfigSubsection, ConfigInteger, ConfigText, ConfigSelection, getConfigListEntry, ConfigSequence + +class ConfigColor(ConfigSequence): + def __init__(self): + ConfigSequence.__init__(self, seperator = "#", limits = [(0,255),(0,255),(0,255)]) + +class ConfigPixelvals(ConfigSequence): + def __init__(self): + ConfigSequence.__init__(self, seperator = ",", limits = [(0,200),(0,200),(0,200)]) + +class ConfigPixelvals(ConfigSequence): + def __init__(self): + ConfigSequence.__init__(self, seperator = ",", limits = [(0,200),(0,200),(0,200)]) + +class ConfigFilename(ConfigText): + def __init__(self): + ConfigText.__init__(self, default = "", fixed_size = True, visible_width = False) + + def getMulti(self, selected): + filename = (self.text.rstrip("/").rsplit("/",1))[1].encode("utf-8")[:40] + " " + if self.allmarked: + mark = range(0, len(filename)) + else: + mark = [filename] + return ("mtext"[1-selected:], filename, mark) + class DVDProject: def __init__(self): self.titles = [ ] self.target = None - self.name = _("New DVD") + self.settings = ConfigSubsection() + self.settings.name = ConfigText(fixed_size = False, visible_width = 40) + self.settings.authormode = ConfigSelection(choices = [("menu_linked", _("Linked titles with a DVD menu")), ("just_linked", _("Direct playback of linked titles without menu")), ("menu_seperate", _("Seperate titles with a main menu")), ("data_ts", _("Dreambox format data DVD (HDTV compatible)"))]) + self.settings.titlesetmode = ConfigSelection(choices = [("single", _("Simple titleset (compatibility for legacy players)")), ("multi", _("Complex (allows mixing audio tracks and aspects)"))], default="multi") + self.settings.output = ConfigSelection(choices = [("iso", _("Create DVD-ISO")), ("dvd", _("Burn DVD"))]) + self.settings.isopath = ConfigText(fixed_size = False, visible_width = 40) + self.settings.dataformat = ConfigSelection(choices = [("iso9660_1", ("ISO9660 Level 1")), ("iso9660_4", ("ISO9660 version 2")), ("udf", ("UDF"))]) + self.settings.menubg = ConfigFilename() + self.settings.menuaudio = ConfigFilename() + self.settings.titleformat = ConfigText(fixed_size = False, visible_width = 40) + self.settings.subtitleformat = ConfigText(fixed_size = False, visible_width = 40) + self.settings.color_headline = ConfigColor() + self.settings.color_highlight = ConfigColor() + self.settings.color_button = ConfigColor() + self.settings.font_face = ConfigFilename() + self.settings.font_size = ConfigPixelvals() + self.settings.space = ConfigPixelvals() + self.settings.vmgm = ConfigFilename() + self.filekeys = ["vmgm", "menubg", "menuaudio", "font_face", "isopath"] def addService(self, service): import DVDTitle - t = DVDTitle.DVDTitle() - t.source = service + title = DVDTitle.DVDTitle() + title.addService(service) + self.titles.append(title) + return title - from enigma import eServiceCenter, iServiceInformation - serviceHandler = eServiceCenter.getInstance() + def saveProject(self, path): + import xml.dom.minidom + from Tools.XMLTools import elementsWithTag, mergeText, stringToXML + list = [] + list.append('\n') + list.append('\n') + list.append('\t\n') + list.append('\t\n') + for title in self.titles: + list.append('\t\t') + list.append(stringToXML(title.source.getPath())) + list.append('\n') + list.append('\t\n') + list.append('\n') - info = serviceHandler.info(service) - descr = info and " " + info.getInfoString(service, iServiceInformation.sDescription) or "" - t.name = info and info.getName(service) or "Title" + descr + name = self.settings.name.getValue() + i = 0 + filename = path + name + ".ddvdp.xml" + while fileExists(filename): + i = i+1 + filename = path + name + str(i).zfill(3) + ".ddvdp.xml" + try: + file = open(filename, "w") + for x in list: + file.write(x) + file.close() + except: + return False + return filename - self.titles.append(t) - return t + def loadProject(self, filename): + import xml.dom.minidom + try: + if not fileExists(filename): + self.error = "xml file not found!" + raise AttributeError + else: + self.error = "" + file = open(filename, "r") + data = file.read().decode("utf-8").replace('&',"&").encode("ascii",'xmlcharrefreplace') + file.close() + projectfiledom = xml.dom.minidom.parseString(data) + for project in projectfiledom.childNodes[0].childNodes: + if project.nodeType == xml.dom.minidom.Element.nodeType: + if project.tagName == 'settings': + i = 0 + if project.attributes.length < 11: + self.error = "project attributes missing" + raise AttributeError + while i < project.attributes.length: + item = project.attributes.item(i) + key = item.name.encode("utf-8") + try: + val = eval(item.nodeValue) + except (NameError, SyntaxError): + val = item.nodeValue.encode("utf-8") + try: + self.settings.dict()[key].setValue(val) + except (KeyError): + self.error = "unknown attribute '%s'" % (key) + raise AttributeError + i += 1 + for key in self.filekeys: + val = self.settings.dict()[key].getValue() + if not fileExists(val): + self.error += "\n%s '%s' not found" % (key, val) + if len(self.error): + raise AttributeError + except AttributeError: + self.error += (" in project '%s'") % (filename) + return False + return True