From 7ee1bc52423a75f792af92f4d34c76fc069f81c4 Mon Sep 17 00:00:00 2001
From: Erik Verbruggen <erik.verbruggen@nokia.com>
Date: Thu, 18 Feb 2010 14:24:46 +0100
Subject: [PATCH] Suppress 'unknown property' warning after finding an unknown
 type. And made the warnings/errors translatable.

---
 src/libs/qmljs/qmljscheck.cpp | 23 +++++++++++++++++------
 1 file changed, 17 insertions(+), 6 deletions(-)

diff --git a/src/libs/qmljs/qmljscheck.cpp b/src/libs/qmljs/qmljscheck.cpp
index b79a6495caa..9340ec4ee35 100644
--- a/src/libs/qmljs/qmljscheck.cpp
+++ b/src/libs/qmljs/qmljscheck.cpp
@@ -33,8 +33,20 @@
 #include "qmljsevaluate.h"
 #include "parser/qmljsast_p.h"
 
+#include <QtGui/QApplication>
 #include <QtCore/QDebug>
 
+namespace QmlJS {
+namespace Messages {
+static const char *invalidPropertyName =  QT_TRANSLATE_NOOP("QmlJS::Check", "'%1' is not a valid property name");
+static const char *unknownType = QT_TRANSLATE_NOOP("QmlJS::Check", "unknown type");
+} // namespace Messages
+
+static inline QString tr(const char *msg)
+{ return qApp->translate("QmlJS::Check", msg); }
+
+} // namespace QmlJS
+
 using namespace QmlJS;
 using namespace QmlJS::AST;
 using namespace QmlJS::Interpreter;
@@ -94,15 +106,15 @@ void Check::visitQmlObject(Node *ast, UiQualifiedId *typeId,
         return;
     }
 
+    const bool oldAllowAnyProperty = _allowAnyProperty;
+
     if (! _context.lookupType(_doc.data(), typeId)) {
-        warning(typeId->identifierToken, QLatin1String("unknown type"));
-        // ### don't give up!
-        return;
+        warning(typeId->identifierToken, tr(Messages::unknownType));
+        _allowAnyProperty = true; // suppress subsequent "unknown property" errors
     }
 
     const ObjectValue *oldScopeObject = _context.qmlScopeObject();
     const ObjectValue *oldExtraScope = _extraScope;
-    const bool oldAllowAnyProperty = _allowAnyProperty;
     const ObjectValue *scopeObject = _doc->bind()->findQmlObject(ast);
     _context.setQmlScopeObject(scopeObject);
 
@@ -205,8 +217,7 @@ void Check::checkScopeObjectMember(const UiQualifiedId *id)
         value = _extraScope->lookupMember(propertyName, &_context);
     if (!value) {
         error(id->identifierToken,
-              QString("'%1' is not a valid property name").arg(propertyName));
-        return;
+              tr(Messages::invalidPropertyName).arg(propertyName));
     }
 
     // can't look up members for attached properties
-- 
GitLab