diff options
author | Thorsten Behrens <tbehrens@suse.com> | 2013-06-27 20:41:29 +0200 |
---|---|---|
committer | Thorsten Behrens <tbehrens@suse.com> | 2013-06-27 20:44:07 +0200 |
commit | d9b09a3ff38b2cf11ee0b9f9f03d47375f2b11e8 (patch) | |
tree | 882746586e9284c25adde71d6e66f3021d0c3355 /svgio/inc | |
parent | 66e72c38f77bedc28b990b2a724829b50c70bf8d (diff) |
Fix fdo#65847 - avoid infinite recursion in style resolution.
That was previously asking back the node for the font size, which
was again asking the SvgNumber, which was ...
In this case, if the node has relative sizes, this is always
relative to the parent.
Change-Id: Iaa81d0238d9eb73f5af24df347d12d7cb8ba8c0a
Diffstat (limited to 'svgio/inc')
-rw-r--r-- | svgio/inc/svgio/svgreader/svgnode.hxx | 9 | ||||
-rw-r--r-- | svgio/inc/svgio/svgreader/svgtools.hxx | 8 |
2 files changed, 11 insertions, 6 deletions
diff --git a/svgio/inc/svgio/svgreader/svgnode.hxx b/svgio/inc/svgio/svgreader/svgnode.hxx index 725fb5cb2b8a..7c1c39b968d9 100644 --- a/svgio/inc/svgio/svgreader/svgnode.hxx +++ b/svgio/inc/svgio/svgreader/svgnode.hxx @@ -134,9 +134,12 @@ namespace svgio const SvgNodeVector& getChildren() const { return maChildren; } /// InfoProvider support for %, em and ex values - virtual const basegfx::B2DRange* getCurrentViewPort() const; - virtual double getCurrentFontSize() const; - virtual double getCurrentXHeight() const; + virtual const basegfx::B2DRange* getCurrentViewPort() const SAL_OVERRIDE; + virtual double getCurrentFontSizeInherited() const SAL_OVERRIDE; + virtual double getCurrentXHeightInherited() const SAL_OVERRIDE; + + double getCurrentFontSize() const; + double getCurrentXHeight() const; /// Id access const OUString* getId() const { return mpId; } diff --git a/svgio/inc/svgio/svgreader/svgtools.hxx b/svgio/inc/svgio/svgreader/svgtools.hxx index 0dbedf87eac5..138a06546a0b 100644 --- a/svgio/inc/svgio/svgreader/svgtools.hxx +++ b/svgio/inc/svgio/svgreader/svgtools.hxx @@ -62,10 +62,12 @@ namespace svgio class InfoProvider { public: - virtual ~InfoProvider() {} + virtual ~InfoProvider() {} virtual const basegfx::B2DRange* getCurrentViewPort() const = 0; - virtual double getCurrentFontSize() const = 0; - virtual double getCurrentXHeight() const = 0; + /// return font size of node inherited from parents + virtual double getCurrentFontSizeInherited() const = 0; + /// return xheight of node inherited from parents + virtual double getCurrentXHeightInherited() const = 0; }; enum SvgUnit |