summaryrefslogtreecommitdiffstats
path: root/src/declarative/qml
diff options
context:
space:
mode:
authorWarwick Allison <warwick.allison@nokia.com>2009-09-10 00:19:33 (GMT)
committerWarwick Allison <warwick.allison@nokia.com>2009-09-10 00:19:33 (GMT)
commita250db23c96fc1ec47ea4d19d62a19cad7c50b46 (patch)
tree640237f325d4a734ecc42c042812a497c7a1f190 /src/declarative/qml
parentd3bd0567fbc16263fcb181d58529e6d7aeee1bbd (diff)
downloadQt-a250db23c96fc1ec47ea4d19d62a19cad7c50b46.zip
Qt-a250db23c96fc1ec47ea4d19d62a19cad7c50b46.tar.gz
Qt-a250db23c96fc1ec47ea4d19d62a19cad7c50b46.tar.bz2
Report custom parse errors verbosely.
Diffstat (limited to 'src/declarative/qml')
-rw-r--r--src/declarative/qml/qmlcompiler.cpp11
-rw-r--r--src/declarative/qml/qmlcustomparser.cpp51
-rw-r--r--src/declarative/qml/qmlcustomparser_p.h19
-rw-r--r--src/declarative/qml/qmlcustomparser_p_p.h9
4 files changed, 71 insertions, 19 deletions
diff --git a/src/declarative/qml/qmlcompiler.cpp b/src/declarative/qml/qmlcompiler.cpp
index b8e9d47..f02dad5 100644
--- a/src/declarative/qml/qmlcompiler.cpp
+++ b/src/declarative/qml/qmlcompiler.cpp
@@ -761,12 +761,13 @@ bool QmlCompiler::buildObject(Object *obj, const BindingContext &ctxt)
// Compile custom parser parts
if (isCustomParser && !customProps.isEmpty()) {
- // ### Check for failure
- bool ok = false;
QmlCustomParser *cp = output->types.at(obj->type).type->customParser();
- obj->custom = cp->compile(customProps, &ok);
- if(!ok)
- COMPILE_EXCEPTION(obj, "Failure compiling custom type");
+ cp->clearErrors();
+ obj->custom = cp->compile(customProps);
+ foreach (QmlError err, cp->errors()) {
+ err.setUrl(output->url);
+ exceptions << err;
+ }
}
return true;
diff --git a/src/declarative/qml/qmlcustomparser.cpp b/src/declarative/qml/qmlcustomparser.cpp
index b543978..dbcbeb1 100644
--- a/src/declarative/qml/qmlcustomparser.cpp
+++ b/src/declarative/qml/qmlcustomparser.cpp
@@ -70,7 +70,7 @@ using namespace QmlParser;
*/
/*
- \fn QByteArray QmlCustomParser::compile(QXmlStreamReader& reader, bool *ok)
+ \fn QByteArray QmlCustomParser::compile(QXmlStreamReader& reader)
Upon entry to this function, \a reader is positioned on a
QXmlStreamReader::StartElement with the name specified when the
@@ -80,7 +80,7 @@ using namespace QmlParser;
EndElement matching the initial start element is reached, or until
error.
- On return, \c *ok indicates success.
+ Errors must be reported via the error() functions.
The returned QByteArray contains data meaningful only to the
custom parser; the type engine will pass this same data to
@@ -109,6 +109,7 @@ QmlCustomParserNodePrivate::fromObject(QmlParser::Object *root)
{
QmlCustomParserNode rootNode;
rootNode.d->name = root->typeName;
+ rootNode.d->location = root->location.start;
for(QHash<QByteArray, Property *>::Iterator iter = root->properties.begin();
iter != root->properties.end();
@@ -128,6 +129,7 @@ QmlCustomParserNodePrivate::fromProperty(QmlParser::Property *p)
QmlCustomParserProperty prop;
prop.d->name = p->name;
prop.d->isList = (p->values.count() > 1);
+ prop.d->location = p->location.start;
if (p->value) {
QmlCustomParserNode node = fromObject(p->value);
@@ -167,6 +169,7 @@ QmlCustomParserNode &QmlCustomParserNode::operator=(const QmlCustomParserNode &o
{
d->name = other.d->name;
d->properties = other.d->properties;
+ d->location = other.d->location;
return *this;
}
@@ -185,6 +188,11 @@ QList<QmlCustomParserProperty> QmlCustomParserNode::properties() const
return d->properties;
}
+QmlParser::Location QmlCustomParserNode::location() const
+{
+ return d->location;
+}
+
QmlCustomParserProperty::QmlCustomParserProperty()
: d(new QmlCustomParserPropertyPrivate)
{
@@ -201,6 +209,7 @@ QmlCustomParserProperty &QmlCustomParserProperty::operator=(const QmlCustomParse
d->name = other.d->name;
d->isList = other.d->isList;
d->values = other.d->values;
+ d->location = other.d->location;
return *this;
}
@@ -219,19 +228,49 @@ bool QmlCustomParserProperty::isList() const
return d->isList;
}
+QmlParser::Location QmlCustomParserProperty::location() const
+{
+ return d->location;
+}
+
QList<QVariant> QmlCustomParserProperty::assignedValues() const
{
return d->values;
}
-QByteArray QmlCustomParser::compile(const QList<QmlCustomParserProperty> &, bool *ok)
+void QmlCustomParser::clearErrors()
{
- Q_UNUSED(ok);
- return QByteArray();
+ exceptions.clear();
}
-void QmlCustomParser::setCustomData(QObject *, const QByteArray &)
+/*!
+ Reports an error in parsing \a prop, with the given \a description.
+
+ An error is generated referring to the position of \a node in the source file.
+*/
+void QmlCustomParser::error(const QmlCustomParserProperty& prop, const QString& description)
+{
+ QmlError error;
+ QString exceptionDescription;
+ error.setLine(prop.location().line);
+ error.setColumn(prop.location().column);
+ error.setDescription(description);
+ exceptions << error;
+}
+
+/*!
+ Reports an error in parsing \a node, with the given \a description.
+
+ An error is generated referring to the position of \a node in the source file.
+*/
+void QmlCustomParser::error(const QmlCustomParserNode& node, const QString& description)
{
+ QmlError error;
+ QString exceptionDescription;
+ error.setLine(node.location().line);
+ error.setColumn(node.location().column);
+ error.setDescription(description);
+ exceptions << error;
}
QT_END_NAMESPACE
diff --git a/src/declarative/qml/qmlcustomparser_p.h b/src/declarative/qml/qmlcustomparser_p.h
index 74bd15c..5be0680 100644
--- a/src/declarative/qml/qmlcustomparser_p.h
+++ b/src/declarative/qml/qmlcustomparser_p.h
@@ -57,6 +57,8 @@
#include <QtCore/qxmlstream.h>
#include <QtDeclarative/qfxglobal.h>
#include <QtDeclarative/qmlmetatype.h>
+#include <QtDeclarative/qmlerror.h>
+#include <private/qmlparser_p.h>
QT_BEGIN_HEADER
@@ -74,6 +76,7 @@ public:
~QmlCustomParserProperty();
QByteArray name() const;
+ QmlParser::Location location() const;
bool isList() const;
// Will be one of QmlParser::Variant, QmlCustomParserProperty or
@@ -96,6 +99,7 @@ public:
~QmlCustomParserNode();
QByteArray name() const;
+ QmlParser::Location location() const;
QList<QmlCustomParserProperty> properties() const;
@@ -109,8 +113,19 @@ class Q_DECLARATIVE_EXPORT QmlCustomParser
public:
virtual ~QmlCustomParser() {}
- virtual QByteArray compile(const QList<QmlCustomParserProperty> &, bool *ok);
- virtual void setCustomData(QObject *, const QByteArray &);
+ void clearErrors();
+
+ virtual QByteArray compile(const QList<QmlCustomParserProperty> &)=0;
+ virtual void setCustomData(QObject *, const QByteArray &)=0;
+
+ QList<QmlError> errors() const { return exceptions; }
+
+protected:
+ void error(const QmlCustomParserProperty&, const QString& description);
+ void error(const QmlCustomParserNode&, const QString& description);
+
+private:
+ QList<QmlError> exceptions;
};
#define QML_DEFINE_CUSTOM_TYPE(URI, VERSION_MAJ, VERSION_MIN_FROM, VERSION_MAJ_TO, NAME, TYPE, CUSTOMTYPE) \
template<> QmlPrivate::InstanceType QmlPrivate::Define<TYPE *,(VERSION_MAJ), (VERSION_MIN_FROM), (VERSION_MAJ_TO)>::instance(qmlRegisterCustomType<TYPE>(#URI, VERSION_MAJ, VERSION_MIN_FROM, VERSION_MAJ_TO, #NAME, #TYPE, new CUSTOMTYPE));
diff --git a/src/declarative/qml/qmlcustomparser_p_p.h b/src/declarative/qml/qmlcustomparser_p_p.h
index 0011c3b..25023d3 100644
--- a/src/declarative/qml/qmlcustomparser_p_p.h
+++ b/src/declarative/qml/qmlcustomparser_p_p.h
@@ -55,20 +55,16 @@
#include <QtCore/qglobal.h>
#include "qmlcustomparser_p.h"
+#include "qmlparser_p.h"
QT_BEGIN_NAMESPACE
-namespace QmlParser
-{
- class Object;
- class Property;
-};
-
class QmlCustomParserNodePrivate
{
public:
QByteArray name;
QList<QmlCustomParserProperty> properties;
+ QmlParser::Location location;
static QmlCustomParserNode fromObject(QmlParser::Object *);
static QmlCustomParserProperty fromProperty(QmlParser::Property *);
@@ -82,6 +78,7 @@ public:
QByteArray name;
bool isList;
+ QmlParser::Location location;
QList<QVariant> values;
};