]>
git.saurik.com Git - apple/javascriptcore.git/blob - qt/api/qscriptvalue.cpp
f692817439274ee5cc1a220e2c84b7ff8d85d5e0
2 Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies)
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.
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.
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.
22 #include "qscriptvalue.h"
24 #include "qscriptengine.h"
25 #include "qscriptengine_p.h"
26 #include "qscriptvalue_p.h"
27 #include <QtCore/qdebug.h>
30 Constructs an invalid value.
32 QScriptValue::QScriptValue()
33 : d_ptr(new QScriptValuePrivate())
38 Constructs a new QScriptValue with a boolean \a value.
40 QScriptValue::QScriptValue(bool value
)
41 : d_ptr(new QScriptValuePrivate(value
))
46 Constructs a new QScriptValue with a number \a value.
48 QScriptValue::QScriptValue(int value
)
49 : d_ptr(new QScriptValuePrivate(value
))
54 Constructs a new QScriptValue with a number \a value.
56 QScriptValue::QScriptValue(uint value
)
57 : d_ptr(new QScriptValuePrivate(value
))
62 Constructs a new QScriptValue with a number \a value.
64 QScriptValue::QScriptValue(qsreal value
)
65 : d_ptr(new QScriptValuePrivate(value
))
70 Constructs a new QScriptValue with a string \a value.
72 QScriptValue::QScriptValue(const QString
& value
)
73 : d_ptr(new QScriptValuePrivate(value
))
78 Constructs a new QScriptValue with a special \a value.
80 QScriptValue::QScriptValue(SpecialValue value
)
81 : d_ptr(new QScriptValuePrivate(value
))
86 Constructs a new QScriptValue with a string \a value.
88 QScriptValue::QScriptValue(const char* value
)
89 : d_ptr(new QScriptValuePrivate(QString::fromUtf8(value
)))
94 Block automatic convertion to bool
97 QScriptValue::QScriptValue(void* d
)
103 Constructs a new QScriptValue from private
106 QScriptValue::QScriptValue(QScriptValuePrivate
* d
)
114 Constructs a new QScriptValue with the boolean \a value and
115 registers it with the script \a engine.
117 QScriptValue::QScriptValue(QScriptEngine
* engine
, bool value
)
120 d_ptr
= new QScriptValuePrivate(QScriptEnginePrivate::get(engine
), value
);
122 d_ptr
= new QScriptValuePrivate(value
);
128 Constructs a new QScriptValue with the integer \a value and
129 registers it with the script \a engine.
131 QScriptValue::QScriptValue(QScriptEngine
* engine
, int value
)
134 d_ptr
= new QScriptValuePrivate(QScriptEnginePrivate::get(engine
), value
);
136 d_ptr
= new QScriptValuePrivate(value
);
142 Constructs a new QScriptValue with the unsigned integer \a value and
143 registers it with the script \a engine.
145 QScriptValue::QScriptValue(QScriptEngine
* engine
, uint value
)
148 d_ptr
= new QScriptValuePrivate(QScriptEnginePrivate::get(engine
), value
);
150 d_ptr
= new QScriptValuePrivate(value
);
156 Constructs a new QScriptValue with the qsreal \a value and
157 registers it with the script \a engine.
159 QScriptValue::QScriptValue(QScriptEngine
* engine
, qsreal value
)
162 d_ptr
= new QScriptValuePrivate(QScriptEnginePrivate::get(engine
), value
);
164 d_ptr
= new QScriptValuePrivate(value
);
170 Constructs a new QScriptValue with the string \a value and
171 registers it with the script \a engine.
173 QScriptValue::QScriptValue(QScriptEngine
* engine
, const QString
& value
)
176 d_ptr
= new QScriptValuePrivate(QScriptEnginePrivate::get(engine
), value
);
178 d_ptr
= new QScriptValuePrivate(value
);
184 Constructs a new QScriptValue with the string \a value and
185 registers it with the script \a engine.
187 QScriptValue::QScriptValue(QScriptEngine
* engine
, const char* value
)
190 d_ptr
= new QScriptValuePrivate(QScriptEnginePrivate::get(engine
), QString::fromUtf8(value
));
192 d_ptr
= new QScriptValuePrivate(QString::fromUtf8(value
));
198 Constructs a new QScriptValue with the special \a value and
199 registers it with the script \a engine.
201 QScriptValue::QScriptValue(QScriptEngine
* engine
, SpecialValue value
)
204 d_ptr
= new QScriptValuePrivate(QScriptEnginePrivate::get(engine
), value
);
206 d_ptr
= new QScriptValuePrivate(value
);
210 Constructs a new QScriptValue that is a copy of \a other.
212 Note that if \a other is an object (i.e., isObject() would return
213 true), then only a reference to the underlying object is copied into
214 the new script value (i.e., the object itself is not copied).
216 QScriptValue::QScriptValue(const QScriptValue
& other
)
222 Destroys this QScriptValue.
224 QScriptValue::~QScriptValue()
229 Returns true if this QScriptValue is valid; otherwise returns
232 bool QScriptValue::isValid() const
234 return d_ptr
->isValid();
238 Returns true if this QScriptValue is of the primitive type Boolean;
239 otherwise returns false.
243 bool QScriptValue::isBool() const
245 return d_ptr
->isBool();
251 Use isBool() instead.
252 Returns true if this QScriptValue is of the primitive type Boolean;
253 otherwise returns false.
255 bool QScriptValue::isBoolean() const
257 return d_ptr
->isBool();
261 Returns true if this QScriptValue is of the primitive type Number;
262 otherwise returns false.
266 bool QScriptValue::isNumber() const
268 return d_ptr
->isNumber();
272 Returns true if this QScriptValue is of the primitive type Null;
273 otherwise returns false.
275 \sa QScriptEngine::nullValue()
277 bool QScriptValue::isNull() const
279 return d_ptr
->isNull();
283 Returns true if this QScriptValue is of the primitive type String;
284 otherwise returns false.
288 bool QScriptValue::isString() const
290 return d_ptr
->isString();
294 Returns true if this QScriptValue is of the primitive type Undefined;
295 otherwise returns false.
297 \sa QScriptEngine::undefinedValue()
299 bool QScriptValue::isUndefined() const
301 return d_ptr
->isUndefined();
305 Returns true if this QScriptValue is an object of the Error class;
306 otherwise returns false.
308 \sa QScriptContext::throwError()
310 bool QScriptValue::isError() const
312 return d_ptr
->isError();
316 Returns true if this QScriptValue is of the Object type; otherwise
319 Note that function values, variant values, and QObject values are
320 objects, so this function returns true for such values.
322 \sa toObject(), QScriptEngine::newObject()
324 bool QScriptValue::isObject() const
326 return d_ptr
->isObject();
330 Returns true if this QScriptValue is a function; otherwise returns
335 bool QScriptValue::isFunction() const
337 return d_ptr
->isFunction();
341 Returns the string value of this QScriptValue, as defined in
342 \l{ECMA-262} section 9.8, "ToString".
344 Note that if this QScriptValue is an object, calling this function
345 has side effects on the script engine, since the engine will call
346 the object's toString() function (and possibly valueOf()) in an
347 attempt to convert the object to a primitive value (possibly
348 resulting in an uncaught script exception).
352 QString
QScriptValue::toString() const
354 return d_ptr
->toString();
358 Returns the number value of this QScriptValue, as defined in
359 \l{ECMA-262} section 9.3, "ToNumber".
361 Note that if this QScriptValue is an object, calling this function
362 has side effects on the script engine, since the engine will call
363 the object's valueOf() function (and possibly toString()) in an
364 attempt to convert the object to a primitive value (possibly
365 resulting in an uncaught script exception).
367 \sa isNumber(), toInteger(), toInt32(), toUInt32(), toUInt16()
369 qsreal
QScriptValue::toNumber() const
371 return d_ptr
->toNumber();
375 Returns the boolean value of this QScriptValue, using the conversion
376 rules described in \l{ECMA-262} section 9.2, "ToBoolean".
378 Note that if this QScriptValue is an object, calling this function
379 has side effects on the script engine, since the engine will call
380 the object's valueOf() function (and possibly toString()) in an
381 attempt to convert the object to a primitive value (possibly
382 resulting in an uncaught script exception).
386 bool QScriptValue::toBool() const
388 return d_ptr
->toBool();
394 Use toBool() instead.
396 bool QScriptValue::toBoolean() const
398 return d_ptr
->toBool();
402 Returns the integer value of this QScriptValue, using the conversion
403 rules described in \l{ECMA-262} section 9.4, "ToInteger".
405 Note that if this QScriptValue is an object, calling this function
406 has side effects on the script engine, since the engine will call
407 the object's valueOf() function (and possibly toString()) in an
408 attempt to convert the object to a primitive value (possibly
409 resulting in an uncaught script exception).
413 qsreal
QScriptValue::toInteger() const
415 return d_ptr
->toInteger();
419 Returns the signed 32-bit integer value of this QScriptValue, using
420 the conversion rules described in \l{ECMA-262} section 9.5, "ToInt32".
422 Note that if this QScriptValue is an object, calling this function
423 has side effects on the script engine, since the engine will call
424 the object's valueOf() function (and possibly toString()) in an
425 attempt to convert the object to a primitive value (possibly
426 resulting in an uncaught script exception).
428 \sa toNumber(), toUInt32()
430 qint32
QScriptValue::toInt32() const
432 return d_ptr
->toInt32();
436 Returns the unsigned 32-bit integer value of this QScriptValue, using
437 the conversion rules described in \l{ECMA-262} section 9.6, "ToUint32".
439 Note that if this QScriptValue is an object, calling this function
440 has side effects on the script engine, since the engine will call
441 the object's valueOf() function (and possibly toString()) in an
442 attempt to convert the object to a primitive value (possibly
443 resulting in an uncaught script exception).
445 \sa toNumber(), toInt32()
447 quint32
QScriptValue::toUInt32() const
449 return d_ptr
->toUInt32();
453 Returns the unsigned 16-bit integer value of this QScriptValue, using
454 the conversion rules described in \l{ECMA-262} section 9.7, "ToUint16".
456 Note that if this QScriptValue is an object, calling this function
457 has side effects on the script engine, since the engine will call
458 the object's valueOf() function (and possibly toString()) in an
459 attempt to convert the object to a primitive value (possibly
460 resulting in an uncaught script exception).
464 quint16
QScriptValue::toUInt16() const
466 return d_ptr
->toUInt16();
470 Calls this QScriptValue as a function, using \a thisObject as
471 the `this' object in the function call, and passing \a args
472 as arguments to the function. Returns the value returned from
475 If this QScriptValue is not a function, call() does nothing
476 and returns an invalid QScriptValue.
478 Note that if \a thisObject is not an object, the global object
479 (see \l{QScriptEngine::globalObject()}) will be used as the
482 Calling call() can cause an exception to occur in the script engine;
483 in that case, call() returns the value that was thrown (typically an
484 \c{Error} object). You can call
485 QScriptEngine::hasUncaughtException() to determine if an exception
488 \snippet doc/src/snippets/code/src_script_qscriptvalue.cpp 2
492 QScriptValue
QScriptValue::call(const QScriptValue
& thisObject
, const QScriptValueList
& args
)
494 return d_ptr
->call(thisObject
.d_ptr
.data(), args
);
498 Returns the QScriptEngine that created this QScriptValue,
499 or 0 if this QScriptValue is invalid or the value is not
500 associated with a particular engine.
502 QScriptEngine
* QScriptValue::engine() const
504 QScriptEnginePrivate
* engine
= d_ptr
->engine();
506 return QScriptEnginePrivate::get(engine
);
511 Assigns the \a other value to this QScriptValue.
513 Note that if \a other is an object (isObject() returns true),
514 only a reference to the underlying object will be assigned;
515 the object itself will not be copied.
517 QScriptValue
& QScriptValue::operator=(const QScriptValue
& other
)
524 Returns true if this QScriptValue is equal to \a other, otherwise
525 returns false. The comparison follows the behavior described in
526 \l{ECMA-262} section 11.9.3, "The Abstract Equality Comparison
529 This function can return true even if the type of this QScriptValue
530 is different from the type of the \a other value; i.e. the
531 comparison is not strict. For example, comparing the number 9 to
532 the string "9" returns true; comparing an undefined value to a null
533 value returns true; comparing a \c{Number} object whose primitive
534 value is 6 to a \c{String} object whose primitive value is "6"
535 returns true; and comparing the number 1 to the boolean value
536 \c{true} returns true. If you want to perform a comparison
537 without such implicit value conversion, use strictlyEquals().
539 Note that if this QScriptValue or the \a other value are objects,
540 calling this function has side effects on the script engine, since
541 the engine will call the object's valueOf() function (and possibly
542 toString()) in an attempt to convert the object to a primitive value
543 (possibly resulting in an uncaught script exception).
545 \sa strictlyEquals(), lessThan()
547 bool QScriptValue::equals(const QScriptValue
& other
) const
549 return d_ptr
== other
.d_ptr
|| d_ptr
->equals(QScriptValuePrivate::get(other
));
553 Returns true if this QScriptValue is equal to \a other using strict
554 comparison (no conversion), otherwise returns false. The comparison
555 follows the behavior described in \l{ECMA-262} section 11.9.6, "The
556 Strict Equality Comparison Algorithm".
558 If the type of this QScriptValue is different from the type of the
559 \a other value, this function returns false. If the types are equal,
560 the result depends on the type, as shown in the following table:
563 \header \o Type \o Result
564 \row \o Undefined \o true
566 \row \o Boolean \o true if both values are true, false otherwise
567 \row \o Number \o false if either value is NaN (Not-a-Number); true if values are equal, false otherwise
568 \row \o String \o true if both values are exactly the same sequence of characters, false otherwise
569 \row \o Object \o true if both values refer to the same object, false otherwise
574 bool QScriptValue::strictlyEquals(const QScriptValue
& other
) const
576 return d_ptr
== other
.d_ptr
|| d_ptr
->strictlyEquals(QScriptValuePrivate::get(other
));