X-Git-Url: https://git.saurik.com/apple/javascriptcore.git/blobdiff_plain/f9bf01c6616d5ddcf65b13b33cedf9e387ff7a63..HEAD:/runtime/JSNotAnObject.cpp diff --git a/runtime/JSNotAnObject.cpp b/runtime/JSNotAnObject.cpp index f4764e2..af4737e 100644 --- a/runtime/JSNotAnObject.cpp +++ b/runtime/JSNotAnObject.cpp @@ -10,7 +10,7 @@ * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. - * 3. Neither the name of Apple Computer, Inc. ("Apple") nor the names of + * 3. Neither the name of Apple Inc. ("Apple") nor the names of * its contributors may be used to endorse or promote products derived * from this software without specific prior written permission. * @@ -30,100 +30,59 @@ #include "config.h" #include "JSNotAnObject.h" -#include +#include "JSCInlines.h" namespace JSC { -ASSERT_CLASS_FITS_IN_CELL(JSNotAnObject); +STATIC_ASSERT_IS_TRIVIALLY_DESTRUCTIBLE(JSNotAnObject); -// JSValue methods -JSValue JSNotAnObject::toPrimitive(ExecState* exec, PreferredPrimitiveType) const -{ - ASSERT_UNUSED(exec, exec->hadException() && exec->exception() == m_exception); - return m_exception; -} - -bool JSNotAnObject::getPrimitiveNumber(ExecState* exec, double&, JSValue&) -{ - ASSERT_UNUSED(exec, exec->hadException() && exec->exception() == m_exception); - return false; -} +const ClassInfo JSNotAnObject::s_info = { "Object", &Base::s_info, 0, CREATE_METHOD_TABLE(JSNotAnObject) }; -bool JSNotAnObject::toBoolean(ExecState* exec) const -{ - ASSERT_UNUSED(exec, exec->hadException() && exec->exception() == m_exception); - return false; -} - -double JSNotAnObject::toNumber(ExecState* exec) const -{ - ASSERT_UNUSED(exec, exec->hadException() && exec->exception() == m_exception); - return NaN; -} - -UString JSNotAnObject::toString(ExecState* exec) const -{ - ASSERT_UNUSED(exec, exec->hadException() && exec->exception() == m_exception); - return ""; -} - -JSObject* JSNotAnObject::toObject(ExecState* exec) const -{ - ASSERT_UNUSED(exec, exec->hadException() && exec->exception() == m_exception); - return m_exception; -} - -// Marking -void JSNotAnObject::markChildren(MarkStack& markStack) +// JSValue methods +JSValue JSNotAnObject::defaultValue(const JSObject*, ExecState* exec, PreferredPrimitiveType) { - JSObject::markChildren(markStack); - markStack.append(m_exception); + ASSERT_UNUSED(exec, exec->hadException()); + return jsNumber(0); } // JSObject methods -bool JSNotAnObject::getOwnPropertySlot(ExecState* exec, const Identifier&, PropertySlot&) -{ - ASSERT_UNUSED(exec, exec->hadException() && exec->exception() == m_exception); - return false; -} - -bool JSNotAnObject::getOwnPropertySlot(ExecState* exec, unsigned, PropertySlot&) +bool JSNotAnObject::getOwnPropertySlot(JSObject*, ExecState* exec, PropertyName, PropertySlot&) { - ASSERT_UNUSED(exec, exec->hadException() && exec->exception() == m_exception); + ASSERT_UNUSED(exec, exec->hadException()); return false; } -bool JSNotAnObject::getOwnPropertyDescriptor(ExecState* exec, const Identifier&, PropertyDescriptor&) +bool JSNotAnObject::getOwnPropertySlotByIndex(JSObject*, ExecState* exec, unsigned, PropertySlot&) { - ASSERT_UNUSED(exec, exec->hadException() && exec->exception() == m_exception); + ASSERT_UNUSED(exec, exec->hadException()); return false; } -void JSNotAnObject::put(ExecState* exec, const Identifier& , JSValue, PutPropertySlot&) +void JSNotAnObject::put(JSCell*, ExecState* exec, PropertyName , JSValue, PutPropertySlot&) { - ASSERT_UNUSED(exec, exec->hadException() && exec->exception() == m_exception); + ASSERT_UNUSED(exec, exec->hadException()); } -void JSNotAnObject::put(ExecState* exec, unsigned, JSValue) +void JSNotAnObject::putByIndex(JSCell*, ExecState* exec, unsigned, JSValue, bool) { - ASSERT_UNUSED(exec, exec->hadException() && exec->exception() == m_exception); + ASSERT_UNUSED(exec, exec->hadException()); } -bool JSNotAnObject::deleteProperty(ExecState* exec, const Identifier&) +bool JSNotAnObject::deleteProperty(JSCell*, ExecState* exec, PropertyName) { - ASSERT_UNUSED(exec, exec->hadException() && exec->exception() == m_exception); + ASSERT_UNUSED(exec, exec->hadException()); return false; } -bool JSNotAnObject::deleteProperty(ExecState* exec, unsigned) +bool JSNotAnObject::deletePropertyByIndex(JSCell*, ExecState* exec, unsigned) { - ASSERT_UNUSED(exec, exec->hadException() && exec->exception() == m_exception); + ASSERT_UNUSED(exec, exec->hadException()); return false; } -void JSNotAnObject::getOwnPropertyNames(ExecState* exec, PropertyNameArray&, EnumerationMode) +void JSNotAnObject::getOwnPropertyNames(JSObject*, ExecState* exec, PropertyNameArray&, EnumerationMode) { - ASSERT_UNUSED(exec, exec->hadException() && exec->exception() == m_exception); + ASSERT_UNUSED(exec, exec->hadException()); } } // namespace JSC