X-Git-Url: https://git.phdru.name/?a=blobdiff_plain;f=bkmk_parser.py;h=02116ccf025c9edacd119362331b64174ce89767;hb=71f7553119f3efe154d1154dd85f1ceecc46f641;hp=02b20d780c56003aea95d30827e4a8d85e6c4ef4;hpb=97aa08d47caad9eb70df496aa65e63b57b9cd5b6;p=bookmarks_db.git diff --git a/bkmk_parser.py b/bkmk_parser.py index 02b20d7..02116cc 100644 --- a/bkmk_parser.py +++ b/bkmk_parser.py @@ -3,17 +3,15 @@ This file is a part of Bookmarks database and Internet robot. """ -__version__ = "$Revision$"[11:-2] -__revision__ = "$Id$"[5:-2] -__date__ = "$Date$"[7:-2] __author__ = "Oleg Broytman " -__copyright__ = "Copyright (C) 1997-2011 PhiloSoft Design" +__copyright__ = "Copyright (C) 1997-2012 PhiloSoft Design" __license__ = "GNU GPL" __all__ = ['BkmkParser'] -import sys, os +import os +from m_lib.defenc import default_encoding from m_lib.net.www.html import HTMLParser from bkmk_objects import Folder, Bookmark, Ruler @@ -37,11 +35,6 @@ else: dump_names = debug -try: - from m_lib.defenc import default_encoding as DEFAULT_CHARSET -except ImportError: - DEFAULT_CHARSET = None - class BkmkParser(HTMLParser): def __init__(self): HTMLParser.__init__(self) @@ -54,8 +47,8 @@ class BkmkParser(HTMLParser): def handle_data(self, data): if data: - if self.charset and DEFAULT_CHARSET: - data = unicode(data, self.charset, "replace").encode(DEFAULT_CHARSET, "xmlcharrefreplace") + if self.charset and default_encoding: + data = unicode(data, self.charset, "replace").encode(default_encoding, "xmlcharrefreplace") self.accumulator += data # Mozilla - get charset @@ -78,8 +71,8 @@ class BkmkParser(HTMLParser): pass def start_title(self, attrs): - if DEFAULT_CHARSET: - self.accumulator += '\n' % DEFAULT_CHARSET + if default_encoding: + self.accumulator += '\n' % default_encoding self.accumulator += "" def end_title(self): @@ -133,7 +126,7 @@ class BkmkParser(HTMLParser): add_date = None last_visit = None last_modified = None - keyword = None + keyword = '' icon = None charset = None @@ -156,7 +149,8 @@ class BkmkParser(HTMLParser): debug("Bookmark points to: `%s'" % href) bookmark = Bookmark(href, add_date, last_visit, last_modified, - keyword or '', '', icon, charset) + keyword=keyword, icon=icon, + charset=charset, parser_charset=self.charset or default_encoding) self.current_object = bookmark self.current_folder.append(bookmark) self.urls += 1