webengine/osswebengine/DerivedSources/WebCore/JSSVGGElement.cpp
changeset 0 dd21522fd290
--- /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 <wtf/GetPtr.h>
+
+#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<JSSVGGElementPrototype>(exec, "[[JSSVGGElement.prototype]]");
+}
+
+bool JSSVGGElementPrototype::getOwnPropertySlot(ExecState* exec, const Identifier& propertyName, PropertySlot& slot)
+{
+    return getStaticFunctionSlot<JSSVGGElementPrototypeFunction, JSObject>(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<JSSVGGElement, JSSVGElement>(exec, &JSSVGGElementTable, this, propertyName, slot);
+}
+
+JSValue* JSSVGGElement::getValueProperty(ExecState* exec, int token) const
+{
+    switch (token) {
+    case RequiredFeaturesAttrNum: {
+        SVGGElement* imp = static_cast<SVGGElement*>(impl());
+
+        return toJS(exec, WTF::getPtr(imp->requiredFeatures()));
+    }
+    case RequiredExtensionsAttrNum: {
+        SVGGElement* imp = static_cast<SVGGElement*>(impl());
+
+        return toJS(exec, WTF::getPtr(imp->requiredExtensions()));
+    }
+    case SystemLanguageAttrNum: {
+        SVGGElement* imp = static_cast<SVGGElement*>(impl());
+
+        return toJS(exec, WTF::getPtr(imp->systemLanguage()));
+    }
+    case XmllangAttrNum: {
+        SVGGElement* imp = static_cast<SVGGElement*>(impl());
+
+        return jsString(imp->xmllang());
+    }
+    case XmlspaceAttrNum: {
+        SVGGElement* imp = static_cast<SVGGElement*>(impl());
+
+        return jsString(imp->xmlspace());
+    }
+    case ExternalResourcesRequiredAttrNum: {
+        SVGGElement* imp = static_cast<SVGGElement*>(impl());
+
+        ASSERT(exec && exec->dynamicInterpreter());
+
+        RefPtr<SVGAnimatedBoolean> obj = imp->externalResourcesRequiredAnimated();
+        Frame* activeFrame = static_cast<ScriptInterpreter*>(exec->dynamicInterpreter())->frame();
+        if (activeFrame) {
+            SVGDocumentExtensions* extensions = (activeFrame->document() ? activeFrame->document()->accessSVGExtensions() : 0);
+            if (extensions) {
+                if (extensions->hasGenericContext<SVGAnimatedBoolean>(obj.get()))
+                    ASSERT(extensions->genericContext<SVGAnimatedBoolean>(obj.get()) == imp);
+                else
+                    extensions->setGenericContext<SVGAnimatedBoolean>(obj.get(), imp);
+            }
+        }
+
+        return toJS(exec, obj.get());
+    }
+    case ClassNameAttrNum: {
+        SVGGElement* imp = static_cast<SVGGElement*>(impl());
+
+        ASSERT(exec && exec->dynamicInterpreter());
+
+        RefPtr<SVGAnimatedString> obj = imp->classNameAnimated();
+        Frame* activeFrame = static_cast<ScriptInterpreter*>(exec->dynamicInterpreter())->frame();
+        if (activeFrame) {
+            SVGDocumentExtensions* extensions = (activeFrame->document() ? activeFrame->document()->accessSVGExtensions() : 0);
+            if (extensions) {
+                if (extensions->hasGenericContext<SVGAnimatedString>(obj.get()))
+                    ASSERT(extensions->genericContext<SVGAnimatedString>(obj.get()) == imp);
+                else
+                    extensions->setGenericContext<SVGAnimatedString>(obj.get(), imp);
+            }
+        }
+
+        return toJS(exec, obj.get());
+    }
+    case StyleAttrNum: {
+        SVGGElement* imp = static_cast<SVGGElement*>(impl());
+
+        return toJS(exec, WTF::getPtr(imp->style()));
+    }
+    case TransformAttrNum: {
+        SVGGElement* imp = static_cast<SVGGElement*>(impl());
+
+        ASSERT(exec && exec->dynamicInterpreter());
+
+        RefPtr<SVGAnimatedTransformList> obj = imp->transformAnimated();
+        Frame* activeFrame = static_cast<ScriptInterpreter*>(exec->dynamicInterpreter())->frame();
+        if (activeFrame) {
+            SVGDocumentExtensions* extensions = (activeFrame->document() ? activeFrame->document()->accessSVGExtensions() : 0);
+            if (extensions) {
+                if (extensions->hasGenericContext<SVGAnimatedTransformList>(obj.get()))
+                    ASSERT(extensions->genericContext<SVGAnimatedTransformList>(obj.get()) == imp);
+                else
+                    extensions->setGenericContext<SVGAnimatedTransformList>(obj.get(), imp);
+            }
+        }
+
+        return toJS(exec, obj.get());
+    }
+    case NearestViewportElementAttrNum: {
+        SVGGElement* imp = static_cast<SVGGElement*>(impl());
+
+        return toJS(exec, WTF::getPtr(imp->nearestViewportElement()));
+    }
+    case FarthestViewportElementAttrNum: {
+        SVGGElement* imp = static_cast<SVGGElement*>(impl());
+
+        return toJS(exec, WTF::getPtr(imp->farthestViewportElement()));
+    }
+    }
+    return 0;
+}
+
+void JSSVGGElement::put(ExecState* exec, const Identifier& propertyName, JSValue* value, int attr)
+{
+    lookupPut<JSSVGGElement, JSSVGElement>(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<SVGGElement*>(impl());
+
+        imp->setXmllang(value->toString(exec));
+        break;
+    }
+    case XmlspaceAttrNum: {
+        SVGGElement* imp = static_cast<SVGGElement*>(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<SVGGElement*>(static_cast<JSSVGGElement*>(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<FloatRect>(imp->getBBox()));
+        return result;
+    }
+    case JSSVGGElement::GetCTMFuncNum: {
+
+
+        KJS::JSValue* result = toJS(exec, new JSSVGPODTypeWrapper<AffineTransform>(imp->getCTM()));
+        return result;
+    }
+    case JSSVGGElement::GetScreenCTMFuncNum: {
+
+
+        KJS::JSValue* result = toJS(exec, new JSSVGPODTypeWrapper<AffineTransform>(imp->getScreenCTM()));
+        return result;
+    }
+    case JSSVGGElement::GetTransformToElementFuncNum: {
+        ExceptionCode ec = 0;
+        SVGElement* element = toSVGElement(args[0]);
+
+
+        KJS::JSValue* result = toJS(exec, new JSSVGPODTypeWrapper<AffineTransform>(imp->getTransformToElement(element, ec)));
+        setDOMException(exec, ec);
+        return result;
+    }
+    }
+    return 0;
+}
+
+}
+
+#endif // ENABLE(SVG)