/* Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies) This library is free software; you can redistribute it and/or modify it under the terms of the GNU Library 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 Library General Public License for more details. You should have received a copy of the GNU Library General Public License along with this library; see the file COPYING.LIB. If not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ #include "config.h" #include "qscriptstring.h" #include "qscriptstring_p.h" #include /*! Constructs an invalid QScriptString. */ QScriptString::QScriptString() : d_ptr(new QScriptStringPrivate()) { } /*! Constructs an QScriptString from internal representation \internal */ QScriptString::QScriptString(QScriptStringPrivate* d) : d_ptr(d) { } /*! Constructs a new QScriptString that is a copy of \a other. */ QScriptString::QScriptString(const QScriptString& other) { d_ptr = other.d_ptr; } /*! Destroys this QScriptString. */ QScriptString::~QScriptString() { } /*! Assigns the \a other value to this QScriptString. */ QScriptString& QScriptString::operator=(const QScriptString& other) { d_ptr = other.d_ptr; return *this; } /*! Returns true if this QScriptString is valid; otherwise returns false. */ bool QScriptString::isValid() const { return d_ptr->isValid(); } /*! Returns true if this QScriptString is equal to \a other; otherwise returns false. */ bool QScriptString::operator==(const QScriptString& other) const { return d_ptr == other.d_ptr || *d_ptr == *(other.d_ptr); } /*! Returns true if this QScriptString is not equal to \a other; otherwise returns false. */ bool QScriptString::operator!=(const QScriptString& other) const { return d_ptr != other.d_ptr || *d_ptr != *(other.d_ptr); } /*! Attempts to convert this QScriptString to a QtScript array index, and returns the result. If a conversion error occurs, *\a{ok} is set to false; otherwise *\a{ok} is set to true. */ quint32 QScriptString::toArrayIndex(bool* ok) const { return d_ptr->toArrayIndex(ok); } /*! Returns the string that this QScriptString represents, or a null string if this QScriptString is not valid. \sa isValid() */ QString QScriptString::toString() const { return d_ptr->toString(); } /*! Returns the string that this QScriptString represents, or a null string if this QScriptString is not valid. \sa toString() */ QScriptString::operator QString() const { return d_ptr->toString(); } uint qHash(const QScriptString& key) { return qHash(QScriptStringPrivate::get(key)->id()); }