/* Copyright (C) 2010 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 "qscriptsyntaxcheckresult.h" #include "qscriptsyntaxcheckresult_p.h" /*! \class QScriptSyntaxCheckResult \brief The QScriptSyntaxCheckResult class provides the result of a script syntax check. \ingroup script \mainclass QScriptSyntaxCheckResult is returned by QScriptEngine::checkSyntax() to provide information about the syntactical (in)correctness of a script. */ /*! \enum QScriptSyntaxCheckResult::State This enum specifies the state of a syntax check. \value Error The program contains a syntax error. \value Intermediate The program is incomplete. \value Valid The program is a syntactically correct Qt Script program. */ /*! Constructs a new QScriptSyntaxCheckResult from the \a other result. */ QScriptSyntaxCheckResult::QScriptSyntaxCheckResult(const QScriptSyntaxCheckResult& other) : d_ptr(other.d_ptr) {} /*! Constructs a new QScriptSyntaxCheckResult from an internal representation. \internal */ QScriptSyntaxCheckResult::QScriptSyntaxCheckResult(QScriptSyntaxCheckResultPrivate* d) : d_ptr(d) {} /*! Destroys this QScriptSyntaxCheckResult. */ QScriptSyntaxCheckResult::~QScriptSyntaxCheckResult() {} /*! Assigns the \a other result to this QScriptSyntaxCheckResult, and returns a reference to this QScriptSyntaxCheckResult. */ QScriptSyntaxCheckResult& QScriptSyntaxCheckResult::operator=(const QScriptSyntaxCheckResult& other) { d_ptr = other.d_ptr; return *this; } /*! Returns the state of this QScriptSyntaxCheckResult. */ QScriptSyntaxCheckResult::State QScriptSyntaxCheckResult::state() const { return d_ptr->state(); } /*! Returns the error line number of this QScriptSyntaxCheckResult, or -1 if there is no error. \sa state(), errorMessage() */ int QScriptSyntaxCheckResult::errorLineNumber() const { return d_ptr->errorLineNumber(); } /*! Returns the error column number of this QScriptSyntaxCheckResult, or -1 if there is no error. \sa state(), errorLineNumber() */ int QScriptSyntaxCheckResult::errorColumnNumber() const { return d_ptr->errorColumnNumber(); } /*! Returns the error message of this QScriptSyntaxCheckResult, or an empty string if there is no error. \sa state(), errorLineNumber() */ QString QScriptSyntaxCheckResult::errorMessage() const { return d_ptr->errorMessage(); } QScriptSyntaxCheckResultPrivate::~QScriptSyntaxCheckResultPrivate() { if (m_exception) JSValueUnprotect(*m_engine, m_exception); } QString QScriptSyntaxCheckResultPrivate::errorMessage() const { if (!m_exception) return QString(); JSStringRef tmp = JSValueToStringCopy(*m_engine, m_exception, /* exception */ 0); QString message = QScriptConverter::toString(tmp); JSStringRelease(tmp); return message; } int QScriptSyntaxCheckResultPrivate::errorLineNumber() const { if (!m_exception) return -1; // m_exception is an instance of the Exception so it has "line" attribute. JSStringRef lineAttrName = QScriptConverter::toString("line"); JSValueRef line = JSObjectGetProperty(*m_engine, m_exception, lineAttrName, /* exceptions */0); JSStringRelease(lineAttrName); return JSValueToNumber(*m_engine, line, /* exceptions */0); }