/* Copyright (C) 2007 Nikolas Zimmermann This file is part of the KDE project This library is free software; you can redistribute it and/or modify it under the terms of the GNU Library General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This library 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 Library General Public License for more details. You should have received a copy of the GNU Library General Public License along with this library; see the file COPYING.LIB. If not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ #include "config.h" #if ENABLE(SVG) #include "SVGTextPathElement.h" #include "FloatRect.h" #include "MappedAttribute.h" #include "RenderSVGTextPath.h" #include "SVGLengthList.h" #include "SVGPathElement.h" #include "SVGRenderStyle.h" #include "SVGTransformList.h" #include "TransformationMatrix.h" namespace WebCore { SVGTextPathElement::SVGTextPathElement(const QualifiedName& tagName, Document* doc) : SVGTextContentElement(tagName, doc) , SVGURIReference() , m_startOffset(this, SVGNames::startOffsetAttr, LengthModeOther) , m_method(this, SVGNames::methodAttr, SVG_TEXTPATH_METHODTYPE_ALIGN) , m_spacing(this, SVGNames::spacingAttr, SVG_TEXTPATH_SPACINGTYPE_EXACT) , m_href(this, XLinkNames::hrefAttr) { } SVGTextPathElement::~SVGTextPathElement() { } void SVGTextPathElement::parseMappedAttribute(MappedAttribute* attr) { const String& value = attr->value(); if (attr->name() == SVGNames::startOffsetAttr) setStartOffsetBaseValue(SVGLength(LengthModeOther, value)); else if (attr->name() == SVGNames::methodAttr) { if (value == "align") setSpacingBaseValue(SVG_TEXTPATH_METHODTYPE_ALIGN); else if (value == "stretch") setSpacingBaseValue(SVG_TEXTPATH_METHODTYPE_STRETCH); } else if (attr->name() == SVGNames::spacingAttr) { if (value == "auto") setMethodBaseValue(SVG_TEXTPATH_SPACINGTYPE_AUTO); else if (value == "exact") setMethodBaseValue(SVG_TEXTPATH_SPACINGTYPE_EXACT); } else { if (SVGURIReference::parseMappedAttribute(attr)) return; SVGTextContentElement::parseMappedAttribute(attr); } } RenderObject* SVGTextPathElement::createRenderer(RenderArena* arena, RenderStyle*) { return new (arena) RenderSVGTextPath(this); } bool SVGTextPathElement::childShouldCreateRenderer(Node* child) const { if (child->isTextNode() #if ENABLE(SVG_FONTS) || child->hasTagName(SVGNames::altGlyphTag) #endif || child->hasTagName(SVGNames::trefTag) || child->hasTagName(SVGNames::tspanTag) || child->hasTagName(SVGNames::textPathTag)) return true; return false; } void SVGTextPathElement::insertedIntoDocument() { SVGElement::insertedIntoDocument(); String id = SVGURIReference::getTarget(href()); Element* targetElement = ownerDocument()->getElementById(id); if (!targetElement) { document()->accessSVGExtensions()->addPendingResource(id, this); return; } } } #endif // ENABLE(SVG) // vim:ts=4:noet