source: webkit/trunk/JavaScriptCore/kjs/reference.cpp@ 15310

Last change on this file since 15310 was 15225, checked in by ggaren, 19 years ago

Reviewed by Maciej.


  • Standardized which functions take a JSContext as an argument. The rule is: if you might execute JavaScript, you take a JSContext, otherwise you don't.


The FIXME in JSObjectRef.h requires refactoring some parts of Interpreter,
but not API changes, so I'm putting it off until later.

  • API/JSCallbackObject.cpp: (KJS::JSCallbackObject::JSCallbackObject): (KJS::JSCallbackObject::init):
  • API/JSCallbackObject.h:
  • API/JSContextRef.cpp: (JSContextCreate):
  • API/JSContextRef.h:
  • API/JSObjectRef.cpp: (JSObjectMake): (JSPropertyEnumeratorGetNext):
  • API/JSObjectRef.h:
  • API/testapi.c: (MyObject_initialize): (main):
  • JavaScriptCore.exp:
  • kjs/array_object.cpp: (ArrayInstance::setLength): (ArrayInstance::pushUndefinedObjectsToEnd):
  • kjs/nodes.cpp: (ForInNode::execute):
  • kjs/reference.cpp: (KJS::Reference::getPropertyName): (KJS::Reference::getValue):
  • kjs/reference.h:
  • kjs/scope_chain.cpp: (KJS::ScopeChain::print):
  • Property svn:eol-style set to native
File size: 2.4 KB
Line 
1// -*- c-basic-offset: 2 -*-
2/*
3 * This file is part of the KDE libraries
4 * Copyright (C) 2004 Apple Computer, Inc
5 *
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Library General Public
8 * License as published by the Free Software Foundation; either
9 * version 2 of the License, or (at your option) any later version.
10 *
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Library General Public License for more details.
15 *
16 * You should have received a copy of the GNU Library General Public License
17 * along with this library; see the file COPYING.LIB. If not, write to
18 * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
19 * Boston, MA 02110-1301, USA.
20 *
21 */
22
23#include "JSType.h"
24#include "config.h"
25#include "internal.h"
26#include "reference.h"
27
28namespace KJS {
29
30// ------------------------------ Reference ------------------------------------
31
32Reference::Reference(JSObject *b, const Identifier& p)
33 : base(b),
34 propertyNameIsNumber(false),
35 prop(p)
36{
37}
38
39Reference::Reference(JSObject *b, unsigned p)
40 : base(b),
41 propertyNameAsNumber(p),
42 propertyNameIsNumber(true)
43{
44}
45
46Identifier Reference::getPropertyName() const
47{
48 if (propertyNameIsNumber && prop.isNull())
49 prop = Identifier::from(propertyNameAsNumber);
50 return prop;
51}
52
53JSValue *Reference::getValue(ExecState *exec) const
54{
55 JSValue *o = base;
56 if (!o || !o->isObject()) {
57 if (!o || o->isNull())
58 return throwError(exec, ReferenceError, "Can't find variable: " + getPropertyName().ustring());
59 return throwError(exec, ReferenceError, "Base is not an object");
60 }
61
62 if (propertyNameIsNumber)
63 return static_cast<JSObject*>(o)->get(exec, propertyNameAsNumber);
64 return static_cast<JSObject*>(o)->get(exec, prop);
65}
66
67bool Reference::deleteValue(ExecState *exec)
68{
69 JSValue *o = base;
70 JSType t = o ? o->type() : NullType;
71
72 // The spec doesn't mention what to do if the base is null... just return true
73 if (t != ObjectType) {
74 assert(t == NullType);
75 return true;
76 }
77
78 if (propertyNameIsNumber)
79 return static_cast<JSObject*>(o)->deleteProperty(exec,propertyNameAsNumber);
80 return static_cast<JSObject*>(o)->deleteProperty(exec,prop);
81}
82
83}
Note: See TracBrowser for help on using the repository browser.