From 520665a6cc95277476b3423a46a76c2b78edd49e Mon Sep 17 00:00:00 2001 From: Denis Fomin Date: Fri, 11 Jan 2013 01:53:09 +0400 Subject: [PATCH] fix html --- src/common/helpers.py | 3 ++- src/htmltextview.py | 26 ++++++++++++++++++-------- 2 files changed, 20 insertions(+), 9 deletions(-) diff --git a/src/common/helpers.py b/src/common/helpers.py index 733a43232..3c95ff268 100644 --- a/src/common/helpers.py +++ b/src/common/helpers.py @@ -1460,7 +1460,8 @@ def _get_img_direct(attrs): """ Download an image. This function should be launched in a separated thread. """ - mem, alt = '', '' + mem = b'' + alt = '' # Wait maximum 5s for connection socket.setdefaulttimeout(5) try: diff --git a/src/htmltextview.py b/src/htmltextview.py index fda3b0b99..922734f03 100644 --- a/src/htmltextview.py +++ b/src/htmltextview.py @@ -238,7 +238,7 @@ class HtmlHandler(xml.sax.handler.ContentHandler): def _get_current_attributes(self): attrs = self.textview.get_default_attributes() self.iter.backward_char() - self.iter.get_attributes(attrs) + attrs = (self.iter.get_attributes())[1] self.iter.forward_char() return attrs @@ -265,7 +265,8 @@ class HtmlHandler(xml.sax.handler.ContentHandler): frac = val/100 if font_relative: attrs = self._get_current_attributes() - font_size = attrs.font.get_size() / Pango.SCALE + if not attrs.font: + font_size = self.get_font_size() callback(frac*display_resolution*font_size, *args) elif block_relative: # CSS says 'Percentage values: refer to width of the closest @@ -297,14 +298,17 @@ class HtmlHandler(xml.sax.handler.ContentHandler): elif value.endswith('em'): # ems, the width of the element's font attrs = self._get_current_attributes() - font_size = attrs.font.get_size() / Pango.SCALE + if not attrs.font: + font_size = self.get_font_size() callback(get_val()*display_resolution*font_size, *args) elif value.endswith('ex'): # x-height, ~ the height of the letter 'x' # FIXME: figure out how to calculate this correctly # for now 'em' size is used as approximation + attrs = self._get_current_attributes() - font_size = attrs.font.get_size() / Pango.SCALE + if not attrs.font: + font_size = self.get_font_size() callback(get_val()*display_resolution*font_size, *args) elif value.endswith('px'): # pixels @@ -359,13 +363,14 @@ class HtmlHandler(xml.sax.handler.ContentHandler): pass else: attrs = self._get_current_attributes() - tag.set_property('scale', scale / attrs.font_scale) + if attrs.font_scale ==0: + tag.set_property('scale', scale) return if value == 'smaller': - tag.set_property('scale', Pango.SCALE_SMALL) + tag.set_property('scale', 0.8333333333333) return if value == 'larger': - tag.set_property('scale', Pango.SCALE_LARGE) + tag.set_property('scale', 1.2) return # font relative (5 ~ 4pt, 110 ~ 72pt) self._parse_length(value, True, False, 5, 110,self.__parse_font_size_cb, @@ -758,7 +763,7 @@ class HtmlHandler(xml.sax.handler.ContentHandler): self.list_counters.append(0) elif name == 'li': if self.list_counters[-1] is None: - li_head = unichr(0x2022) + li_head = chr(0x2022) else: self.list_counters[-1] += 1 li_head = '%i.' % self.list_counters[-1] @@ -820,6 +825,11 @@ class HtmlHandler(xml.sax.handler.ContentHandler): self._jump_line() self._end_span() + def get_font_size(self): + context = self.conv_textview.tv.get_style_context() + font = context.get_font(Gtk.StateType.NORMAL) + return font.get_size() / Pango.SCALE + class HtmlTextView(Gtk.TextView): def __init__(self):