X-Git-Url: http://code.vuplus.com/gitweb/?a=blobdiff_plain;f=lib%2Fpython%2FComponents%2FTimezones.py;h=7f709159286b0065cc3e53fd9a1dd6f76e9b7c74;hb=78dd965fb694fb8afa6d9ddc12cf45ae4645f848;hp=0b6eb79bfe880b896905edf132757ae300ad3f74;hpb=d0ca21133e420f63c90d44e6b8bd23273e2ffd58;p=vuplus_dvbapp diff --git a/lib/python/Components/Timezones.py b/lib/python/Components/Timezones.py index 0b6eb79..7f70915 100644 --- a/lib/python/Components/Timezones.py +++ b/lib/python/Components/Timezones.py @@ -1,11 +1,9 @@ from xml.sax import make_parser from xml.sax.handler import ContentHandler -import os +from os import environ, unlink, symlink import time -from enigma import * - class Timezones: class parseTimezones(ContentHandler): def __init__(self, timezones): @@ -23,25 +21,45 @@ class Timezones: def readTimezonesFromFile(self): parser = make_parser() - timezonesHandler = self.parseTimezones(self.timezones) - parser.setContentHandler(timezonesHandler) - parser.parse('/etc/timezone.xml') + + try: + timezonesHandler = self.parseTimezones(self.timezones) + parser.setContentHandler(timezonesHandler) + parser.parse('/etc/timezone.xml') + except: + pass + + if len(self.timezones) == 0: + self.timezones = [("UTC", "UTC")] def activateTimezone(self, index): - os.environ['TZ'] = self.timezones[index][1] + if len(self.timezones) <= index: + return + + environ['TZ'] = self.timezones[index][1] + try: + unlink("/etc/localtime") + except OSError: + pass + try: + symlink("/usr/share/zoneinfo/%s" %(self.timezones[index][1]), "/etc/localtime") + except OSError: + pass try: time.tzset() except: - etimezone() + from enigma import e_tzset + e_tzset() def getTimezoneList(self): - list = [] - for x in self.timezones: - list.append(str(x[0])) - return list - + return [ str(x[0]) for x in self.timezones ] + def getDefaultTimezone(self): # TODO return something more useful - depending on country-settings? - return 27 + t = "(GMT+01:00) Amsterdam, Berlin, Bern, Rome, Vienna" + for (a,b) in self.timezones: + if a == t: + return a + return self.timezones[0][0] timezones = Timezones()