buildframework/helium/tools/common/java/src/com/nokia/ant/ModelPropertiesParser.java
changeset 1 be27ed110b50
child 179 d8ac696cc51f
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/buildframework/helium/tools/common/java/src/com/nokia/ant/ModelPropertiesParser.java	Wed Oct 28 14:39:48 2009 +0000
@@ -0,0 +1,114 @@
+/*
+* Copyright (c) 2007-2008 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of the License "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+*
+* Description: 
+*
+*/
+ 
+package com.nokia.ant;
+
+import info.bliki.wiki.model.WikiModel;
+
+import java.io.File;
+import java.io.FileOutputStream;
+import java.io.IOException;
+import java.util.Iterator;
+import java.util.List;
+
+import org.dom4j.Document;
+import org.dom4j.DocumentException;
+import org.dom4j.Element;
+import org.dom4j.io.OutputFormat;
+import org.dom4j.io.SAXReader;
+import org.dom4j.io.XMLWriter;
+
+
+/**
+ * Renders model property and group description to Wiki Model Syntax
+ * @author Helium Team
+ */
+public class ModelPropertiesParser
+{
+    private String inputPath;
+    private String outputPath;
+    private Document doc;
+    
+    public ModelPropertiesParser(String inputPath, String outputPath)
+    {
+        this.inputPath = inputPath;
+        this.outputPath = outputPath;
+    }
+
+    /**
+     * Reads model xml file, changes description format.
+     * @throws DocumentException
+     * @throws IOException
+     */
+    public void parsePropertiesDescription() throws IOException, DocumentException
+    {
+        SAXReader xmlReader = new SAXReader();
+        doc = xmlReader.read(new File(inputPath));
+        List importNodes = doc.selectNodes("//description");
+        for (Iterator iterator = importNodes.iterator(); iterator.hasNext();)
+        {
+            Element importCurrentNode = (Element) iterator.next();
+            importCurrentNode.setText(renderWikiModel(importCurrentNode.getText()));
+            writeXMLFile();
+        }
+    }
+    
+     /**
+     * Writes Document object as xml file
+     */
+    private void writeXMLFile()
+    {
+        try {
+            if (outputPath != null) {
+            XMLWriter out = new XMLWriter(new FileOutputStream(new File(outputPath)), OutputFormat.createPrettyPrint());
+            out.write(doc);
+          }
+        } catch (Exception e) {
+            e.printStackTrace();
+        }
+    }
+    
+     /**
+     * Render the description as Wiki model
+     * @param String descriptionText
+     * @return String
+     */
+    private String renderWikiModel(String descriptionText) throws IOException, DocumentException
+    {
+        if (descriptionText != null)
+        {
+            WikiModel wikiModel = new WikiModel("", "");
+            //If description contains unwanted symbols like "**", "==" and "- -", remove those from description.
+            if (descriptionText.contains("**") || descriptionText.contains("==") || descriptionText.contains("- -"))
+            {
+                descriptionText = descriptionText.replace("**", "").replace("==", "").replace("- -", "").trim();
+            }
+            //If description starts with "-", remove it. As wiki have special meaning for this symbol
+            if (descriptionText.startsWith("-"))
+                descriptionText = descriptionText.replace("-", "");
+            descriptionText = descriptionText.trim();
+            //Render description with wiki model syntax
+            descriptionText = wikiModel.render(descriptionText);
+        }
+        else
+        {
+            descriptionText = "";
+        }
+      return descriptionText;
+     }
+}
+