diff options
| author | Tavmjong Bah <tavmjong@free.fr> | 2018-01-30 08:33:01 +0000 |
|---|---|---|
| committer | Tavmjong Bah <tavmjong@free.fr> | 2018-01-30 08:33:01 +0000 |
| commit | 267299811df952d08324a39008f52c19641de9e0 (patch) | |
| tree | 28fef736a52cb7a72119d119be8eb663ad20a77f /src/sp-glyph.cpp | |
| parent | Translations: update inkscape.pot (diff) | |
| download | inkscape-267299811df952d08324a39008f52c19641de9e0.tar.gz inkscape-267299811df952d08324a39008f52c19641de9e0.zip | |
Move classes derived from SPObject to own directory.
A lot of header clean-up.
Diffstat (limited to 'src/sp-glyph.cpp')
| -rw-r--r-- | src/sp-glyph.cpp | 289 |
1 files changed, 0 insertions, 289 deletions
diff --git a/src/sp-glyph.cpp b/src/sp-glyph.cpp deleted file mode 100644 index 6284cbfa1..000000000 --- a/src/sp-glyph.cpp +++ /dev/null @@ -1,289 +0,0 @@ -#ifdef HAVE_CONFIG_H -#endif - -/* - * SVG <glyph> element implementation - * - * Author: - * Felipe C. da S. Sanches <juca@members.fsf.org> - * Abhishek Sharma - * - * Copyright (C) 2008, Felipe C. da S. Sanches - * - * Released under GNU GPL, read the file 'COPYING' for more information - */ - -#include "xml/repr.h" -#include "attributes.h" -#include "sp-glyph.h" -#include "document.h" - -SPGlyph::SPGlyph() - : SPObject() -//TODO: correct these values: - , d(NULL) - , orientation(GLYPH_ORIENTATION_BOTH) - , arabic_form(GLYPH_ARABIC_FORM_INITIAL) - , lang(NULL) - , horiz_adv_x(0) - , vert_origin_x(0) - , vert_origin_y(0) - , vert_adv_y(0) -{ -} - -void SPGlyph::build(SPDocument *document, Inkscape::XML::Node *repr) -{ - SPObject::build(document, repr); - - this->readAttr( "unicode" ); - this->readAttr( "glyph-name" ); - this->readAttr( "d" ); - this->readAttr( "orientation" ); - this->readAttr( "arabic-form" ); - this->readAttr( "lang" ); - this->readAttr( "horiz-adv-x" ); - this->readAttr( "vert-origin-x" ); - this->readAttr( "vert-origin-y" ); - this->readAttr( "vert-adv-y" ); -} - -void SPGlyph::release() { - SPObject::release(); -} - -static glyphArabicForm sp_glyph_read_arabic_form(gchar const *value){ - if (!value) { - return GLYPH_ARABIC_FORM_INITIAL; //TODO: verify which is the default default (for me, the spec is not clear) - } - - switch(value[0]){ - case 'i': - if (strncmp(value, "initial", 7) == 0) { - return GLYPH_ARABIC_FORM_INITIAL; - } - - if (strncmp(value, "isolated", 8) == 0) { - return GLYPH_ARABIC_FORM_ISOLATED; - } - break; - case 'm': - if (strncmp(value, "medial", 6) == 0) { - return GLYPH_ARABIC_FORM_MEDIAL; - } - break; - case 't': - if (strncmp(value, "terminal", 8) == 0) { - return GLYPH_ARABIC_FORM_TERMINAL; - } - break; - } - - return GLYPH_ARABIC_FORM_INITIAL; //TODO: VERIFY DEFAULT! -} - -static glyphOrientation sp_glyph_read_orientation(gchar const *value) -{ - if (!value) { - return GLYPH_ORIENTATION_BOTH; - } - - switch(value[0]){ - case 'h': - return GLYPH_ORIENTATION_HORIZONTAL; - break; - case 'v': - return GLYPH_ORIENTATION_VERTICAL; - break; - } - -//ERROR? TODO: VERIFY PROPER ERROR HANDLING - return GLYPH_ORIENTATION_BOTH; -} - -void SPGlyph::set(unsigned int key, const gchar *value) -{ - switch (key) { - case SP_ATTR_UNICODE: - { - this->unicode.clear(); - - if (value) { - this->unicode.append(value); - } - - this->requestModified(SP_OBJECT_MODIFIED_FLAG); - break; - } - case SP_ATTR_GLYPH_NAME: - { - this->glyph_name.clear(); - - if (value) { - this->glyph_name.append(value); - } - - this->requestModified(SP_OBJECT_MODIFIED_FLAG); - break; - } - case SP_ATTR_D: - { - if (this->d) { - g_free(this->d); - } - - this->d = g_strdup(value); - this->requestModified(SP_OBJECT_MODIFIED_FLAG); - break; - } - case SP_ATTR_ORIENTATION: - { - glyphOrientation orient = sp_glyph_read_orientation(value); - - if (this->orientation != orient){ - this->orientation = orient; - this->requestModified(SP_OBJECT_MODIFIED_FLAG); - } - break; - } - case SP_ATTR_ARABIC_FORM: - { - glyphArabicForm form = sp_glyph_read_arabic_form(value); - - if (this->arabic_form != form){ - this->arabic_form = form; - this->requestModified(SP_OBJECT_MODIFIED_FLAG); - } - break; - } - case SP_ATTR_LANG: - { - if (this->lang) { - g_free(this->lang); - } - - this->lang = g_strdup(value); - this->requestModified(SP_OBJECT_MODIFIED_FLAG); - break; - } - case SP_ATTR_HORIZ_ADV_X: - { - double number = value ? g_ascii_strtod(value, 0) : 0; - - if (number != this->horiz_adv_x){ - this->horiz_adv_x = number; - this->requestModified(SP_OBJECT_MODIFIED_FLAG); - } - break; - } - case SP_ATTR_VERT_ORIGIN_X: - { - double number = value ? g_ascii_strtod(value, 0) : 0; - - if (number != this->vert_origin_x){ - this->vert_origin_x = number; - this->requestModified(SP_OBJECT_MODIFIED_FLAG); - } - break; - } - case SP_ATTR_VERT_ORIGIN_Y: - { - double number = value ? g_ascii_strtod(value, 0) : 0; - - if (number != this->vert_origin_y){ - this->vert_origin_y = number; - this->requestModified(SP_OBJECT_MODIFIED_FLAG); - } - break; - } - case SP_ATTR_VERT_ADV_Y: - { - double number = value ? g_ascii_strtod(value, 0) : 0; - - if (number != this->vert_adv_y){ - this->vert_adv_y = number; - this->requestModified(SP_OBJECT_MODIFIED_FLAG); - } - break; - } - default: - { - SPObject::set(key, value); - break; - } - } -} - -/** - * Receives update notifications. - */ -void SPGlyph::update(SPCtx *ctx, guint flags) -{ - if (flags & SP_OBJECT_MODIFIED_FLAG) { - /* do something to trigger redisplay, updates? */ - this->readAttr( "unicode" ); - this->readAttr( "glyph-name" ); - this->readAttr( "d" ); - this->readAttr( "orientation" ); - this->readAttr( "arabic-form" ); - this->readAttr( "lang" ); - this->readAttr( "horiz-adv-x" ); - this->readAttr( "vert-origin-x" ); - this->readAttr( "vert-origin-y" ); - this->readAttr( "vert-adv-y" ); - } - - SPObject::update(ctx, flags); -} - -#define COPY_ATTR(rd,rs,key) (rd)->setAttribute((key), rs->attribute(key)); - -Inkscape::XML::Node* SPGlyph::write(Inkscape::XML::Document *xml_doc, Inkscape::XML::Node *repr, guint flags) -{ - if ((flags & SP_OBJECT_WRITE_BUILD) && !repr) { - repr = xml_doc->createElement("svg:glyph"); - } - - /* I am commenting out this part because I am not certain how does it work. I will have to study it later. Juca - repr->setAttribute("unicode", glyph->unicode); - repr->setAttribute("glyph-name", glyph->glyph_name); - repr->setAttribute("d", glyph->d); - sp_repr_set_svg_double(repr, "orientation", (double) glyph->orientation); - sp_repr_set_svg_double(repr, "arabic-form", (double) glyph->arabic_form); - repr->setAttribute("lang", glyph->lang); - sp_repr_set_svg_double(repr, "horiz-adv-x", glyph->horiz_adv_x); - sp_repr_set_svg_double(repr, "vert-origin-x", glyph->vert_origin_x); - sp_repr_set_svg_double(repr, "vert-origin-y", glyph->vert_origin_y); - sp_repr_set_svg_double(repr, "vert-adv-y", glyph->vert_adv_y); - */ - - if (repr != this->getRepr()) { - // All the COPY_ATTR functions below use - // XML Tree directly while they shouldn't. - COPY_ATTR(repr, this->getRepr(), "unicode"); - COPY_ATTR(repr, this->getRepr(), "glyph-name"); - COPY_ATTR(repr, this->getRepr(), "d"); - COPY_ATTR(repr, this->getRepr(), "orientation"); - COPY_ATTR(repr, this->getRepr(), "arabic-form"); - COPY_ATTR(repr, this->getRepr(), "lang"); - COPY_ATTR(repr, this->getRepr(), "horiz-adv-x"); - COPY_ATTR(repr, this->getRepr(), "vert-origin-x"); - COPY_ATTR(repr, this->getRepr(), "vert-origin-y"); - COPY_ATTR(repr, this->getRepr(), "vert-adv-y"); - } - - SPObject::write(xml_doc, repr, flags); - - return repr; -} - -/* - Local Variables: - mode:c++ - c-file-style:"stroustrup" - c-file-offsets:((innamespace . 0)(inline-open . 0)(case-label . +)) - indent-tabs-mode:nil - fill-column:99 - End: -*/ -// vim: filetype=cpp:expandtab:shiftwidth=4:tabstop=8:softtabstop=4 : |
