diff options
Diffstat (limited to 'kjs/error_object.cpp')
-rw-r--r-- | kjs/error_object.cpp | 192 |
1 files changed, 192 insertions, 0 deletions
diff --git a/kjs/error_object.cpp b/kjs/error_object.cpp new file mode 100644 index 000000000..1b2451489 --- /dev/null +++ b/kjs/error_object.cpp @@ -0,0 +1,192 @@ +// -*- c-basic-offset: 2 -*- +/* + * This file is part of the KDE libraries + * Copyright (C) 1999-2000 Harri Porten (porten@kde.org) + * Copyright (C) 2003 Apple Computer, Inc. + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser 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 + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + * + */ + +#include "value.h" +#include "object.h" +#include "types.h" +#include "interpreter.h" +#include "operations.h" +#include "error_object.h" +//#include "debugger.h" + +using namespace KJS; + +// ------------------------------ ErrorInstanceImp ---------------------------- + +const ClassInfo ErrorInstanceImp::info = {"Error", 0, 0, 0}; + +ErrorInstanceImp::ErrorInstanceImp(ObjectImp *proto) + : ObjectImp(proto) +{ +} + +// ------------------------------ ErrorPrototypeImp ---------------------------- + +// ECMA 15.9.4 +ErrorPrototypeImp::ErrorPrototypeImp(ExecState *exec, + ObjectPrototypeImp *objectProto, + FunctionPrototypeImp *funcProto) + : ObjectImp(objectProto) +{ + Value protect(this); + setInternalValue(Undefined()); + // The constructor will be added later in ErrorObjectImp's constructor + + put(exec, namePropertyName, String("Error"), DontEnum); + put(exec, messagePropertyName, String("Unknown error"), DontEnum); + putDirect(toStringPropertyName, new ErrorProtoFuncImp(exec,funcProto), DontEnum); +} + +// ------------------------------ ErrorProtoFuncImp ---------------------------- + +ErrorProtoFuncImp::ErrorProtoFuncImp(ExecState * /*exec*/, FunctionPrototypeImp *funcProto) + : InternalFunctionImp(funcProto) +{ + Value protect(this); + putDirect(lengthPropertyName, NumberImp::zero(), DontDelete|ReadOnly|DontEnum); + ident = "toString"; +} + +bool ErrorProtoFuncImp::implementsCall() const +{ + return true; +} + +Value ErrorProtoFuncImp::call(ExecState *exec, Object &thisObj, const List &/*args*/) +{ + // toString() + UString s = "Error"; + + Value v = thisObj.get(exec, namePropertyName); + if (v.type() != UndefinedType) { + s = v.toString(exec); + } + + v = thisObj.get(exec, messagePropertyName); + if (v.type() != UndefinedType) { + s += ": " + v.toString(exec); // Mozilla compatible format + } + + return String(s); +} + +// ------------------------------ ErrorObjectImp ------------------------------- + +ErrorObjectImp::ErrorObjectImp(ExecState * /*exec*/, FunctionPrototypeImp *funcProto, + ErrorPrototypeImp *errorProto) + : InternalFunctionImp(funcProto) +{ + Value protect(this); + // ECMA 15.11.3.1 Error.prototype + putDirect(prototypePropertyName, errorProto, DontEnum|DontDelete|ReadOnly); + putDirect(lengthPropertyName, NumberImp::one(), DontDelete|ReadOnly|DontEnum); + //putDirect(namePropertyName, String(n)); +} + +bool ErrorObjectImp::implementsConstruct() const +{ + return true; +} + +// ECMA 15.9.3 +Object ErrorObjectImp::construct(ExecState *exec, const List &args) +{ + Object proto = Object::dynamicCast(exec->lexicalInterpreter()->builtinErrorPrototype()); + ObjectImp *imp = new ErrorInstanceImp(proto.imp()); + Object obj(imp); + + if (!args.isEmpty() && args[0].type() != UndefinedType) { + imp->putDirect(messagePropertyName, new StringImp(args[0].toString(exec))); + } + + return obj; +} + +bool ErrorObjectImp::implementsCall() const +{ + return true; +} + +// ECMA 15.9.2 +Value ErrorObjectImp::call(ExecState *exec, Object &/*thisObj*/, const List &args) +{ + // "Error()" gives the sames result as "new Error()" + return construct(exec,args); +} + +// ------------------------------ NativeErrorPrototypeImp ---------------------- + +NativeErrorPrototypeImp::NativeErrorPrototypeImp(ExecState * /*exec*/, ErrorPrototypeImp *errorProto, + ErrorType et, UString name, UString message) + : ObjectImp(errorProto) +{ + Value protect(this); + errType = et; + putDirect(namePropertyName, new StringImp(name), 0); + putDirect(messagePropertyName, new StringImp(message), 0); +} + +// ------------------------------ NativeErrorImp ------------------------------- + +const ClassInfo NativeErrorImp::info = {"Function", &InternalFunctionImp::info, 0, 0}; + +NativeErrorImp::NativeErrorImp(ExecState * /*exec*/, FunctionPrototypeImp *funcProto, + const Object &prot) + : InternalFunctionImp(funcProto), proto(0) +{ + Value protect(this); + proto = static_cast<ObjectImp*>(prot.imp()); + + putDirect(lengthPropertyName, NumberImp::one(), DontDelete|ReadOnly|DontEnum); // ECMA 15.11.7.5 + putDirect(prototypePropertyName, proto, DontDelete|ReadOnly|DontEnum); +} + +bool NativeErrorImp::implementsConstruct() const +{ + return true; +} + +Object NativeErrorImp::construct(ExecState *exec, const List &args) +{ + ObjectImp *imp = new ErrorInstanceImp(proto); + Object obj(imp); + if (args[0].type() != UndefinedType) + imp->putDirect(messagePropertyName, new StringImp(args[0].toString(exec))); + return obj; +} + +bool NativeErrorImp::implementsCall() const +{ + return true; +} + +Value NativeErrorImp::call(ExecState *exec, Object &/*thisObj*/, const List &args) +{ + return construct(exec,args); +} + +void NativeErrorImp::mark() +{ + ObjectImp::mark(); + if (proto && !proto->marked()) + proto->mark(); +} |