/* -*- mode: C++; tab-width: 4; c-basic-offset: 4; -*- */ /* AbiSource * * Copyright (C) 2007 Philippe Milot * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; either version 2 * of the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA * 02111-1307, USA. */ // Class definition include #include // AbiWord includes #include #include #include // External includes #include OXML_Element_Run::OXML_Element_Run(const std::string & id) : OXML_Element(id, R_TAG, SPAN) { //Intentionally empty } OXML_Element_Run::~OXML_Element_Run() { } UT_Error OXML_Element_Run::serializeChildren(IE_Exp_OpenXML* exporter) { UT_Error ret = UT_OK; OXML_ElementVector children = getChildren(); OXML_ElementVector::size_type i; for (i = 0; i < children.size(); i++) { if(getType() == LIST) children[i]->setType(LIST); ret = children[i]->serialize(exporter); if(ret != UT_OK) return ret; } return ret; } UT_Error OXML_Element_Run::serialize(IE_Exp_OpenXML* exporter) { UT_Error err = UT_OK; err = exporter->startRun(TARGET); if(err != UT_OK) return err; err = serializeProperties(exporter); if(err != UT_OK) return err; err = this->serializeChildren(exporter); if(err != UT_OK) return err; return exporter->finishRun(TARGET); } UT_Error OXML_Element_Run::serializeProperties(IE_Exp_OpenXML* exporter) { //TODO: Add all the property serializations here UT_Error err = UT_OK; const gchar* szValue = NULL; err = exporter->startRunProperties(TARGET); if(err != UT_OK) return err; if(getProperty("lang", szValue) == UT_OK) { if(!strcmp(szValue, "-none-")) err = exporter->setNoProof(TARGET); else err = exporter->setLanguage(TARGET, szValue); if(err != UT_OK) return err; } if(getProperty("font-family", szValue) == UT_OK) { err = exporter->setFontFamily(TARGET, szValue); if(err != UT_OK) return err; } if(getProperty("font-weight", szValue) == UT_OK) { if(!strcmp(szValue, "bold")) { err = exporter->setBold(TARGET); if(err != UT_OK) return err; } } if(getProperty("font-style", szValue) == UT_OK) { if(!strcmp(szValue, "italic")) { err = exporter->setItalic(TARGET); if(err != UT_OK) return err; } } if(getProperty("font-size", szValue) == UT_OK) { err = exporter->setFontSize(TARGET, szValue); if(err != UT_OK) return err; } if(getProperty("text-decoration", szValue) == UT_OK) { if(strstr(szValue, "underline")) { err = exporter->setUnderline(TARGET); if(err != UT_OK) return err; } if(strstr(szValue, "overline")) { err = exporter->setOverline(TARGET); if(err != UT_OK) return err; } if(strstr(szValue, "line-through")) { err = exporter->setLineThrough(TARGET); if(err != UT_OK) return err; } } if(getProperty("text-position", szValue) == UT_OK) { if(!strcmp(szValue, "superscript")) { err = exporter->setSuperscript(TARGET); if(err != UT_OK) return err; } else if(!strcmp(szValue, "subscript")) { err = exporter->setSubscript(TARGET); if(err != UT_OK) return err; } } if(getProperty("color", szValue) == UT_OK) { err = exporter->setTextColor(TARGET, szValue); if(err != UT_OK) return err; } if(getProperty("bgcolor", szValue) == UT_OK) { err = exporter->setBackgroundColor(TARGET, szValue); if(err != UT_OK) return err; } if(getProperty("dir-override", szValue) == UT_OK) { err = exporter->setTextDirection(TARGET, szValue); if(err != UT_OK) return err; } return exporter->finishRunProperties(TARGET); } UT_Error OXML_Element_Run::addToPT(PD_Document * pDocument) { UT_return_val_if_fail(pDocument != NULL, UT_ERROR); UT_Error ret = UT_OK; const gchar ** atts = getAttributesWithProps(); if (atts != NULL) { //We open the formatting tag ret = pDocument->appendFmt(atts) ? UT_OK : UT_ERROR; if(ret != UT_OK) { UT_ASSERT_HARMLESS(ret == UT_OK); return ret; } } ret = addChildrenToPT(pDocument); if(ret != UT_OK) { UT_ASSERT_HARMLESS(ret == UT_OK); return ret; } if (atts != NULL) { //We close the formatting tag ret = pDocument->appendFmt((const gchar **)NULL) ? UT_OK : UT_ERROR; UT_return_val_if_fail(ret == UT_OK, ret); } return ret; }