diff -r 000000000000 -r dd21522fd290 webengine/osswebengine/DerivedSources/WebCore/JSSVGGElement.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/webengine/osswebengine/DerivedSources/WebCore/JSSVGGElement.cpp Mon Mar 30 12:54:55 2009 +0300 @@ -0,0 +1,298 @@ +/* + This file is part of the WebKit open source project. + This file has been generated by generate-bindings.pl. DO NOT MODIFY! + + 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 "Document.h" +#include "Frame.h" +#include "SVGDocumentExtensions.h" +#include "SVGElement.h" +#include "SVGAnimatedTemplate.h" +#include "JSSVGGElement.h" + +#include + +#include "CSSMutableStyleDeclaration.h" +#include "CSSStyleDeclaration.h" +#include "JSCSSStyleDeclaration.h" +#include "JSSVGAnimatedBoolean.h" +#include "JSSVGAnimatedString.h" +#include "JSSVGAnimatedTransformList.h" +#include "JSSVGElement.h" +#include "JSSVGMatrix.h" +#include "JSSVGRect.h" +#include "JSSVGStringList.h" +#include "PlatformString.h" +#include "SVGElement.h" +#include "SVGGElement.h" +#include "SVGStringList.h" + +using namespace KJS; + +namespace WebCore { + +/* Hash table */ + +static const HashEntry JSSVGGElementTableEntries[] = +{ + { 0, 0, 0, 0, 0 }, + { "farthestViewportElement", JSSVGGElement::FarthestViewportElementAttrNum, DontDelete|ReadOnly, 0, 0 }, + { "systemLanguage", JSSVGGElement::SystemLanguageAttrNum, DontDelete|ReadOnly, 0, &JSSVGGElementTableEntries[11] }, + { 0, 0, 0, 0, 0 }, + { "xmlspace", JSSVGGElement::XmlspaceAttrNum, DontDelete, 0, 0 }, + { "requiredExtensions", JSSVGGElement::RequiredExtensionsAttrNum, DontDelete|ReadOnly, 0, &JSSVGGElementTableEntries[12] }, + { "nearestViewportElement", JSSVGGElement::NearestViewportElementAttrNum, DontDelete|ReadOnly, 0, 0 }, + { "style", JSSVGGElement::StyleAttrNum, DontDelete|ReadOnly, 0, 0 }, + { 0, 0, 0, 0, 0 }, + { "requiredFeatures", JSSVGGElement::RequiredFeaturesAttrNum, DontDelete|ReadOnly, 0, 0 }, + { 0, 0, 0, 0, 0 }, + { "xmllang", JSSVGGElement::XmllangAttrNum, DontDelete, 0, &JSSVGGElementTableEntries[14] }, + { "externalResourcesRequired", JSSVGGElement::ExternalResourcesRequiredAttrNum, DontDelete|ReadOnly, 0, &JSSVGGElementTableEntries[13] }, + { "className", JSSVGGElement::ClassNameAttrNum, DontDelete|ReadOnly, 0, 0 }, + { "transform", JSSVGGElement::TransformAttrNum, DontDelete|ReadOnly, 0, 0 } +}; + +static const HashTable JSSVGGElementTable = +{ + 2, 15, JSSVGGElementTableEntries, 11 +}; + +/* Hash table for prototype */ + +static const HashEntry JSSVGGElementPrototypeTableEntries[] = +{ + { "hasExtension", JSSVGGElement::HasExtensionFuncNum, DontDelete|Function, 1, &JSSVGGElementPrototypeTableEntries[6] }, + { 0, 0, 0, 0, 0 }, + { 0, 0, 0, 0, 0 }, + { "getBBox", JSSVGGElement::GetBBoxFuncNum, DontDelete|Function, 0, &JSSVGGElementPrototypeTableEntries[5] }, + { "getTransformToElement", JSSVGGElement::GetTransformToElementFuncNum, DontDelete|Function, 1, 0 }, + { "getCTM", JSSVGGElement::GetCTMFuncNum, DontDelete|Function, 0, 0 }, + { "getScreenCTM", JSSVGGElement::GetScreenCTMFuncNum, DontDelete|Function, 0, 0 } +}; + +static const HashTable JSSVGGElementPrototypeTable = +{ + 2, 7, JSSVGGElementPrototypeTableEntries, 5 +}; + +const ClassInfo JSSVGGElementPrototype::info = { "SVGGElementPrototype", 0, &JSSVGGElementPrototypeTable, 0 }; + +JSObject* JSSVGGElementPrototype::self(ExecState* exec) +{ + return KJS::cacheGlobalObject(exec, "[[JSSVGGElement.prototype]]"); +} + +bool JSSVGGElementPrototype::getOwnPropertySlot(ExecState* exec, const Identifier& propertyName, PropertySlot& slot) +{ + return getStaticFunctionSlot(exec, &JSSVGGElementPrototypeTable, this, propertyName, slot); +} + +const ClassInfo JSSVGGElement::info = { "SVGGElement", &JSSVGElement::info, &JSSVGGElementTable, 0 }; + +JSSVGGElement::JSSVGGElement(ExecState* exec, SVGGElement* impl) + : JSSVGElement(exec, impl) +{ + setPrototype(JSSVGGElementPrototype::self(exec)); +} + +bool JSSVGGElement::getOwnPropertySlot(ExecState* exec, const Identifier& propertyName, PropertySlot& slot) +{ + return getStaticValueSlot(exec, &JSSVGGElementTable, this, propertyName, slot); +} + +JSValue* JSSVGGElement::getValueProperty(ExecState* exec, int token) const +{ + switch (token) { + case RequiredFeaturesAttrNum: { + SVGGElement* imp = static_cast(impl()); + + return toJS(exec, WTF::getPtr(imp->requiredFeatures())); + } + case RequiredExtensionsAttrNum: { + SVGGElement* imp = static_cast(impl()); + + return toJS(exec, WTF::getPtr(imp->requiredExtensions())); + } + case SystemLanguageAttrNum: { + SVGGElement* imp = static_cast(impl()); + + return toJS(exec, WTF::getPtr(imp->systemLanguage())); + } + case XmllangAttrNum: { + SVGGElement* imp = static_cast(impl()); + + return jsString(imp->xmllang()); + } + case XmlspaceAttrNum: { + SVGGElement* imp = static_cast(impl()); + + return jsString(imp->xmlspace()); + } + case ExternalResourcesRequiredAttrNum: { + SVGGElement* imp = static_cast(impl()); + + ASSERT(exec && exec->dynamicInterpreter()); + + RefPtr obj = imp->externalResourcesRequiredAnimated(); + Frame* activeFrame = static_cast(exec->dynamicInterpreter())->frame(); + if (activeFrame) { + SVGDocumentExtensions* extensions = (activeFrame->document() ? activeFrame->document()->accessSVGExtensions() : 0); + if (extensions) { + if (extensions->hasGenericContext(obj.get())) + ASSERT(extensions->genericContext(obj.get()) == imp); + else + extensions->setGenericContext(obj.get(), imp); + } + } + + return toJS(exec, obj.get()); + } + case ClassNameAttrNum: { + SVGGElement* imp = static_cast(impl()); + + ASSERT(exec && exec->dynamicInterpreter()); + + RefPtr obj = imp->classNameAnimated(); + Frame* activeFrame = static_cast(exec->dynamicInterpreter())->frame(); + if (activeFrame) { + SVGDocumentExtensions* extensions = (activeFrame->document() ? activeFrame->document()->accessSVGExtensions() : 0); + if (extensions) { + if (extensions->hasGenericContext(obj.get())) + ASSERT(extensions->genericContext(obj.get()) == imp); + else + extensions->setGenericContext(obj.get(), imp); + } + } + + return toJS(exec, obj.get()); + } + case StyleAttrNum: { + SVGGElement* imp = static_cast(impl()); + + return toJS(exec, WTF::getPtr(imp->style())); + } + case TransformAttrNum: { + SVGGElement* imp = static_cast(impl()); + + ASSERT(exec && exec->dynamicInterpreter()); + + RefPtr obj = imp->transformAnimated(); + Frame* activeFrame = static_cast(exec->dynamicInterpreter())->frame(); + if (activeFrame) { + SVGDocumentExtensions* extensions = (activeFrame->document() ? activeFrame->document()->accessSVGExtensions() : 0); + if (extensions) { + if (extensions->hasGenericContext(obj.get())) + ASSERT(extensions->genericContext(obj.get()) == imp); + else + extensions->setGenericContext(obj.get(), imp); + } + } + + return toJS(exec, obj.get()); + } + case NearestViewportElementAttrNum: { + SVGGElement* imp = static_cast(impl()); + + return toJS(exec, WTF::getPtr(imp->nearestViewportElement())); + } + case FarthestViewportElementAttrNum: { + SVGGElement* imp = static_cast(impl()); + + return toJS(exec, WTF::getPtr(imp->farthestViewportElement())); + } + } + return 0; +} + +void JSSVGGElement::put(ExecState* exec, const Identifier& propertyName, JSValue* value, int attr) +{ + lookupPut(exec, propertyName, value, attr, &JSSVGGElementTable, this); +} + +void JSSVGGElement::putValueProperty(ExecState* exec, int token, JSValue* value, int /*attr*/) +{ + switch (token) { + case XmllangAttrNum: { + SVGGElement* imp = static_cast(impl()); + + imp->setXmllang(value->toString(exec)); + break; + } + case XmlspaceAttrNum: { + SVGGElement* imp = static_cast(impl()); + + imp->setXmlspace(value->toString(exec)); + break; + } + } +} + +JSValue* JSSVGGElementPrototypeFunction::callAsFunction(ExecState* exec, JSObject* thisObj, const List& args) +{ + if (!thisObj->inherits(&JSSVGGElement::info)) + return throwError(exec, TypeError); + + SVGGElement* imp = static_cast(static_cast(thisObj)->impl()); + + switch (id) { + case JSSVGGElement::HasExtensionFuncNum: { + String extension = args[0]->toString(exec); + + + KJS::JSValue* result = jsBoolean(imp->hasExtension(extension)); + return result; + } + case JSSVGGElement::GetBBoxFuncNum: { + + + KJS::JSValue* result = toJS(exec, new JSSVGPODTypeWrapper(imp->getBBox())); + return result; + } + case JSSVGGElement::GetCTMFuncNum: { + + + KJS::JSValue* result = toJS(exec, new JSSVGPODTypeWrapper(imp->getCTM())); + return result; + } + case JSSVGGElement::GetScreenCTMFuncNum: { + + + KJS::JSValue* result = toJS(exec, new JSSVGPODTypeWrapper(imp->getScreenCTM())); + return result; + } + case JSSVGGElement::GetTransformToElementFuncNum: { + ExceptionCode ec = 0; + SVGElement* element = toSVGElement(args[0]); + + + KJS::JSValue* result = toJS(exec, new JSSVGPODTypeWrapper(imp->getTransformToElement(element, ec))); + setDOMException(exec, ec); + return result; + } + } + return 0; +} + +} + +#endif // ENABLE(SVG)