You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
tdelibs/kjs/error_object.cpp

193 lines
5.7 KiB

// -*- 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();
}