Make our bindings' GetOwnPropertySlot() behave according to specification
[WebKit-https.git] / Source / WebCore / bindings / js / JSHTMLOptionsCollectionCustom.cpp
1 /*
2  * Copyright (C) 2006, 2007, 2008 Apple Inc. All rights reserved.
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 #include "JSHTMLOptionsCollection.h"
22
23 #include "ExceptionCode.h"
24 #include "HTMLNames.h"
25 #include "HTMLOptionElement.h"
26 #include "HTMLOptionsCollection.h"
27 #include "HTMLSelectElement.h"
28 #include "JSHTMLOptionElement.h"
29 #include "JSHTMLSelectElement.h"
30 #include "JSHTMLSelectElementCustom.h"
31 #include "JSNodeList.h"
32 #include "StaticNodeList.h"
33
34 #include <wtf/MathExtras.h>
35
36 using namespace JSC;
37
38 namespace WebCore {
39
40 bool JSHTMLOptionsCollection::canGetItemsForName(ExecState*, HTMLOptionsCollection* collection, PropertyName propertyName)
41 {
42     return collection->hasNamedItem(propertyNameToAtomicString(propertyName));
43 }
44
45 EncodedJSValue JSHTMLOptionsCollection::nameGetter(ExecState* exec, JSObject* slotBase, EncodedJSValue, PropertyName propertyName)
46 {
47     JSHTMLCollection* collection = jsCast<JSHTMLCollection*>(slotBase);
48     const AtomicString& name = propertyNameToAtomicString(propertyName);
49     return JSValue::encode(toJS(exec, collection->globalObject(), collection->impl().namedItem(name)));
50 }
51
52 void JSHTMLOptionsCollection::setLength(ExecState* exec, JSValue value)
53 {
54     ExceptionCode ec = 0;
55     unsigned newLength = 0;
56     double lengthValue = value.toNumber(exec);
57     if (!std::isnan(lengthValue) && !std::isinf(lengthValue)) {
58         if (lengthValue < 0.0)
59             ec = INDEX_SIZE_ERR;
60         else if (lengthValue > static_cast<double>(UINT_MAX))
61             newLength = UINT_MAX;
62         else
63             newLength = static_cast<unsigned>(lengthValue);
64     }
65     if (!ec)
66         impl().setLength(newLength, ec);
67     setDOMException(exec, ec);
68 }
69
70 void JSHTMLOptionsCollection::indexSetter(ExecState* exec, unsigned index, JSValue value)
71 {
72     selectIndexSetter(&impl().selectElement(), exec, index, value);
73 }
74
75 JSValue JSHTMLOptionsCollection::remove(ExecState* exec)
76 {
77     // The argument can be an HTMLOptionElement or an index.
78     JSValue argument = exec->argument(0);
79     if (HTMLOptionElement* option = JSHTMLOptionElement::toWrapped(argument))
80         impl().remove(option);
81     else
82         impl().remove(argument.toInt32(exec));
83     return jsUndefined();
84 }
85
86 }