From b44efd097b03a89d1df1fd77b871ff5a238f66c5 Mon Sep 17 00:00:00 2001
From: Friedemann Kleint <Friedemann.Kleint@nokia.com>
Date: Fri, 13 Aug 2010 11:10:11 +0200
Subject: [PATCH] Custom wizard: Add boolean 'enabled' attribute to <wizard>.

Reviewed-by: Kai Koehne <kai.koehne@nokia.com>
---
 .../customwizard/customwizard.cpp             |  9 +++--
 .../customwizard/customwizardparameters.cpp   | 33 ++++++++++++-------
 .../customwizard/customwizardparameters.h     | 10 +++---
 3 files changed, 34 insertions(+), 18 deletions(-)

diff --git a/src/plugins/projectexplorer/customwizard/customwizard.cpp b/src/plugins/projectexplorer/customwizard/customwizard.cpp
index b9c8e7e18a7..81a141e315a 100644
--- a/src/plugins/projectexplorer/customwizard/customwizard.cpp
+++ b/src/plugins/projectexplorer/customwizard/customwizard.cpp
@@ -331,13 +331,18 @@ QList<CustomWizard*> CustomWizard::createWizards()
         if (dir.exists(configFile)) {
             CustomWizardParametersPtr parameters(new Internal::CustomWizardParameters);
             Core::BaseFileWizardParameters baseFileParameters;
-            if (parameters->parse(dir.absoluteFilePath(configFile), &baseFileParameters, &errorMessage)) {
+            switch (parameters->parse(dir.absoluteFilePath(configFile), &baseFileParameters, &errorMessage)) {
+            case Internal::CustomWizardParameters::ParseOk:
                 parameters->directory = dir.absolutePath();
                 if (CustomWizardPrivate::verbose)
                     verboseLog += parameters->toString();
                 if (CustomWizard *w = createWizard(parameters, baseFileParameters))
                     rc.push_back(w);
-            } else {
+            case Internal::CustomWizardParameters::ParseDisabled:
+                if (CustomWizardPrivate::verbose)
+                    qWarning("Ignoring disabled wizard %s...", qPrintable(dir.absolutePath()));
+                break;
+            case Internal::CustomWizardParameters::ParseFailed:
                 qWarning("Failed to initialize custom project wizard in %s: %s",
                          qPrintable(dir.absolutePath()), qPrintable(errorMessage));
             }
diff --git a/src/plugins/projectexplorer/customwizard/customwizardparameters.cpp b/src/plugins/projectexplorer/customwizard/customwizardparameters.cpp
index 2f3d902c88e..034692039e3 100644
--- a/src/plugins/projectexplorer/customwizard/customwizardparameters.cpp
+++ b/src/plugins/projectexplorer/customwizard/customwizardparameters.cpp
@@ -48,6 +48,7 @@ static const char customWizardElementC[] = "wizard";
 static const char iconElementC[] = "icon";
 static const char descriptionElementC[] = "description";
 static const char displayNameElementC[] = "displayname";
+static const char wizardEnabledAttributeC[] = "enabled";
 static const char idAttributeC[] = "id";
 static const char kindAttributeC[] = "kind";
 static const char klassAttributeC[] = "class";
@@ -329,9 +330,13 @@ static inline QString msgError(const QXmlStreamReader &reader,
             arg(fileName).arg(reader.lineNumber()).arg(reader.columnNumber()).arg(what);
 }
 
-static inline bool booleanAttributeValue(const QXmlStreamReader &r, const char *name)
+static inline bool booleanAttributeValue(const QXmlStreamReader &r, const char *nameC,
+                                         bool defaultValue)
 {
-    return r.attributes().value(QLatin1String(name)) == QLatin1String("true");
+    const QStringRef attributeValue = r.attributes().value(QLatin1String(nameC));
+    if (attributeValue.isEmpty())
+        return defaultValue;
+    return attributeValue == QLatin1String("true");
 }
 
 static inline int integerAttributeValue(const QXmlStreamReader &r, const char *name, int defaultValue)
@@ -368,7 +373,8 @@ static inline QString localeLanguage()
 }
 
 // Main parsing routine
-bool CustomWizardParameters::parse(QIODevice &device,
+CustomWizardParameters::ParseResult
+     CustomWizardParameters::parse(QIODevice &device,
                                    const QString &configFileFullPath,
                                    Core::BaseFileWizardParameters *bp,
                                    QString *errorMessage)
@@ -386,7 +392,7 @@ bool CustomWizardParameters::parse(QIODevice &device,
         switch (token) {
         case QXmlStreamReader::Invalid:
             *errorMessage = msgError(reader, configFileFullPath, reader.errorString());
-            return false;
+            return ParseFailed;
         case QXmlStreamReader::StartElement:
             do {
                 // Read out subelements applicable to current state
@@ -401,8 +407,10 @@ bool CustomWizardParameters::parse(QIODevice &device,
                 case ParseError:
                     *errorMessage = msgError(reader, configFileFullPath,
                                              QString::fromLatin1("Unexpected start element %1").arg(reader.name().toString()));
-                    return false;
+                    return ParseFailed;
                 case ParseWithinWizard:
+                    if (!booleanAttributeValue(reader, wizardEnabledAttributeC, true))
+                        return ParseDisabled;
                     bp->setId(attributeValue(reader, idAttributeC));
                     bp->setCategory(attributeValue(reader, categoryAttributeC));
                     bp->setKind(kindAttribute(reader));
@@ -411,14 +419,14 @@ bool CustomWizardParameters::parse(QIODevice &device,
                     break;
                 case ParseWithinField: // field attribute
                     field.name = attributeValue(reader, fieldNameAttributeC);
-                    field.mandatory = booleanAttributeValue(reader, fieldMandatoryAttributeC);
+                    field.mandatory = booleanAttributeValue(reader, fieldMandatoryAttributeC, false);
                     break;
                 case ParseWithinFile: { // file attribute
                         CustomWizardFile file;
                         file.source = attributeValue(reader, fileNameSourceAttributeC);
                         file.target = attributeValue(reader, fileNameTargetAttributeC);
-                        file.openEditor = booleanAttributeValue(reader, fileNameOpenEditorAttributeC);
-                        file.openProject = booleanAttributeValue(reader, fileNameOpenProjectAttributeC);
+                        file.openEditor = booleanAttributeValue(reader, fileNameOpenEditorAttributeC, false);
+                        file.openProject = booleanAttributeValue(reader, fileNameOpenProjectAttributeC, false);
                         if (file.target.isEmpty())
                             file.target = file.source;
                         if (file.source.isEmpty()) {
@@ -438,7 +446,7 @@ bool CustomWizardParameters::parse(QIODevice &device,
             if (state == ParseError) {
                 *errorMessage = msgError(reader, configFileFullPath,
                                          QString::fromLatin1("Unexpected end element %1").arg(reader.name().toString()));
-                return false;
+                return ParseFailed;
             }
             if (state == ParseWithinFields) { // Leaving a field element
                 fields.push_back(field);
@@ -449,17 +457,18 @@ bool CustomWizardParameters::parse(QIODevice &device,
             break;
         }
     } while (token != QXmlStreamReader::EndDocument);
-    return true;
+    return ParseOk;
 }
 
-bool CustomWizardParameters::parse(const QString &configFileFullPath,
+CustomWizardParameters::ParseResult
+     CustomWizardParameters::parse(const QString &configFileFullPath,
                                    Core::BaseFileWizardParameters *bp,
                                    QString *errorMessage)
 {
     QFile configFile(configFileFullPath);
     if (!configFile.open(QIODevice::ReadOnly|QIODevice::Text)) {
         *errorMessage = QString::fromLatin1("Cannot open %1: %2").arg(configFileFullPath, configFile.errorString());
-        return false;
+        return ParseFailed;
     }
     return parse(configFile, configFileFullPath, bp, errorMessage);
 }
diff --git a/src/plugins/projectexplorer/customwizard/customwizardparameters.h b/src/plugins/projectexplorer/customwizard/customwizardparameters.h
index f71de2b612b..3d5b223d4c3 100644
--- a/src/plugins/projectexplorer/customwizard/customwizardparameters.h
+++ b/src/plugins/projectexplorer/customwizard/customwizardparameters.h
@@ -67,12 +67,14 @@ struct CustomWizardFile {
 struct CustomWizardParameters
 {
 public:
+    enum ParseResult { ParseOk, ParseDisabled, ParseFailed };
+
     CustomWizardParameters();
     void clear();
-    bool parse(QIODevice &device, const QString &configFileFullPath,
-               Core::BaseFileWizardParameters *bp, QString *errorMessage);
-    bool parse(const QString &configFileFullPath,
-               Core::BaseFileWizardParameters *bp, QString *errorMessage);
+    ParseResult parse(QIODevice &device, const QString &configFileFullPath,
+                      Core::BaseFileWizardParameters *bp, QString *errorMessage);
+    ParseResult parse(const QString &configFileFullPath,
+                      Core::BaseFileWizardParameters *bp, QString *errorMessage);
     QString toString() const;
 
     QString directory;
-- 
GitLab