JavaScriptCore:
[WebKit-https.git] / WebCore / bindings / js / JSSVGMatrixCustom.cpp
1 /*
2  * Copyright (C) 2006, 2007, 2008 Nikolas Zimmermann <zimmermann@kde.org>
3  *
4  * This library is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU Library General Public
6  * License as published by the Free Software Foundation; either
7  * version 2 of the License, or (at your option) any later version.
8  *
9  * This library is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12  * Library General Public License for more details.
13  *
14  * You should have received a copy of the GNU Library General Public License
15  * along with this library; see the file COPYING.LIB.  If not, write to
16  * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
17  * Boston, MA 02110-1301, USA.
18  */
19
20 #include "config.h"
21
22 #if ENABLE(SVG)
23 #include "JSSVGMatrix.h"
24
25 #include "TransformationMatrix.h"
26 #include "SVGException.h"
27
28 using namespace JSC;
29
30 namespace WebCore {
31
32 JSValuePtr JSSVGMatrix::multiply(ExecState* exec, const ArgList& args)
33 {
34     TransformationMatrix imp(*impl());
35
36     TransformationMatrix secondMatrix = toSVGMatrix(args.at(exec, 0));    
37     return toJS(exec, JSSVGStaticPODTypeWrapper<TransformationMatrix>::create(imp.multiply(secondMatrix)).get(), m_context.get());
38 }
39
40 JSValuePtr JSSVGMatrix::inverse(ExecState* exec, const ArgList&)
41 {
42     TransformationMatrix imp(*impl());
43     JSC::JSValuePtr result = toJS(exec, JSSVGStaticPODTypeWrapper<TransformationMatrix>::create(imp.inverse()).get(), m_context.get());
44
45     if (!imp.isInvertible())
46         setDOMException(exec, SVGException::SVG_MATRIX_NOT_INVERTABLE);
47
48     return result;
49 }
50
51 JSValuePtr JSSVGMatrix::translate(ExecState* exec, const ArgList& args)
52 {
53     TransformationMatrix imp(*impl());
54
55     float x = args.at(exec, 0).toFloat(exec);
56     float y = args.at(exec, 1).toFloat(exec);
57
58     return toJS(exec, JSSVGStaticPODTypeWrapper<TransformationMatrix>::create(imp.translate(x, y)).get(), m_context.get());
59 }
60
61 JSValuePtr JSSVGMatrix::scale(ExecState* exec, const ArgList& args)
62 {
63     TransformationMatrix imp(*impl());
64
65     float scaleFactor = args.at(exec, 0).toFloat(exec);
66     return toJS(exec, JSSVGStaticPODTypeWrapper<TransformationMatrix>::create(imp.scale(scaleFactor)).get(), m_context.get());
67 }
68
69 JSValuePtr JSSVGMatrix::scaleNonUniform(ExecState* exec, const ArgList& args)
70 {
71     TransformationMatrix imp(*impl());
72
73     float scaleFactorX = args.at(exec, 0).toFloat(exec);
74     float scaleFactorY = args.at(exec, 1).toFloat(exec);
75
76     return toJS(exec, JSSVGStaticPODTypeWrapper<TransformationMatrix>::create(imp.scaleNonUniform(scaleFactorX, scaleFactorY)).get(), m_context.get());
77 }
78
79 JSValuePtr JSSVGMatrix::rotate(ExecState* exec, const ArgList& args)
80 {
81     TransformationMatrix imp(*impl());
82
83     float angle = args.at(exec, 0).toFloat(exec);
84     return toJS(exec, JSSVGStaticPODTypeWrapper<TransformationMatrix>::create(imp.rotate(angle)).get(), m_context.get());
85 }
86
87 JSValuePtr JSSVGMatrix::rotateFromVector(ExecState* exec, const ArgList& args)
88 {
89     TransformationMatrix imp(*impl());
90  
91     float x = args.at(exec, 0).toFloat(exec);
92     float y = args.at(exec, 1).toFloat(exec);
93
94     JSC::JSValuePtr result = toJS(exec, JSSVGStaticPODTypeWrapper<TransformationMatrix>::create(imp.rotateFromVector(x, y)).get(), m_context.get());
95
96     if (x == 0.0 || y == 0.0)
97         setDOMException(exec, SVGException::SVG_INVALID_VALUE_ERR);
98
99     return result;
100 }
101
102 JSValuePtr JSSVGMatrix::flipX(ExecState* exec, const ArgList&)
103 {
104     TransformationMatrix imp(*impl());
105     return toJS(exec, JSSVGStaticPODTypeWrapper<TransformationMatrix>::create(imp.flipX()).get(), m_context.get());
106 }
107
108 JSValuePtr JSSVGMatrix::flipY(ExecState* exec, const ArgList&)
109 {
110     TransformationMatrix imp(*impl());
111     return toJS(exec, JSSVGStaticPODTypeWrapper<TransformationMatrix>::create(imp.flipY()).get(), m_context.get());
112 }
113
114 JSValuePtr JSSVGMatrix::skewX(ExecState* exec, const ArgList& args)
115 {
116     TransformationMatrix imp(*impl());
117
118     float angle = args.at(exec, 0).toFloat(exec);
119     return toJS(exec, JSSVGStaticPODTypeWrapper<TransformationMatrix>::create(imp.skewX(angle)).get(), m_context.get());
120 }
121
122 JSValuePtr JSSVGMatrix::skewY(ExecState* exec, const ArgList& args)
123 {
124     TransformationMatrix imp(*impl());
125
126     float angle = args.at(exec, 0).toFloat(exec);
127     return toJS(exec, JSSVGStaticPODTypeWrapper<TransformationMatrix>::create(imp.skewY(angle)).get(), m_context.get());
128 }
129
130 }
131
132 #endif // ENABLE(SVG)