diff options
| author | Tavmjong Bah <tavmjong@free.fr> | 2014-05-29 09:41:39 +0000 |
|---|---|---|
| committer | tavmjong-free <tavmjong@free.fr> | 2014-05-29 09:41:39 +0000 |
| commit | f4f35a8c63d574cadaec4ad323f6c9cffa30e4c7 (patch) | |
| tree | acbd2659119d0bfb4c535e7d100a3f65dcab86b6 /src/libnrtype | |
| parent | Initialize style store with default styles. Fixes Gtk-CRITICAL and GLib-Gobje... (diff) | |
| download | inkscape-f4f35a8c63d574cadaec4ad323f6c9cffa30e4c7.tar.gz inkscape-f4f35a8c63d574cadaec4ad323f6c9cffa30e4c7.zip | |
Use SPStyle value for 'font-family' rather than parse 'style' ourselves.
This fixes the problem of a 'font-family' declared via the 'font'
shorthand being ignored when creating the document font list.
(bzr r13401)
Diffstat (limited to 'src/libnrtype')
| -rw-r--r-- | src/libnrtype/font-lister.cpp | 31 |
1 files changed, 3 insertions, 28 deletions
diff --git a/src/libnrtype/font-lister.cpp b/src/libnrtype/font-lister.cpp index 300273378..333c4ef5b 100644 --- a/src/libnrtype/font-lister.cpp +++ b/src/libnrtype/font-lister.cpp @@ -240,37 +240,12 @@ namespace Inkscape font_list_store->thaw_notify(); } - // FIXME: why do we parse the style attribute instead of the object's SPStyle? void FontLister::update_font_list_recursive( SPObject *r, std::list<Glib::ustring> *l ) { - const gchar *style = r->getRepr()->attribute("style"); - if( style != NULL ) { - - std::vector<Glib::ustring> tokens = Glib::Regex::split_simple(";", style ); - for( size_t i=0; i < tokens.size(); ++i ) { - - Glib::ustring token = tokens[i]; - size_t found = token.find("font-family:"); - - if( found != Glib::ustring::npos ) { - - // Remove "font-family:" - token.erase(found,12); - - // Remove any leading single or double quote - if( token[0] == '\'' || token[0] == '"' ) { - token.erase(0,1); - } - - // Remove any trailing single or double quote - if( token[token.length()-1] == '\'' || token[token.length()-1] == '"' ) { - token.erase(token.length()-1); - } - - l->push_back( token ); - } - } + const gchar *font_family = r->style->font_family.value; + if( font_family ) { + l->push_back( Glib::ustring( font_family ) ); } for (SPObject *child = r->firstChild(); child; child = child->getNext()) { |
