X-Git-Url: https://git.ucc.asn.au/?a=blobdiff_plain;f=XMLParse2.py;h=563a0faad0f12adb0ac2b45b167887abf59c3073;hb=70b487ce56a52ae51eccb89d2e1ae57485a30f59;hp=e5c244df73f526c3137003ae323a230d7a334eea;hpb=38e3a5e3bc3dfae433af9bbf96d93d74d0641795;p=planet-ucc.git diff --git a/XMLParse2.py b/XMLParse2.py index e5c244d..563a0fa 100644 --- a/XMLParse2.py +++ b/XMLParse2.py @@ -38,14 +38,13 @@ class XMLParse: def parse(self): "Return a single Blog object" item = Blog() - if self.blogObject: + if self.blogObject and self.blogObject.cache: sys.stdout.write('Downloading feed %s...' % self.feedURL) try: data = feedparser.parse(self.feedURL, self.blogObject.cache.etag, self.blogObject.cache.date) sys.stdout.write('done.\n') except: sys.stdout.write('failed.\n') - raise return None # check to see what we got returned if data['items'] == [] and data['channel'] == {}: @@ -62,10 +61,17 @@ class XMLParse: # create caching data try: cache = CacheHandler.CacheObject() - cache.etag = data['etag'] - cache.date = data['modified'] + try: + cache.etag = data['etag'] + except: + cache.etag = None + try: + cache.date = data['modified'] + except: + cache.date = None item.cache = cache except: + sys.stderr.write('DEBUG: XMLParse2: cache item generation failed\n') item.cache = None # parse the return of data into a blog if data['channel'].has_key('title'): @@ -87,7 +93,7 @@ class XMLParse: else: blogItem.itemURL = item.blogURL if entry.has_key('date_parsed'): - blogItem.itemDate = time.mktime(entry['date_parsed']) + 28000 + blogItem.itemDate = time.mktime(entry['date_parsed']) + 28800 else: blogItem.itemDate = 0 if entry.has_key('description'):