diff --git a/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/.classpath b/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/.classpath
new file mode 100644
index 0000000000000000000000000000000000000000..751c8f2e504c40d1c41ebbd87d8f8968529e9c30
--- /dev/null
+++ b/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/.classpath
@@ -0,0 +1,7 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<classpath>
+	<classpathentry kind="src" path="src"/>
+	<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER"/>
+	<classpathentry kind="con" path="org.eclipse.pde.core.requiredPlugins"/>
+	<classpathentry kind="output" path="bin"/>
+</classpath>
diff --git a/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/.cvsignore b/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/.cvsignore
new file mode 100644
index 0000000000000000000000000000000000000000..5022c63e805f40d8627b29d7abcae3b38bf5fd31
--- /dev/null
+++ b/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/.cvsignore
@@ -0,0 +1,4 @@
+javaCompiler.wtpRelengTools.jar.args
+build.xml
+bin
+temp.folder
diff --git a/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/.project b/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/.project
new file mode 100644
index 0000000000000000000000000000000000000000..99c64d2848d16c2d543ba02443926850bb1adbe1
--- /dev/null
+++ b/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/.project
@@ -0,0 +1,28 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<projectDescription>
+	<name>org.eclipse.wtp.releng.tools</name>
+	<comment></comment>
+	<projects>
+	</projects>
+	<buildSpec>
+		<buildCommand>
+			<name>org.eclipse.jdt.core.javabuilder</name>
+			<arguments>
+			</arguments>
+		</buildCommand>
+		<buildCommand>
+			<name>org.eclipse.pde.ManifestBuilder</name>
+			<arguments>
+			</arguments>
+		</buildCommand>
+		<buildCommand>
+			<name>org.eclipse.pde.SchemaBuilder</name>
+			<arguments>
+			</arguments>
+		</buildCommand>
+	</buildSpec>
+	<natures>
+		<nature>org.eclipse.pde.PluginNature</nature>
+		<nature>org.eclipse.jdt.core.javanature</nature>
+	</natures>
+</projectDescription>
diff --git a/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/META-INF/MANIFEST.MF b/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/META-INF/MANIFEST.MF
new file mode 100644
index 0000000000000000000000000000000000000000..048d2df1ce9406110e2f6f4427a4b04ce26c36c5
--- /dev/null
+++ b/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/META-INF/MANIFEST.MF
@@ -0,0 +1,8 @@
+Manifest-Version: 1.0
+Bundle-ManifestVersion: 2
+Bundle-Name: %Bundle-Name.0
+Bundle-SymbolicName: org.eclipse.wtp.releng.tools;singleton:=true
+Bundle-Version: 1.0.0
+Require-Bundle: org.apache.ant
+Bundle-Localization: plugin
+Bundle-ClassPath: wtpRelengTools.jar
diff --git a/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/build.properties b/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/build.properties
new file mode 100644
index 0000000000000000000000000000000000000000..73f4109b7d37f1b1946ff45f6fe2974476564dce
--- /dev/null
+++ b/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/build.properties
@@ -0,0 +1,5 @@
+bin.includes = META-INF/,\
+               plugin.xml,\
+               wtpRelengTools.jar,\
+               plugin.properties
+source.wtpRelengTools.jar = src/
diff --git a/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/plugin.properties b/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/plugin.properties
new file mode 100644
index 0000000000000000000000000000000000000000..be037b9d4e04f1c0bcc159fb7954114f239656f6
--- /dev/null
+++ b/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/plugin.properties
@@ -0,0 +1,2 @@
+# properties file for org.eclipse.wtp.releng.tools
+Bundle-Name.0 = Tools
\ No newline at end of file
diff --git a/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/plugin.xml b/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/plugin.xml
new file mode 100644
index 0000000000000000000000000000000000000000..0dee10e328847e4948335cb8acb4dce8541bc276
--- /dev/null
+++ b/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/plugin.xml
@@ -0,0 +1,27 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<?eclipse version="3.2"?>
+<plugin>
+
+  <extension
+         point="org.eclipse.ant.core.extraClasspathEntries">
+      <extraClasspathEntry
+            library="wtpRelengTools.jar">
+      </extraClasspathEntry>
+   </extension>
+	<!-- Tasks -->
+   <extension point="org.eclipse.ant.core.antTasks">
+   
+       <antTask
+            library="wtpRelengTools.jar"
+            name="indexResults"
+            class="org.eclipse.wtp.releng.tools.TestResultsGenerator">
+      </antTask>
+       <antTask
+            library="wtpRelengTools.jar"
+            name="indexResults"
+            class="org.eclipse.wtp.releng.tools.FileCounter">
+      </antTask>
+ 
+    </extension>
+
+</plugin>
diff --git a/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/src/org/eclipse/wtp/releng/tools/ErrorTracker.java b/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/src/org/eclipse/wtp/releng/tools/ErrorTracker.java
new file mode 100644
index 0000000000000000000000000000000000000000..37efce70a8ff6facf99db8aa666691fe2ae26174
--- /dev/null
+++ b/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/src/org/eclipse/wtp/releng/tools/ErrorTracker.java
@@ -0,0 +1,224 @@
+/*******************************************************************************
+ * Copyright (c) 2000, 2006 IBM Corporation and others.
+ * All rights reserved. This program and the accompanying materials
+ * are made available under the terms of the Eclipse Public License v1.0
+ * which accompanies this distribution, and is available at
+ * http://www.eclipse.org/legal/epl-v10.html
+ *
+ * Contributors:
+ *     IBM Corporation - initial API and implementation
+ *******************************************************************************/
+package org.eclipse.wtp.releng.tools;
+
+import java.io.IOException;
+import java.util.Enumeration;
+import java.util.Hashtable;
+import java.io.File;
+
+import java.util.Vector;
+import javax.xml.parsers.DocumentBuilderFactory;
+import javax.xml.parsers.DocumentBuilder;
+import javax.xml.parsers.ParserConfigurationException;
+
+import org.w3c.dom.Document;
+import org.w3c.dom.Element;
+import org.w3c.dom.Node;
+import org.w3c.dom.NodeList;
+import org.xml.sax.SAXException;
+
+/**
+ * @version 	1.0
+ * @author
+ */
+public class ErrorTracker {
+
+	// List of test logs expected at end of build
+	private Vector testLogs = new Vector();
+
+
+	// Platforms keyed on 
+	private Hashtable platforms = new Hashtable();
+	private Hashtable logFiles = new Hashtable();
+	private Hashtable typesMap = new Hashtable();
+	private Vector typesList = new Vector();
+	
+	public static void main(String[] args) {
+		
+		// For testing only.  Should not be invoked
+		
+		ErrorTracker anInstance = new ErrorTracker();
+		anInstance.loadFile("C:\\junk\\testManifest.xml");
+		String[] theTypes = anInstance.getTypes();
+		for (int i=0; i < theTypes.length; i++) {
+			// System.out.println("Type: " + theTypes[i]);
+			PlatformStatus[] thePlatforms = anInstance.getPlatforms(theTypes[i]);
+			for (int j=0; j < thePlatforms.length; j++) {
+				// System.out.println("Out ID: " + thePlatforms[j].getId());
+			}
+		}
+	}
+	
+	public void loadFile(String fileName) {
+		DocumentBuilderFactory docBuilderFactory = DocumentBuilderFactory.newInstance();
+		DocumentBuilder parser=null;
+		try {
+			parser = docBuilderFactory.newDocumentBuilder();
+		} catch (ParserConfigurationException e1) {
+			e1.printStackTrace();
+		}
+		try {
+			
+			Document document = parser.parse(fileName);
+			NodeList elements = document.getElementsByTagName("platform");
+			int elementCount = elements.getLength();
+			for (int i = 0; i < elementCount; i++) {
+				PlatformStatus aPlatform = new PlatformStatus((Element) elements.item(i));
+				//System.out.println("ID: " + aPlatform.getId());
+				platforms.put(aPlatform.getId(), aPlatform);
+				
+				Node zipType = elements.item(i).getParentNode();
+				String zipTypeName = (String) zipType.getAttributes().getNamedItem("name").getNodeValue();
+				
+				Vector aVector = (Vector) typesMap.get(zipTypeName);
+				if (aVector == null) {
+					typesList.add(zipTypeName);
+					aVector = new Vector();
+					typesMap.put(zipTypeName, aVector);
+				}
+				aVector.add(aPlatform.getId());
+				
+			}
+
+			NodeList effectedFiles = document.getElementsByTagName("effectedFile");
+			int effectedFilesCount = effectedFiles.getLength();
+			for (int i = 0; i < effectedFilesCount; i++) {
+				Node anEffectedFile = effectedFiles.item(i);
+				Node logFile = anEffectedFile.getParentNode();
+				String logFileName = (String) logFile.getAttributes().getNamedItem("name").getNodeValue();
+				logFileName=convertPathDelimiters(logFileName);
+				String effectedFileID = (String) anEffectedFile.getAttributes().getNamedItem("id").getNodeValue();				
+				//System.out.println(logFileName);
+				Vector aVector = (Vector) logFiles.get(logFileName);
+				if (aVector == null) {
+					aVector = new Vector();
+					logFiles.put(logFileName, aVector);
+					
+				}
+				PlatformStatus ps=(PlatformStatus) platforms.get(effectedFileID);
+				if (ps!=null)
+					aVector.addElement(ps);
+			}
+			
+			// store a list of the test logs expected after testing
+			NodeList testLogList = document.getElementsByTagName("logFile");
+				int testLogCount = testLogList.getLength();
+				for (int i = 0; i < testLogCount; i++) {
+								
+					Node testLog = testLogList.item(i);
+					String testLogName = (String) testLog.getAttributes().getNamedItem("name").getNodeValue();
+					Node typeNode=testLog.getAttributes().getNamedItem("type");
+					String type="test";
+					if (typeNode!=null){
+						type = typeNode.getNodeValue();
+					}
+					if (testLogName.endsWith(".xml")&&type.equals("test")){
+						testLogs.add(testLogName);
+						//System.out.println(testLogName);
+					}
+			
+			}
+
+
+//			// Test this mess.
+//			Object[] results = platforms.values().toArray();
+//			for (int i=0; i < results.length; i++) {
+//				PlatformStatus ap = (PlatformStatus) results[i];
+//				System.out.println("ID: " + ap.getId() + " passed: " + ap.getPassed());
+//			}
+//		
+//			Enumeration anEnumeration = logFiles.keys();
+//			while (anEnumeration.hasMoreElements()) {
+//				String aKey = (String) anEnumeration.nextElement();
+//				System.out.println("Whack a key: " + aKey);
+//				((PlatformStatus) logFiles.get(aKey)).setPassed(false);
+//			}
+//			
+//			results = platforms.values().toArray();
+//			for (int i=0; i < results.length; i++) {
+//				PlatformStatus ap = (PlatformStatus) results[i];
+//				System.out.println("ID: " + ap.getId() + " passed: " + ap.getPassed());
+//			}
+			
+			
+		
+			
+			
+		} catch (IOException e) {
+			System.out.println("IOException: " + fileName);
+			// e.printStackTrace();
+			
+		} catch (SAXException e) {
+			System.out.println("SAXException: " + fileName);
+			e.printStackTrace();
+			
+		}
+	}
+	
+	public void registerError(String fileName) {
+		// System.out.println("Found an error in: " + fileName);
+		if (logFiles.containsKey(fileName)) {
+			Vector aVector = (Vector) logFiles.get(fileName);
+			for (int i = 0; i < aVector.size(); i++) {
+				((PlatformStatus) aVector.elementAt(i)).registerError();
+			}
+		} else {
+			
+			// If a log file is not specified explicitly it effects
+			// all "platforms" except JDT
+			
+			Enumeration values = platforms.elements();
+			while (values.hasMoreElements()) {
+				PlatformStatus aValue = (PlatformStatus) values.nextElement();
+				if (!aValue.getId().equals("JA") && 
+					!aValue.getId().equals("EW") && 
+					!aValue.getId().equals("EA")) {
+						aValue.registerError();
+				}
+			}
+		}
+	}
+	
+	public boolean hasErrors(String id) {
+		return ((PlatformStatus) platforms.get(id)).hasErrors();
+	}
+	
+	// Answer a string array of the zip type names in the order they appear in
+	// the .xml file.
+	public String[] getTypes() {
+		return (String[]) typesList.toArray(new String[typesList.size()]);
+	}
+	
+	// Answer an array of PlatformStatus objects for a given type.
+
+	public PlatformStatus[] getPlatforms(String type) {
+		Vector platformIDs = (Vector) typesMap.get(type);
+		PlatformStatus[] result = new PlatformStatus[platformIDs.size()];
+		for (int i = 0; i < platformIDs.size(); i++) {
+			result[i] = (PlatformStatus) platforms.get((String) platformIDs.elementAt(i));
+		}
+		return  result;
+	}	
+
+	/**
+	 * Returns the testLogs.
+	 * @return Vector
+	 */
+	public Vector getTestLogs() {
+		return testLogs;
+	}
+
+	private String convertPathDelimiters(String path){
+		return new File(path).getPath();
+	}
+	
+}
diff --git a/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/src/org/eclipse/wtp/releng/tools/FileCounter.java b/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/src/org/eclipse/wtp/releng/tools/FileCounter.java
new file mode 100644
index 0000000000000000000000000000000000000000..f61c4474fa21c012bf318d7d9e91be2e241d744e
--- /dev/null
+++ b/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/src/org/eclipse/wtp/releng/tools/FileCounter.java
@@ -0,0 +1,146 @@
+/*******************************************************************************
+ * Copyright (c) 2000, 2006 IBM Corporation and others.
+ * All rights reserved. This program and the accompanying materials
+ * are made available under the terms of the Eclipse Public License v1.0
+ * which accompanies this distribution, and is available at
+ * http://www.eclipse.org/legal/epl-v10.html
+ *
+ * Contributors:
+ *     IBM Corporation - initial API and implementation
+ *******************************************************************************/
+
+package org.eclipse.wtp.releng.tools;
+
+import java.io.File;
+import java.io.FileNotFoundException;
+import java.io.FileOutputStream;
+import java.io.IOException;
+import java.util.StringTokenizer;
+import org.apache.tools.ant.BuildException;
+import org.apache.tools.ant.Task;
+
+/**
+ * This task will count the number of fils in a given directory
+ * that match a given filter.  The number of fils will be output
+ * to a given output file.  The output file will be overwritten
+ * if it already exists.
+ * 
+ * Note: Filter comparison is NOT case sensitive.  Do not use wild cards.
+ * ie .zip counts all files with .zip anywere in the name.
+ */
+public class FileCounter extends Task {
+	
+	private String sourceDirectory = "";
+	private String filterString = ".zip";
+	private String outputFile = "";
+	
+	public static void main(String args[]) {
+		// For testing only.
+		FileCounter aFileCounter = new FileCounter();
+		aFileCounter.setSourceDirectory("c:\\RelEng\\dean");
+		aFileCounter.setOutputFile("c:\\RelEng\\dean\\files.count");
+		aFileCounter.setFilterString(".zip");
+		aFileCounter.execute();
+	}
+
+	public void execute() throws BuildException {
+		// Do the work.
+		
+		int count = 0;
+		
+		System.out.println("Source Directory: " + this.getSourceDirectory());
+		System.out.println("Output File: " + this.getOutputFile());
+		System.out.println("Filter String: " + this.getFilterString());
+		
+		File aDirectory = new File(this.getSourceDirectory());
+		if (aDirectory == null) {
+			throw new BuildException("Directory " + this.getSourceDirectory() + " not found.");
+		}
+		
+		String[] names = aDirectory.list();
+		if (names == null) {
+			throw new BuildException("Directory " + this.getSourceDirectory() + " not found.");
+		}			
+		
+		System.out.println("List size: " + names.length);
+		
+		for (int i = 0; i < names.length; i++) {
+			System.out.println("Name: " + names[i]);
+			
+			int index = -1;
+			StringTokenizer types = getFileTypes();
+			
+			while (types.hasMoreTokens()){
+				index = names[i].toLowerCase().indexOf(types.nextToken().toLowerCase());
+				if (index != -1) {
+					count++;
+				}
+			}
+
+		}
+		
+		try {
+			FileOutputStream anOutputStream = new FileOutputStream(this.getOutputFile());
+			anOutputStream.write(String.valueOf(count).getBytes());
+			anOutputStream.close();
+		} catch (FileNotFoundException e) {
+			throw new BuildException("Can not create file.count file");
+		} catch (IOException e) {
+			throw new BuildException("Can not create file.count file");
+		}
+		
+	}
+
+	private StringTokenizer getFileTypes(){
+		return new StringTokenizer(getFilterString(),",");
+	}
+
+	/**
+	 * Gets the sourceDirectory.
+	 * @return Returns a String
+	 */
+	public String getSourceDirectory() {
+		return sourceDirectory;
+	}
+
+	/**
+	 * Sets the sourceDirectory.
+	 * @param sourceDirectory The sourceDirectory to set
+	 */
+	public void setSourceDirectory(String sourceDirectory) {
+		this.sourceDirectory = sourceDirectory;
+	}
+
+	/**
+	 * Gets the filterString.
+	 * @return Returns a String
+	 */
+	public String getFilterString() {
+		return filterString;
+	}
+
+	/**
+	 * Sets the filterString.
+	 * @param filterString The filterString to set
+	 */
+	public void setFilterString(String filterString) {
+		this.filterString = filterString;
+	}
+
+	/**
+	 * Gets the outputFile.
+	 * @return Returns a String
+	 */
+	public String getOutputFile() {
+		return outputFile;
+	}
+
+	/**
+	 * Sets the outputFile.
+	 * @param outputFile The outputFile to set
+	 */
+	public void setOutputFile(String outputFile) {
+		this.outputFile = outputFile;
+	}
+
+}
diff --git a/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/src/org/eclipse/wtp/releng/tools/PlatformStatus.java b/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/src/org/eclipse/wtp/releng/tools/PlatformStatus.java
new file mode 100644
index 0000000000000000000000000000000000000000..5da34514305824ae836cc635e8bc9da2e78aca82
--- /dev/null
+++ b/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/src/org/eclipse/wtp/releng/tools/PlatformStatus.java
@@ -0,0 +1,59 @@
+/*******************************************************************************
+ * Copyright (c) 2000, 2006 IBM Corporation and others.
+ * All rights reserved. This program and the accompanying materials
+ * are made available under the terms of the Eclipse Public License v1.0
+ * which accompanies this distribution, and is available at
+ * http://www.eclipse.org/legal/epl-v10.html
+ *
+ * Contributors:
+ *     IBM Corporation - initial API and implementation
+ *******************************************************************************/
+package org.eclipse.wtp.releng.tools;
+
+import org.w3c.dom.Element;
+import org.w3c.dom.NamedNodeMap;
+
+/**
+ * @version 	1.0
+ * @author
+ */
+public class PlatformStatus {
+	
+	private String id;
+	private String name;
+	private String fileName;
+	private boolean hasErrors = false;
+	
+	PlatformStatus(Element anElement) {
+		super();
+		NamedNodeMap attributes = anElement.getAttributes();
+		this.id = (String) attributes.getNamedItem("id").getNodeValue();
+		this.name = (String) attributes.getNamedItem("name").getNodeValue();
+		this.fileName = (String) attributes.getNamedItem("fileName").getNodeValue();
+
+	}
+
+	/**
+	 * Gets the id.
+	 * @return Returns a String
+	 */
+	public String getId() {
+		return id;
+	}
+
+	public String getName() {
+		return name;
+	}
+
+	public String getFileName() {
+		return fileName;
+	}
+	
+	public void registerError() {
+		this.hasErrors = true;
+	}
+	
+	public boolean hasErrors() {
+		return this.hasErrors;
+	}
+}
diff --git a/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/src/org/eclipse/wtp/releng/tools/TestResultsGenerator.java b/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/src/org/eclipse/wtp/releng/tools/TestResultsGenerator.java
new file mode 100644
index 0000000000000000000000000000000000000000..4a6ed6de858679c9de8ebbb7d7e54fd3f72f3ddd
--- /dev/null
+++ b/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/src/org/eclipse/wtp/releng/tools/TestResultsGenerator.java
@@ -0,0 +1,1250 @@
+package org.eclipse.wtp.releng.tools;
+
+
+import java.io.BufferedReader;
+import java.io.File;
+import java.io.FileInputStream;
+import java.io.FileNotFoundException;
+import java.io.FileOutputStream;
+import java.io.FileReader;
+import java.io.IOException;
+import java.io.InputStream;
+import java.util.Arrays;
+import java.util.StringTokenizer;
+import java.util.Vector;
+import java.util.Enumeration;
+
+import org.apache.tools.ant.Task;
+import javax.xml.parsers.DocumentBuilderFactory;
+import javax.xml.parsers.DocumentBuilder;
+import javax.xml.parsers.ParserConfigurationException;
+
+import org.w3c.dom.Document;
+import org.w3c.dom.Element;
+import org.w3c.dom.NamedNodeMap;
+import org.w3c.dom.Node;
+import org.w3c.dom.NodeList;
+import org.xml.sax.InputSource;
+import org.xml.sax.SAXException;
+
+
+/**
+ * @version 1.0
+ * @author Dean Roberts
+ */
+public class TestResultsGenerator extends Task {
+	private static final String WARNING_SEVERITY = "WARNING";
+	private static final String ERROR_SEVERITY = "ERROR";
+	private static final String ForbiddenReferenceID = "ForbiddenReference";
+	private static final String DiscouragedReferenceID = "DiscouragedReference";
+
+	private static final int DEFAULT_READING_SIZE = 8192;
+
+	static final String elementName = "testsuite";
+	static final String testResultsToken = "%testresults%";
+	static final String compileLogsToken = "%compilelogs%";
+	public Vector dropTokens;
+	public Vector platformSpecs;
+	public Vector differentPlatforms;
+	public String testResultsWithProblems = "\n";
+
+	private DocumentBuilder parser = null;
+	public ErrorTracker anErrorTracker;
+	public String testResultsTemplateString = "";
+	public String dropTemplateString = "";
+
+	public Vector platformDescription;
+	public Vector platformTemplateString;
+	public Vector platformDropFileName;
+
+	// Status of tests results (pending, successful, failed), used to specify
+	// the color
+	// of the test Results link on the build pages (standard, green, red),
+	// once failures
+	// are encountered, this is set to failed
+	protected String testResultsStatus = "successful";
+	// assume tests ran. If no html files are found, this is set to false
+	private boolean testsRan = true;
+
+	// Parameters
+	// build runs JUnit automated tests
+	private boolean isBuildTested;
+
+	// buildType, I, N
+	public String buildType;
+
+	// Comma separated list of drop tokens
+	public String dropTokenList;
+
+	// Token in platform.php.template to be replaced by the desired platform
+	// ID
+	public String platformIdentifierToken;
+
+	// Location of the xml files
+	public String xmlDirectoryName;
+
+	// Location of the html files
+	public String htmlDirectoryName;
+
+	// Location of the resulting index.php file.
+	public String dropDirectoryName;
+
+	// Location and name of the template index.php file.
+	public String testResultsTemplateFileName;
+
+	// Platform specific template and output list (colon separated) in the
+	// following format:
+	// <descriptor, ie. OS name>,path to template file, path to output file
+	public String platformSpecificTemplateList = "";
+
+	// Location and name of the template drop index.php file.
+	public String dropTemplateFileName;
+
+	// Name of the generated index php file.
+	public String testResultsHtmlFileName;
+
+	// Name of the generated drop index php file;
+	public String dropHtmlFileName;
+
+	// Arbitrary path used in the index.php page to href the
+	// generated .html files.
+	public String hrefTestResultsTargetPath;
+
+	// Aritrary path used in the index.php page to reference the compileLogs
+	public String hrefCompileLogsTargetPath;
+
+	// Location of compile logs base directory
+	public String compileLogsDirectoryName;
+
+	// Location and name of test manifest file
+	public String testManifestFileName;
+
+	// Initialize the prefix to a default string
+	private String prefix = "default";
+	private String testShortName = "";
+	private int counter = 0;
+	// The four configurations, add new configurations to test results here +
+	// update
+	// testResults.php.template for changes
+	private String[] testsConfig = {"linux.gtk.x86.xml", "linux.gtk.x86_5.0.xml", "macosx.carbon.ppc.xml", "win32.win32.x86.xml", "win32.win32.x86_5.0.xml"};
+
+
+	public static void main(String[] args) {
+		TestResultsGenerator test = new TestResultsGenerator();
+		test.setDropTokenList("%sdk%,%tests%,%example%,%rcpruntime%,%rcpsdk%,%icubase%,%runtime%,%platformsdk%,%jdt%,%jdtsdk%,%pde%,%pdesdk%,%cvs%,%cvssdk%,%teamextras%,%swt%,%relengtools%");
+		test.setPlatformIdentifierToken("%platform%");
+		test.getDropTokensFromList(test.dropTokenList);
+		test.setIsBuildTested(true);
+		test.setXmlDirectoryName("C:\\junk\\testresults\\xml");
+		test.setHtmlDirectoryName("C:\\junk\\testresults");
+		test.setDropDirectoryName("C:\\junk");
+		test.setTestResultsTemplateFileName("C:\\junk\\templateFiles\\testResults.php.template");
+		test.setPlatformSpecificTemplateList("Windows,C:\\junk\\templateFiles\\platform.php.template,winPlatform.php;Linux,C:\\junk\\templateFiles\\platform.php.template,linPlatform.php;Solaris,C:\\junk\\templateFiles\\platform.php.template,solPlatform.php;AIX,C:\\junk\\templateFiles\\platform.php.template,aixPlatform.php;Macintosh,C:\\junk\\templateFiles\\platform.php.template,macPlatform.php;Source Build,C:\\junk\\templateFiles\\sourceBuilds.php.template,sourceBuilds.php");
+		test.setDropTemplateFileName("C:\\junk\\templateFiles\\index.php.template");
+		test.setTestResultsHtmlFileName("testResults.php");
+		// test.setDropHtmlFileName("index.php");
+		test.setDropHtmlFileName("index.html");
+
+		test.setHrefTestResultsTargetPath("testresults");
+		test.setCompileLogsDirectoryName("C:\\junk\\compilelogs\\plugins");
+		test.setHrefCompileLogsTargetPath("compilelogs");
+		test.setTestManifestFileName("C:\\junk\\testManifest.xml");
+		test.execute();
+	}
+
+	public void execute() {
+
+		anErrorTracker = new ErrorTracker();
+		platformDescription = new Vector();
+		platformTemplateString = new Vector();
+		platformDropFileName = new Vector();
+		anErrorTracker.loadFile(testManifestFileName);
+		getDropTokensFromList(dropTokenList);
+		testResultsTemplateString = readFile(testResultsTemplateFileName);
+		dropTemplateString = readFile(dropTemplateFileName);
+
+		// Specific to the platform build-page
+		if (platformSpecificTemplateList != "") {
+			String description, platformTemplateFile, platformDropFile;
+			// Retrieve the different platforms and their info
+			getDifferentPlatformsFromList(platformSpecificTemplateList);
+			// Parses the platform info and retrieves the platform name,
+			// template file, and drop file
+			for (int i = 0; i < differentPlatforms.size(); i++) {
+				getPlatformSpecsFromList(differentPlatforms.get(i).toString());
+				description = platformSpecs.get(0).toString();
+				platformTemplateFile = platformSpecs.get(1).toString();
+				platformDropFile = platformSpecs.get(2).toString();
+				platformDescription.add(description);
+				platformTemplateString.add(readFile(platformTemplateFile));
+				platformDropFileName.add(platformDropFile);
+
+			}
+
+		}
+
+		System.out.println("Begin: Generating test results index page");
+		System.out.println("Parsing XML files");
+		parseXml();
+		System.out.println("Parsing compile logs");
+		parseCompileLogs();
+		System.out.println("End: Generating test results index page");
+		writeTestResultsFile();
+		// For the platform build-page, write platform files, in addition to
+		// the index file
+		if (platformSpecificTemplateList != "") {
+			writeDropFiles();
+		}
+		else {
+			writeDropIndexFile();
+		}
+	}
+
+	public void parseCompileLogs() {
+
+		StringBuffer replaceString = new StringBuffer();
+		processCompileLogsDirectory(compileLogsDirectoryName, replaceString);
+		if (replaceString.length() == 0) {
+			replaceString.append("None");
+		}
+		testResultsTemplateString = replace(testResultsTemplateString, compileLogsToken, String.valueOf(replaceString));
+
+	}
+
+	private void processCompileLogsDirectory(String directoryName, StringBuffer buffer) {
+		File sourceDirectory = new File(directoryName);
+		if (sourceDirectory.isFile()) {
+			if (sourceDirectory.getName().endsWith(".log"))
+				readCompileLog(sourceDirectory.getAbsolutePath(), buffer);
+			if (sourceDirectory.getName().endsWith(".xml"))
+				parseCompileLog(sourceDirectory.getAbsolutePath(), buffer);
+		}
+		if (sourceDirectory.isDirectory()) {
+			File[] logFiles = sourceDirectory.listFiles();
+			Arrays.sort(logFiles);
+			for (int j = 0; j < logFiles.length; j++) {
+				processCompileLogsDirectory(logFiles[j].getAbsolutePath(), buffer);
+			}
+		}
+	}
+
+	private void readCompileLog(String log, StringBuffer buffer) {
+		String fileContents = readFile(log);
+
+		int errorCount = countCompileErrors(fileContents);
+		int warningCount = countCompileWarnings(fileContents);
+		int forbiddenWarningCount = countForbiddenWarnings(fileContents);
+		int discouragedWarningCount = countDiscouragedWarnings(fileContents);
+		if (errorCount != 0) {
+			// use wildcard in place of version number on directory names
+			String logName = log.substring(getCompileLogsDirectoryName().length() + 1);
+			StringBuffer stringBuffer = new StringBuffer(logName);
+			stringBuffer.replace(logName.indexOf("_") + 1, logName.indexOf(File.separator, logName.indexOf("_") + 1), "*");
+			logName = new String(stringBuffer);
+
+			anErrorTracker.registerError(logName);
+		}
+		formatCompileErrorRow(log, errorCount, warningCount, forbiddenWarningCount, discouragedWarningCount, buffer);
+	}
+
+	private void parseCompileLog(String log, StringBuffer stringBuffer) {
+		int errorCount = 0;
+		int warningCount = 0;
+		int forbiddenWarningCount = 0;
+		int discouragedWarningCount = 0;
+
+		File file = new File(log);
+		Document aDocument = null;
+		BufferedReader reader = null;
+		try {
+			reader = new BufferedReader(new FileReader(file));
+			InputSource inputSource = new InputSource(reader);
+			DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
+			DocumentBuilder builder = factory.newDocumentBuilder();
+			aDocument = builder.parse(inputSource);
+		}
+		catch (SAXException e) {
+			e.printStackTrace();
+		}
+		catch (IOException e) {
+			e.printStackTrace();
+		}
+		catch (ParserConfigurationException e) {
+			e.printStackTrace();
+		}
+		finally {
+			if (reader != null) {
+				try {
+					reader.close();
+				}
+				catch (IOException e) {
+					// ignore
+				}
+			}
+		}
+
+		if (aDocument == null)
+			return;
+		// Get summary of problems
+		NodeList nodeList = aDocument.getElementsByTagName("problem");
+		if (nodeList == null || nodeList.getLength() == 0)
+			return;
+
+		int length = nodeList.getLength();
+		for (int i = 0; i < length; i++) {
+			Node problemNode = nodeList.item(i);
+			NamedNodeMap aNamedNodeMap = problemNode.getAttributes();
+			Node severityNode = aNamedNodeMap.getNamedItem("severity");
+			Node idNode = aNamedNodeMap.getNamedItem("id");
+			if (severityNode != null) {
+				String severityNodeValue = severityNode.getNodeValue();
+				if (WARNING_SEVERITY.equals(severityNodeValue)) {
+					// this is a warning
+					// need to check the id
+					String nodeValue = idNode.getNodeValue();
+					if (ForbiddenReferenceID.equals(nodeValue)) {
+						forbiddenWarningCount++;
+					}
+					else if (DiscouragedReferenceID.equals(nodeValue)) {
+						discouragedWarningCount++;
+					}
+					else {
+						warningCount++;
+					}
+				}
+				else if (ERROR_SEVERITY.equals(severityNodeValue)) {
+					// this is an error
+					errorCount++;
+				}
+			}
+		}
+		if (errorCount != 0) {
+			// use wildcard in place of version number on directory names
+			// System.out.println(log + "/n");
+			String logName = log.substring(getCompileLogsDirectoryName().length() + 1);
+			StringBuffer buffer = new StringBuffer(logName);
+			buffer.replace(logName.indexOf("_") + 1, logName.indexOf(File.separator, logName.indexOf("_") + 1), "*");
+			logName = new String(buffer);
+
+			anErrorTracker.registerError(logName);
+		}
+		formatCompileErrorRow(log.replaceAll(".xml", ".html"), errorCount, warningCount, forbiddenWarningCount, discouragedWarningCount, stringBuffer);
+	}
+
+	public static byte[] getFileByteContent(String fileName) throws IOException {
+		InputStream stream = null;
+		try {
+			File file = new File(fileName);
+			stream = new FileInputStream(file);
+			return getInputStreamAsByteArray(stream, (int) file.length());
+		}
+		finally {
+			if (stream != null) {
+				try {
+					stream.close();
+				}
+				catch (IOException e) {
+					// ignore
+				}
+			}
+		}
+	}
+
+	/**
+	 * Returns the given input stream's contents as a byte array. If a length
+	 * is specified (ie. if length != -1), only length bytes are returned.
+	 * Otherwise all bytes in the stream are returned. Note this doesn't close
+	 * the stream.
+	 * 
+	 * @throws IOException
+	 *             if a problem occured reading the stream.
+	 */
+	public static byte[] getInputStreamAsByteArray(InputStream stream, int length) throws IOException {
+		byte[] contents;
+		if (length == -1) {
+			contents = new byte[0];
+			int contentsLength = 0;
+			int amountRead = -1;
+			do {
+				int amountRequested = Math.max(stream.available(), DEFAULT_READING_SIZE); // read
+																							// at
+																							// least
+																							// 8K
+
+				// resize contents if needed
+				if (contentsLength + amountRequested > contents.length) {
+					System.arraycopy(contents, 0, contents = new byte[contentsLength + amountRequested], 0, contentsLength);
+				}
+
+				// read as many bytes as possible
+				amountRead = stream.read(contents, contentsLength, amountRequested);
+
+				if (amountRead > 0) {
+					// remember length of contents
+					contentsLength += amountRead;
+				}
+			}
+			while (amountRead != -1);
+
+			// resize contents if necessary
+			if (contentsLength < contents.length) {
+				System.arraycopy(contents, 0, contents = new byte[contentsLength], 0, contentsLength);
+			}
+		}
+		else {
+			contents = new byte[length];
+			int len = 0;
+			int readSize = 0;
+			while ((readSize != -1) && (len != length)) {
+				// See PR 1FMS89U
+				// We record first the read size. In this case len is the
+				// actual read size.
+				len += readSize;
+				readSize = stream.read(contents, len, length - len);
+			}
+		}
+
+		return contents;
+	}
+
+	public String readFile(String fileName) {
+		byte[] aByteArray = null;
+		try {
+			aByteArray = getFileByteContent(fileName);
+		}
+		catch (IOException e) {
+			e.printStackTrace();
+		}
+		if (aByteArray == null) {
+			return "";
+		}
+		return new String(aByteArray);
+	}
+
+	private int countCompileErrors(String aString) {
+		return extractNumber(aString, "error");
+	}
+
+	private int countCompileWarnings(String aString) {
+		return extractNumber(aString, "warning");
+	}
+
+	private int countForbiddenWarnings(String aString) {
+		return extractNumber(aString, "Access restriction:");
+	}
+
+	private int countDiscouragedWarnings(String aString) {
+		return extractNumber(aString, "Discouraged access:");
+	}
+
+	private int extractNumber(String aString, String endToken) {
+		int endIndex = aString.lastIndexOf(endToken);
+		if (endIndex == -1) {
+			return 0;
+		}
+
+		int startIndex = endIndex;
+		while (startIndex >= 0 && aString.charAt(startIndex) != '(' && aString.charAt(startIndex) != ',') {
+			startIndex--;
+		}
+
+		String count = aString.substring(startIndex + 1, endIndex).trim();
+		try {
+			return Integer.parseInt(count);
+		}
+		catch (NumberFormatException e) {
+			return 0;
+		}
+
+	}
+
+	private int missingCount = 0;
+	private boolean includeAll;
+
+	private String verifyAllTestsRan(String directory) {
+		Enumeration enumeration = (anErrorTracker.getTestLogs()).elements();
+
+		String replaceString = "";
+		while (enumeration.hasMoreElements()) {
+			String testLogName = enumeration.nextElement().toString();
+
+			if (new File(directory + File.separator + testLogName).exists())
+				continue;
+
+			anErrorTracker.registerError(testLogName);
+			String tmp = ((platformSpecificTemplateList == "") ? formatRow(testLogName, -1, false) : formatRowReleng(testLogName, -1, false));
+			if (missingCount == 0) {
+				replaceString = replaceString + "</table></br>" + "\n" + "<table width=\"65%\" border=\"1\" bgcolor=\"#EEEEEE\" rules=\"groups\" align=\"center\">" + "<tr bgcolor=\"#9999CC\"> <th width=\"80%\" align=\"center\"> Missing Files </th><th  align=\"center\"> Status </th></tr>";
+			}
+			replaceString = replaceString + tmp;
+			testResultsWithProblems = testResultsWithProblems.concat("\n" + testLogName.substring(0, testLogName.length() - 4) + " (file missing)");
+			missingCount++;
+		}
+		return replaceString;
+	}
+
+	public void parseXml() {
+
+		File sourceDirectory = new File(xmlDirectoryName);
+
+		if (sourceDirectory.exists()) {
+
+			String replaceString = "";
+
+			File[] xmlFileNames = sourceDirectory.listFiles();
+			Arrays.sort(xmlFileNames);
+
+			for (int i = 0; i < xmlFileNames.length; i++) {
+				if (xmlFileNames[i].getPath().endsWith(".xml")) {
+					String fullName = xmlFileNames[i].getPath();
+					int errorCount = countErrors(fullName);
+					if (errorCount != 0) {
+						String testName = xmlFileNames[i].getName().substring(0, xmlFileNames[i].getName().length() - 4);
+						testResultsWithProblems = testResultsWithProblems.concat("\n" + testName);
+						anErrorTracker.registerError(fullName.substring(getXmlDirectoryName().length() + 1));
+					}
+
+
+					String tmp = ((platformSpecificTemplateList == "") ? formatRow(xmlFileNames[i].getPath(), errorCount, true) : formatRowReleng(xmlFileNames[i].getPath(), errorCount, true));
+					replaceString = replaceString + tmp;
+
+
+				}
+			}
+			// check for missing test logs
+			replaceString = replaceString + verifyAllTestsRan(xmlDirectoryName);
+
+			testResultsTemplateString = replace(testResultsTemplateString, testResultsToken, replaceString);
+			testsRan = true;
+
+		}
+		else {
+			testsRan = false;
+			System.out.println("Test results not found in " + sourceDirectory.getAbsolutePath());
+		}
+
+	}
+
+	private String replace(String source, String original, String replacement) {
+
+		int replaceIndex = source.indexOf(original);
+		if (replaceIndex > -1) {
+			String resultString = source.substring(0, replaceIndex);
+			resultString = resultString + replacement;
+			resultString = resultString + source.substring(replaceIndex + original.length());
+			return resultString;
+		}
+		else {
+			System.out.println("Could not find token: " + original);
+			return source;
+		}
+
+	}
+
+	protected void writeDropFiles() {
+		writeDropIndexFile();
+		// Write all the platform files
+		for (int i = 0; i < platformDescription.size(); i++) {
+			writePlatformFile(platformDescription.get(i).toString(), platformTemplateString.get(i).toString(), platformDropFileName.get(i).toString());
+		}
+	}
+
+	protected void writeDropIndexFile() {
+
+		String[] types = anErrorTracker.getTypes();
+		for (int i = 0; i < types.length; i++) {
+			PlatformStatus[] platforms = anErrorTracker.getPlatforms(types[i]);
+			String replaceString = processDropRows(platforms);
+			dropTemplateString = replace(dropTemplateString, dropTokens.get(i).toString(), replaceString);
+		}
+		// Replace the token %testsStatus% with the status of the test results
+		dropTemplateString = replace(dropTemplateString, "%testsStatus%", testResultsStatus);
+		String outputFileName = dropDirectoryName + File.separator + dropHtmlFileName;
+		writeFile(outputFileName, dropTemplateString);
+	}
+
+	// Writes the platform file (dropFileName) specific to "desiredPlatform"
+	protected void writePlatformFile(String desiredPlatform, String templateString, String dropFileName) {
+
+		String[] types = anErrorTracker.getTypes();
+		for (int i = 0; i < types.length; i++) {
+			PlatformStatus[] platforms = anErrorTracker.getPlatforms(types[i]);
+			// Call processPlatformDropRows passing the platform's name
+			String replaceString = processPlatformDropRows(platforms, desiredPlatform);
+			templateString = replace(templateString, dropTokens.get(i).toString(), replaceString);
+		}
+		// Replace the platformIdentifierToken with the platform's name and
+		// the testsStatus
+		// token with the status of the test results
+		templateString = replace(templateString, platformIdentifierToken, desiredPlatform);
+		templateString = replace(templateString, "%testsStatus%", testResultsStatus);
+		String outputFileName = dropDirectoryName + File.separator + dropFileName;
+		writeFile(outputFileName, templateString);
+	}
+
+	// Process drop rows specific to each of the platforms
+	protected String processPlatformDropRows(PlatformStatus[] platforms, String name) {
+
+		String result = "";
+		boolean found = false;
+		for (int i = 0; i < platforms.length; i++) {
+			// If the platform description indicates the platform's name, or
+			// "All",
+			// call processDropRow
+			if (platforms[i].getName().startsWith(name.substring(0, 3)) || platforms[i].getName().equals("All")) {
+				result = result + processDropRow(platforms[i]);
+				found = true;
+			}
+			// If the platform description indicates "All Other Platforms",
+			// process
+			// the row locally
+			else if (platforms[i].getName().equals("All Other Platforms") && !found) {
+				String imageName = "";
+
+				if (platforms[i].hasErrors()) {
+					imageName = "<a href=\"" + getTestResultsHtmlFileName() + "\"><img src = \"FAIL.gif\" width=19 height=23></a>";
+				}
+				else {
+					if (testsRan) {
+						imageName = "<img src = \"OK.gif\" width=19 height=23>";
+					}
+					else {
+						if (isBuildTested) {
+							imageName = "<font size=\"-1\" color=\"#FF0000\">pending</font>";
+						}
+						else {
+							imageName = "<img src = \"OK.gif\" width=19 height=23>";
+						}
+					}
+				}
+
+				result = result + "<tr>";
+				result = result + "<td><div align=left>" + imageName + "</div></td>\n";
+				result = result + "<td>All " + name + "</td>";
+				// generate ftp, http, md5 and sha1 links by calling php
+				// functions in the template
+				result = result + "<td><?php genLinks($_SERVER[\"SERVER_NAME\"],\"@buildlabel@\",\"" + platforms[i].getFileName() + "\"); ?></td>\n";
+				result = result + "</tr>\n";
+			}
+		}
+
+		return result;
+	}
+
+	protected String processDropRows(PlatformStatus[] platforms) {
+
+		String result = "";
+		for (int i = 0; i < platforms.length; i++) {
+			result = result + processDropRow(platforms[i]);
+		}
+
+		return result;
+	}
+
+	protected String processDropRow(PlatformStatus aPlatform) {
+
+		String imageName = "";
+
+		if (aPlatform.hasErrors()) {
+			imageName = "<a href=\"" + getTestResultsHtmlFileName() + "\"><img src = \"FAIL.gif\" width=19 height=23></a>";
+			// Failure in tests
+			testResultsStatus = "failed";
+		}
+		else {
+			if (testsRan) {
+				imageName = "<img src = \"OK.gif\" width=19 height=23>";
+			}
+			else {
+				if (isBuildTested) {
+					imageName = "<font size=\"-1\" color=\"#FF0000\">pending</font>";
+					// Tests are pending
+					testResultsStatus = "pending";
+				}
+				else {
+					imageName = "<img src = \"OK.gif\" width=19 height=23>";
+				}
+			}
+		}
+
+		String result = "<tr>";
+
+		result = result + "<td><div align=left>" + imageName + "</div></td>\n";
+		result = result + "<td>" + aPlatform.getName() + "</td>";
+		result = result + "<td>" + aPlatform.getFileName() + "</td>\n";
+		result = result + "</tr>\n";
+
+		return result;
+	}
+
+	public void writeTestResultsFile() {
+
+		String outputFileName = dropDirectoryName + File.separator + testResultsHtmlFileName;
+		writeFile(outputFileName, testResultsTemplateString);
+	}
+
+	private void writeFile(String outputFileName, String contents) {
+		FileOutputStream outputStream = null;
+		try {
+			outputStream = new FileOutputStream(outputFileName);
+			outputStream.write(contents.getBytes());
+		}
+		catch (FileNotFoundException e) {
+			System.out.println("File not found exception writing: " + outputFileName);
+		}
+		catch (IOException e) {
+			System.out.println("IOException writing: " + outputFileName);
+		}
+		finally {
+			if (outputStream != null) {
+				try {
+					outputStream.close();
+				}
+				catch (IOException e) {
+					// ignore
+				}
+			}
+		}
+	}
+
+	public void setTestResultsHtmlFileName(String aString) {
+		testResultsHtmlFileName = aString;
+	}
+
+	public String getTestResultsHtmlFileName() {
+		return testResultsHtmlFileName;
+	}
+
+	public void setTestResultsTemplateFileName(String aString) {
+		testResultsTemplateFileName = aString;
+	}
+
+	public String getTestResultsTemplateFileName() {
+		return testResultsTemplateFileName;
+	}
+
+	public void setXmlDirectoryName(String aString) {
+		xmlDirectoryName = aString;
+	}
+
+	public String getXmlDirectoryName() {
+		return xmlDirectoryName;
+	}
+
+	public void setHtmlDirectoryName(String aString) {
+		htmlDirectoryName = aString;
+	}
+
+	public String getHtmlDirectoryName() {
+		return htmlDirectoryName;
+	}
+
+	public void setDropDirectoryName(String aString) {
+		dropDirectoryName = aString;
+	}
+
+	public String getDropDirectoryName() {
+		return dropDirectoryName;
+	}
+
+	private void formatCompileErrorRow(String fileName, int errorCount, int warningCount, int forbiddenAccessWarningCount, int discouragedAccessWarningCount, StringBuffer buffer) {
+
+		int accessRuleWarningCount = forbiddenAccessWarningCount + discouragedAccessWarningCount;
+		if (!includeAll) {
+			if (errorCount == 0 && warningCount == 0 && accessRuleWarningCount == 0) {
+				return;
+			}
+		}
+
+		int i = fileName.indexOf(getHrefCompileLogsTargetPath());
+
+		String shortName = fileName.substring(i + getHrefCompileLogsTargetPath().length());
+
+		buffer.append("<tr>\n<td>\n").append("<a href=").append("\"").append(getHrefCompileLogsTargetPath()).append(shortName).append("\">").append(shortName).append("</a>").append("</td><td align=\"center\">").append("<a href=").append("\"").append(getHrefCompileLogsTargetPath()).append(shortName).append("#ERRORS").append("\">").append(errorCount).append("</a>").append("</td><td align=\"center\">").append("<a href=").append("\"").append(getHrefCompileLogsTargetPath()).append(shortName).append("#ACCESSRULES_WARNINGS").append("\">").append(accessRuleWarningCount).append("</a>").append("(").append(forbiddenAccessWarningCount).append("/").append(discouragedAccessWarningCount).append(")").append("</td><td align=\"center\">").append("<a href=").append("\"").append(getHrefCompileLogsTargetPath()).append(shortName).append("#OTHER_WARNINGS").append("\">").append(warningCount).append("</a>").append("</td>\n</tr>\n");
+	}
+
+	private String formatRow(String fileName, int errorCount, boolean link) {
+
+		// replace .xml with .html
+
+		String aString = "";
+		if (!link) {
+			return "<tr><td>" + fileName + " (missing)" + "</td><td>" + "DNF";
+		}
+
+		if (fileName.endsWith(".xml")) {
+
+			int begin = fileName.lastIndexOf(File.separatorChar);
+			int end = fileName.lastIndexOf(".xml");
+
+			String shortName = fileName.substring(begin + 1, end);
+			String displayName = shortName;
+			if (errorCount != 0)
+				aString = aString + "<tr><td><b>";
+			else
+				aString = aString + "<tr><td>";
+
+
+			if (errorCount != 0) {
+				displayName = "<font color=\"#ff0000\">" + displayName + "</font>";
+			}
+			if (errorCount == -1) {
+				aString = aString.concat(displayName);
+			}
+			else {
+				aString = aString + "<a href=" + "\"" + hrefTestResultsTargetPath + "/" + shortName + ".html" + "\">" + displayName + "</a>";
+			}
+			if (errorCount > 0)
+				aString = aString + "</td><td><b>";
+			else
+				aString = aString + "</td><td>";
+
+			if (errorCount == -1)
+				aString = aString + "<font color=\"#ff0000\">DNF";
+
+			else if (errorCount > 0)
+				aString = aString + "<font color=\"#ff0000\">" + String.valueOf(errorCount);
+			else
+				aString = aString + String.valueOf(errorCount);
+
+			if (errorCount != 0)
+				aString = aString + "</font></b></td></tr>";
+			else
+				aString = aString + "</td></tr>";
+		}
+
+		return aString;
+
+	}
+
+	// Specific to the RelEng test results page
+	private String formatRowReleng(String fileName, int errorCount, boolean link) {
+
+		// If the file name doesn't end with any of the set test
+		// configurations, do nothing
+		boolean endsWithConfig = false;
+		int card = testsConfig.length;
+		for (int i = 0; i < card; i++) {
+			if (fileName.endsWith(testsConfig[i]))
+				endsWithConfig = true;
+		}
+		if (!endsWithConfig)
+			return "";
+
+		String aString = "";
+		if (!link) {
+			return "<tr><td>" + fileName + "</td><td align=\"center\">" + "DNF </tr>";
+		}
+
+		if (fileName.endsWith(".xml")) {
+
+			int begin = fileName.lastIndexOf(File.separatorChar);
+
+			// Get org.eclipse. out of the component name
+			String shortName = fileName.substring(begin + 13, fileName.indexOf('_'));
+			String displayName = shortName;
+
+			// If the short name does not start with this prefix
+			if (!shortName.startsWith(prefix)) {
+				// If the prefix is not yet set
+				if (prefix == "default") {
+					// Set the testShortName variable to the current short
+					// name
+					testShortName = shortName;
+					counter = 0;
+					// Set new prefix
+					prefix = shortName.substring(0, shortName.indexOf(".tests") + 6);
+					aString = aString + "<tbody><tr><td><b>" + prefix + ".*" + "</b><td><td><td><td>";
+					aString = aString + "<tr><td><P>" + shortName;
+
+					// Loop until the matching string postfix(test config.) is
+					// found
+					while (counter < card && !fileName.endsWith(testsConfig[counter])) {
+						aString = aString + "<td align=\"center\">-</td>";
+						counter++;
+					}
+				}
+				else {
+					// Set new prefix
+					prefix = shortName.substring(0, shortName.indexOf(".tests") + 6);
+
+					// Loop until the matching string postfix(test config.) is
+					// found
+					while (counter < card && !fileName.endsWith(testsConfig[counter])) {
+						aString = aString + "<td align=\"center\">-</td>";
+						counter++;
+					}
+
+					// In this case, the new prefix should be set with the
+					// short name under it,
+					// since this would mean that the team has more than one
+					// component test
+					if (!shortName.endsWith("tests")) {
+						aString = aString + "<tbody><tr><td><b>" + prefix + ".*" + "</b><td><td><td><td>";
+						aString = aString + "<tr><td><P>" + shortName;
+					}
+					// The team has only one component test
+					else
+						aString = aString + "<tbody><tr><td><b>" + shortName;
+					testShortName = shortName;
+
+					counter = 0;
+				}
+			}
+			// If the file's short name starts with the current prefix
+			if (shortName.startsWith(prefix)) {
+				// If the new file has a different short name than the current
+				// one
+				if (!shortName.equals(testShortName)) {
+					// Fill the remaining cells with '-'. These files will
+					// later be listed as
+					// missing
+					while (counter < card) {
+						aString = aString + "<td align=\"center\">-</td>";
+						counter++;
+					}
+					counter = 0;
+					// Print the component name
+					aString = aString + "<tr><td><P>" + shortName;
+					// Loop until the matching string postfix(test config.) is
+					// found
+					while (counter < card && !fileName.endsWith(testsConfig[counter])) {
+						aString = aString + "<td align=\"center\">-</td>";
+						counter++;
+					}
+				}
+				else {
+					// Loop until the matching string postfix(test config.) is
+					// found
+					while (counter < card && !fileName.endsWith(testsConfig[counter])) {
+						aString = aString + "<td align=\"center\">-</td>";
+						counter++;
+					}
+					// If the previous component has no more test files left
+					if (counter == card) {
+						counter = 0;
+						// Print the new component name
+						aString = aString + "<tr><td><P>" + shortName;
+						// Loop until the matching string postfix(test
+						// config.) is found
+						while (counter < card && !fileName.endsWith(testsConfig[counter])) {
+							aString = aString + "<td align=\"center\">-</td>";
+							counter++;
+						}
+					}
+				}
+
+				testShortName = shortName;
+
+				if (errorCount != 0)
+					aString = aString + "<td align=\"center\"><b>";
+				else
+					aString = aString + "<td align=\"center\">";
+
+				// Print number of errors
+				if (errorCount != 0) {
+					displayName = "<font color=\"#ff0000\">" + "(" + String.valueOf(errorCount) + ")" + "</font>";
+				}
+				else {
+					displayName = "(0)";
+				}
+
+				// Reference
+				if (errorCount == -1) {
+					aString = aString.concat(displayName);
+				}
+				else {
+					aString = aString + "<a href=" + "\"" + hrefTestResultsTargetPath + "/" + fileName.substring(begin + 1, fileName.length() - 4) + ".html" + "\">" + displayName + "</a>";
+				}
+
+				if (errorCount == -1)
+					aString = aString + "<font color=\"#ff0000\">DNF";
+
+				if (errorCount != 0)
+					aString = aString + "</font></b></td>";
+				else
+					aString = aString + "</td>";
+				counter++;
+			}
+		}
+
+		return aString;
+	}
+
+	private int countErrors(String fileName) {
+		int errorCount = 0;
+
+		if (new File(fileName).length() == 0)
+			return -1;
+
+		try {
+			DocumentBuilderFactory docBuilderFactory = DocumentBuilderFactory.newInstance();
+			parser = docBuilderFactory.newDocumentBuilder();
+
+			Document document = parser.parse(fileName);
+			NodeList elements = document.getElementsByTagName(elementName);
+
+			int elementCount = elements.getLength();
+			if (elementCount == 0)
+				return -1;
+			for (int i = 0; i < elementCount; i++) {
+				Element element = (Element) elements.item(i);
+				NamedNodeMap attributes = element.getAttributes();
+				Node aNode = attributes.getNamedItem("errors");
+				errorCount = errorCount + Integer.parseInt(aNode.getNodeValue());
+				aNode = attributes.getNamedItem("failures");
+				errorCount = errorCount + Integer.parseInt(aNode.getNodeValue());
+
+			}
+
+		}
+		catch (IOException e) {
+			System.out.println("IOException: " + fileName);
+			// e.printStackTrace();
+			return 0;
+		}
+		catch (SAXException e) {
+			System.out.println("SAXException: " + fileName);
+			// e.printStackTrace();
+			return 0;
+		}
+		catch (ParserConfigurationException e) {
+			e.printStackTrace();
+		}
+		return errorCount;
+	}
+
+
+
+	/**
+	 * Gets the hrefTestResultsTargetPath.
+	 * 
+	 * @return Returns a String
+	 */
+	public String getHrefTestResultsTargetPath() {
+		return hrefTestResultsTargetPath;
+	}
+
+	/**
+	 * Sets the hrefTestResultsTargetPath.
+	 * 
+	 * @param hrefTestResultsTargetPath
+	 *            The hrefTestResultsTargetPath to set
+	 */
+	public void setHrefTestResultsTargetPath(String htmlTargetPath) {
+		this.hrefTestResultsTargetPath = htmlTargetPath;
+	}
+
+	/**
+	 * Gets the compileLogsDirectoryName.
+	 * 
+	 * @return Returns a String
+	 */
+	public String getCompileLogsDirectoryName() {
+		return compileLogsDirectoryName;
+	}
+
+	/**
+	 * Sets the compileLogsDirectoryName.
+	 * 
+	 * @param compileLogsDirectoryName
+	 *            The compileLogsDirectoryName to set
+	 */
+	public void setCompileLogsDirectoryName(String compileLogsDirectoryName) {
+		this.compileLogsDirectoryName = compileLogsDirectoryName;
+	}
+
+	/**
+	 * Gets the hrefCompileLogsTargetPath.
+	 * 
+	 * @return Returns a String
+	 */
+	public String getHrefCompileLogsTargetPath() {
+		return hrefCompileLogsTargetPath;
+	}
+
+	/**
+	 * Sets the hrefCompileLogsTargetPath.
+	 * 
+	 * @param hrefCompileLogsTargetPath
+	 *            The hrefCompileLogsTargetPath to set
+	 */
+	public void setHrefCompileLogsTargetPath(String hrefCompileLogsTargetPath) {
+		this.hrefCompileLogsTargetPath = hrefCompileLogsTargetPath;
+	}
+
+	/**
+	 * Gets the testManifestFileName.
+	 * 
+	 * @return Returns a String
+	 */
+	public String getTestManifestFileName() {
+		return testManifestFileName;
+	}
+
+	/**
+	 * Sets the testManifestFileName.
+	 * 
+	 * @param testManifestFileName
+	 *            The testManifestFileName to set
+	 */
+	public void setTestManifestFileName(String testManifestFileName) {
+		this.testManifestFileName = testManifestFileName;
+	}
+
+	/**
+	 * Gets the dropHtmlFileName.
+	 * 
+	 * @return Returns a String
+	 */
+	public String getDropHtmlFileName() {
+		return dropHtmlFileName;
+	}
+
+	/**
+	 * Sets the dropHtmlFileName.
+	 * 
+	 * @param dropHtmlFileName
+	 *            The dropHtmlFileName to set
+	 */
+	public void setDropHtmlFileName(String dropHtmlFileName) {
+		this.dropHtmlFileName = dropHtmlFileName;
+	}
+
+	/**
+	 * Gets the dropTemplateFileName.
+	 * 
+	 * @return Returns a String
+	 */
+	public String getDropTemplateFileName() {
+		return dropTemplateFileName;
+	}
+
+	/**
+	 * Sets the dropTemplateFileName.
+	 * 
+	 * @param dropTemplateFileName
+	 *            The dropTemplateFileName to set
+	 */
+	public void setDropTemplateFileName(String dropTemplateFileName) {
+		this.dropTemplateFileName = dropTemplateFileName;
+	}
+
+	protected void getDropTokensFromList(String list) {
+		StringTokenizer tokenizer = new StringTokenizer(list, ",");
+		dropTokens = new Vector();
+
+		while (tokenizer.hasMoreTokens()) {
+			dropTokens.add(tokenizer.nextToken());
+		}
+	}
+
+	protected void getDifferentPlatformsFromList(String list) {
+		StringTokenizer tokenizer = new StringTokenizer(list, ";");
+		differentPlatforms = new Vector();
+
+		while (tokenizer.hasMoreTokens()) {
+			differentPlatforms.add(tokenizer.nextToken());
+		}
+	}
+
+	protected void getPlatformSpecsFromList(String list) {
+		StringTokenizer tokenizer = new StringTokenizer(list, ",");
+		platformSpecs = new Vector();
+
+		while (tokenizer.hasMoreTokens()) {
+			platformSpecs.add(tokenizer.nextToken());
+		}
+	}
+
+	public String getDropTokenList() {
+		return dropTokenList;
+	}
+
+	public void setDropTokenList(String dropTokenList) {
+		this.dropTokenList = dropTokenList;
+	}
+
+	public boolean isBuildTested() {
+		return isBuildTested;
+	}
+
+	public void setIsBuildTested(boolean isBuildTested) {
+		this.isBuildTested = isBuildTested;
+	}
+
+
+	/**
+	 * @return
+	 */
+	public boolean testsRan() {
+		return testsRan;
+	}
+
+	/**
+	 * @param b
+	 */
+	public void setTestsRan(boolean b) {
+		testsRan = b;
+	}
+
+	/**
+	 * @return
+	 */
+	public Vector getDropTokens() {
+		return dropTokens;
+	}
+
+	/**
+	 * @param vector
+	 */
+	public void setDropTokens(Vector vector) {
+		dropTokens = vector;
+	}
+
+	/**
+	 * @return
+	 */
+	public String getTestResultsWithProblems() {
+		return testResultsWithProblems;
+	}
+
+	/**
+	 * @param string
+	 */
+	public void setTestResultsWithProblems(String string) {
+		testResultsWithProblems = string;
+	}
+
+	public String getBuildType() {
+		return buildType;
+	}
+
+	public void setBuildType(String buildType) {
+		this.buildType = buildType;
+	}
+
+	public String getPlatformSpecificTemplateList() {
+		return platformSpecificTemplateList;
+	}
+
+	public void setPlatformSpecificTemplateList(String platformSpecificTemplateList) {
+		this.platformSpecificTemplateList = platformSpecificTemplateList;
+	}
+
+	public void setPlatformIdentifierToken(String platformIdentifierToken) {
+		this.platformIdentifierToken = platformIdentifierToken;
+	}
+
+	public String getPlatformIdentifierToken() {
+		return platformIdentifierToken;
+	}
+
+	public boolean isIncludeAll() {
+		return includeAll;
+	}
+
+	public void setIncludeAll(boolean includeAll) {
+		this.includeAll = includeAll;
+	}
+
+}
diff --git a/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/wtpRelengTools.jar b/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/wtpRelengTools.jar
new file mode 100644
index 0000000000000000000000000000000000000000..623e66dbde5a9b822295894dee3f27e8d95c5706
Binary files /dev/null and b/archive/releng.builder/tools/org.eclipse.wtp.releng.tools/wtpRelengTools.jar differ