From 13417cf9c6eec555b51da49742e47939d2f5715b Mon Sep 17 00:00:00 2001
From: James Moger <james.moger@gitblit.com>
Date: Fri, 19 Oct 2012 22:47:33 -0400
Subject: [PATCH] Exclude submodules from zip downloads (issue 151)

---
 src/com/gitblit/build/Build.java |  397 ++++++++++++++++++++++++++++++++++++++++----------------
 1 files changed, 285 insertions(+), 112 deletions(-)

diff --git a/src/com/gitblit/build/Build.java b/src/com/gitblit/build/Build.java
index 682adca..d5abc24 100644
--- a/src/com/gitblit/build/Build.java
+++ b/src/com/gitblit/build/Build.java
@@ -20,6 +20,7 @@
 import java.io.File;
 import java.io.FileInputStream;
 import java.io.FileWriter;
+import java.io.FilenameFilter;
 import java.io.IOException;
 import java.io.InputStream;
 import java.io.RandomAccessFile;
@@ -27,9 +28,7 @@
 import java.text.MessageFormat;
 import java.util.ArrayList;
 import java.util.Collections;
-import java.util.HashMap;
 import java.util.List;
-import java.util.Map;
 import java.util.Properties;
 
 import com.gitblit.Constants;
@@ -73,6 +72,7 @@
 	public static void runtime() {
 		downloadFromApache(MavenObject.JCOMMANDER, BuildType.RUNTIME);
 		downloadFromApache(MavenObject.JETTY, BuildType.RUNTIME);
+		downloadFromApache(MavenObject.JETTY_AJP, BuildType.RUNTIME);
 		downloadFromApache(MavenObject.SERVLET, BuildType.RUNTIME);
 		downloadFromApache(MavenObject.SLF4JAPI, BuildType.RUNTIME);
 		downloadFromApache(MavenObject.SLF4LOG4J, BuildType.RUNTIME);
@@ -90,6 +90,13 @@
 		downloadFromApache(MavenObject.GSON, BuildType.RUNTIME);
 		downloadFromApache(MavenObject.MAIL, BuildType.RUNTIME);
 		downloadFromApache(MavenObject.GROOVY, BuildType.RUNTIME);
+		downloadFromApache(MavenObject.LUCENE, BuildType.RUNTIME);
+		downloadFromApache(MavenObject.LUCENE_HIGHLIGHTER, BuildType.RUNTIME);
+		downloadFromApache(MavenObject.LUCENE_MEMORY, BuildType.RUNTIME);
+		downloadFromApache(MavenObject.LUCENE_QUERIES, BuildType.RUNTIME);
+		downloadFromApache(MavenObject.JAKARTA_REGEXP, BuildType.RUNTIME);
+		downloadFromApache(MavenObject.UNBOUND_ID, BuildType.RUNTIME);
+		downloadFromApache(MavenObject.IVY, BuildType.RUNTIME);
 
 		downloadFromEclipse(MavenObject.JGIT, BuildType.RUNTIME);
 		downloadFromEclipse(MavenObject.JGIT_HTTP, BuildType.RUNTIME);
@@ -97,8 +104,10 @@
 
 	public static void compiletime() {
 		downloadFromApache(MavenObject.JUNIT, BuildType.RUNTIME);
+		downloadFromApache(MavenObject.HAMCREST, BuildType.RUNTIME);
 		downloadFromApache(MavenObject.JCOMMANDER, BuildType.COMPILETIME);
 		downloadFromApache(MavenObject.JETTY, BuildType.COMPILETIME);
+		downloadFromApache(MavenObject.JETTY_AJP, BuildType.COMPILETIME);
 		downloadFromApache(MavenObject.SERVLET, BuildType.COMPILETIME);
 		downloadFromApache(MavenObject.SLF4JAPI, BuildType.COMPILETIME);
 		downloadFromApache(MavenObject.SLF4LOG4J, BuildType.COMPILETIME);
@@ -116,6 +125,13 @@
 		downloadFromApache(MavenObject.GSON, BuildType.COMPILETIME);
 		downloadFromApache(MavenObject.MAIL, BuildType.COMPILETIME);
 		downloadFromApache(MavenObject.GROOVY, BuildType.COMPILETIME);
+		downloadFromApache(MavenObject.LUCENE, BuildType.COMPILETIME);
+		downloadFromApache(MavenObject.LUCENE_HIGHLIGHTER, BuildType.COMPILETIME);
+		downloadFromApache(MavenObject.LUCENE_MEMORY, BuildType.COMPILETIME);
+		downloadFromApache(MavenObject.LUCENE_QUERIES, BuildType.COMPILETIME);
+		downloadFromApache(MavenObject.JAKARTA_REGEXP, BuildType.COMPILETIME);
+		downloadFromApache(MavenObject.UNBOUND_ID, BuildType.COMPILETIME);
+		downloadFromApache(MavenObject.IVY, BuildType.COMPILETIME);
 		
 		downloadFromEclipse(MavenObject.JGIT, BuildType.COMPILETIME);
 		downloadFromEclipse(MavenObject.JGIT_HTTP, BuildType.COMPILETIME);
@@ -133,6 +149,11 @@
 		downloadFromApache(MavenObject.LOG4J, BuildType.RUNTIME);
 		downloadFromApache(MavenObject.GSON, BuildType.RUNTIME);
 		downloadFromApache(MavenObject.JSCH, BuildType.RUNTIME);
+		downloadFromApache(MavenObject.LUCENE, BuildType.RUNTIME);
+		downloadFromApache(MavenObject.LUCENE_HIGHLIGHTER, BuildType.RUNTIME);
+		downloadFromApache(MavenObject.LUCENE_MEMORY, BuildType.RUNTIME);
+		downloadFromApache(MavenObject.LUCENE_QUERIES, BuildType.RUNTIME);
+		downloadFromApache(MavenObject.JAKARTA_REGEXP, BuildType.RUNTIME);
 
 		downloadFromEclipse(MavenObject.JGIT, BuildType.RUNTIME);
 	}
@@ -172,66 +193,139 @@
 		List<String> keys = new ArrayList<String>(properties.stringPropertyNames());
 		Collections.sort(keys);
 
-		// Determine static key group classes
-		Map<String, List<String>> staticClasses = new HashMap<String, List<String>>();
-		staticClasses.put("", new ArrayList<String>());
+		KeyGroup root = new KeyGroup();
 		for (String key : keys) {
-			String clazz = "";
-			String field = key;
-			if (key.indexOf('.') > -1) {
-				clazz = key.substring(0, key.indexOf('.'));
-				field = key.substring(key.indexOf('.') + 1);
-			}
-			if (!staticClasses.containsKey(clazz)) {
-				staticClasses.put(clazz, new ArrayList<String>());
-			}
-			staticClasses.get(clazz).add(field);
+			root.addKey(key);
 		}
-
-		// Assemble Keys source file
-		StringBuilder sb = new StringBuilder();
-		sb.append("package com.gitblit;\n");
-		sb.append('\n');
-		sb.append("/*\n");
-		sb.append(" * This class is auto-generated from the properties file.\n");
-		sb.append(" * Do not version control!\n");
-		sb.append(" */\n");
-		sb.append("public final class Keys {\n");
-		sb.append('\n');
-		List<String> classSet = new ArrayList<String>(staticClasses.keySet());
-		Collections.sort(classSet);
-		for (String clazz : classSet) {
-			List<String> keySet = staticClasses.get(clazz);
-			if (clazz.equals("")) {
-				// root keys
-				for (String key : keySet) {
-					sb.append(MessageFormat.format(
-							"\tpublic static final String {0} = \"{1}\";\n\n",
-							key.replace('.', '_'), key));
-				}
-			} else {
-				// class keys
-				sb.append(MessageFormat.format("\tpublic static final class {0} '{'\n\n", clazz));
-				sb.append(MessageFormat.format(
-						"\t\tpublic static final String _ROOT = \"{0}\";\n\n", clazz));
-				for (String key : keySet) {
-					sb.append(MessageFormat.format(
-							"\t\tpublic static final String {0} = \"{1}\";\n\n",
-							key.replace('.', '_'), clazz + "." + key));
-				}
-				sb.append("\t}\n\n");
-			}
-		}
-		sb.append('}');
 
 		// Save Keys class definition
 		try {
 			File file = new File("src/com/gitblit/Keys.java");
 			FileWriter fw = new FileWriter(file, false);
-			fw.write(sb.toString());
+			fw.write(root.generateClass("com.gitblit", "Keys"));
 			fw.close();
 		} catch (Throwable t) {
 			t.printStackTrace();
+		}
+	}
+	
+	private static class KeyGroup {
+		final KeyGroup parent;
+		final String namespace;
+		
+		String name;
+		List<KeyGroup> children;		
+		List<String> fields;		
+		
+		KeyGroup() {
+			this.parent = null;
+			this.namespace = "";
+			this.name = "";	
+		}
+		
+		KeyGroup(String namespace, KeyGroup parent) {
+			this.parent = parent;
+			this.namespace = namespace;
+			if (parent.children == null) {
+				parent.children = new ArrayList<KeyGroup>();
+			}
+			parent.children.add(this);
+		}
+		
+		void addKey(String key) {
+			String keyspace = "";
+			String field = key;
+			if (key.indexOf('.') > -1) {
+				keyspace = key.substring(0, key.lastIndexOf('.'));
+				field = key.substring(key.lastIndexOf('.') + 1);
+				KeyGroup group = addKeyGroup(keyspace);
+				group.addKey(field);
+			} else {
+				if (fields == null) {
+					fields = new ArrayList<String>();
+				}
+				fields.add(key);
+			}
+		}
+				
+		KeyGroup addKeyGroup(String keyspace) {
+			KeyGroup parent = this;
+			KeyGroup node = null;			
+			String [] space = keyspace.split("\\.");
+			for (int i = 0; i < space.length; i++) {
+				StringBuilder namespace = new StringBuilder();
+				for (int j = 0; j <= i; j++) {
+					namespace.append(space[j]);
+					if (j < i) {
+						namespace.append('.');
+					}
+				}
+				if (parent.children != null) {
+					for (KeyGroup child : parent.children) {
+						if (child.name.equals(space[i])) {
+							node = child;					
+						}
+					}
+				}
+				if (node == null) {
+					node = new KeyGroup(namespace.toString(), parent);
+					node.name = space[i];
+				}
+				parent = node;
+				node = null;
+			}
+			return parent;
+		}		
+		
+		String fullKey(String field) {
+			if (namespace.equals("")) {
+				return field;
+			}
+			return namespace + "." + field;
+		}
+		
+		String generateClass(String packageName, String className) {
+			StringBuilder sb = new StringBuilder();
+			sb.append("package ").append(packageName).append(";\n");
+			sb.append('\n');
+			sb.append("/*\n");
+			sb.append(" * This class is auto-generated from the properties file.\n");
+			sb.append(" * Do not version control!\n");
+			sb.append(" */\n");
+			sb.append(MessageFormat.format("public final class {0} '{'\n\n", className));
+			sb.append(generateClass(this, 0));
+			sb.append("}\n");
+			return sb.toString();
+		}
+		
+		String generateClass(KeyGroup group, int level) {
+			String classIndent = StringUtils.leftPad("", level, '\t');
+			String fieldIndent = StringUtils.leftPad("", level + 1, '\t');
+			
+			// begin class
+			StringBuilder sb = new StringBuilder();
+			if (!group.namespace.equals("")) {
+				sb.append(classIndent).append(MessageFormat.format("public static final class {0} '{'\n\n", group.name));
+				sb.append(fieldIndent).append(MessageFormat.format("public static final String _ROOT = \"{0}\";\n\n", group.namespace));
+			}
+			
+			if (group.fields != null) {
+				// fields
+				for (String field : group.fields) {					
+					sb.append(fieldIndent).append(MessageFormat.format("public static final String {0} = \"{1}\";\n\n", field, group.fullKey(field)));
+				}
+			}
+			if (group.children != null) {
+				// inner classes
+				for (KeyGroup child : group.children) {
+					sb.append(generateClass(child, level + 1));
+				}
+			}
+			// end class
+			if (!group.namespace.equals("")) {
+				sb.append(classIndent).append("}\n\n");
+			}
+			return sb.toString();			
 		}
 	}
 
@@ -270,12 +364,23 @@
 		if (BuildType.RUNTIME.equals(type)) {
 			jars = new String[] { "" };
 		} else if (BuildType.COMPILETIME.equals(type)) {
-			jars = new String[] { "-sources", "-javadoc" };
+			jars = new String[] { "-sources" };
 		}
 		for (String jar : jars) {
 			File targetFile = mo.getLocalFile("ext", jar);
+			if ("-sources".equals(jar)) {
+				File relocated = new File("ext/src", targetFile.getName());
+				if (targetFile.exists()) {
+					// move -sources jar to ext/src folder
+					targetFile.renameTo(relocated);
+				}
+				// -sources jars are located in ext/src
+				targetFile = relocated;
+			}
+			
 			if (targetFile.exists()) {
 				downloads.add(targetFile);
+				removeObsoleteArtifacts(mo, type, targetFile.getParentFile());
 				continue;
 			}
 			String expectedSHA1 = mo.getSHA1(jar);
@@ -351,8 +456,40 @@
 				throw new RuntimeException("Error writing to file " + targetFile, e);
 			}
 			downloads.add(targetFile);
+			
+			removeObsoleteArtifacts(mo, type, targetFile.getParentFile());
 		}
 		return downloads;
+	}
+	
+	private static void removeObsoleteArtifacts(final MavenObject mo, final BuildType type, File folder) {
+		File [] removals = folder.listFiles(new FilenameFilter() {
+			@Override
+			public boolean accept(File dir, String name) {
+				String n = name.toLowerCase();
+				String dep = mo.artifact.toLowerCase();
+				if (n.startsWith(dep)) {
+					String suffix = "-" + mo.version;
+					if (type.equals(BuildType.COMPILETIME)) {
+						suffix += "-sources.jar";
+					} else {
+						suffix += ".jar";
+					}
+					if (!n.endsWith(suffix)) {
+						return true;
+					}
+				}
+				return false;
+			}
+		});
+		
+		// delete any matches
+		if (removals != null) {
+			for (File file : removals) {
+				System.out.println("deleting " + file);
+				file.delete();
+			}
+		}
 	}
 
 	private static void updateDownload(float progress, File file) {
@@ -384,65 +521,72 @@
 				"c7adc475ca40c288c93054e0f4fe58f3a98c0cb5");
 
 		public static final MavenObject JETTY = new MavenObject("Jetty",
-				"org/eclipse/jetty/aggregate", "jetty-webapp", "7.4.3.v20110701", 1000000, 680000,
-				2720000, "bde072b178f9650e2308f0babe58a4baaa469e3c",
-				"bc75f05dd4f7fa848720ac669b8b438ee4a6b146",
-				"dcd42f672e734521d1a6ccc0c2f9ecded1a1a281");
+				"org/eclipse/jetty/aggregate", "jetty-webapp", "7.6.7.v20120910", 1000000, 680000,
+				2720000, "d621fa6419aaa37edbcab8e16a5e6b05c9527e62",
+				"b505f7b493c5aa262d371d90754bded8b392ffb0",
+				"");
 
-		public static final MavenObject SERVLET = new MavenObject("Servlet 3.0", "org/glassfish",
-				"javax.servlet", "3.0.1", 84000, 211000, 0,
-				"58f17c941cd0607bb5edcbcafc491d02265ac9a1",
-				"63f2f8bcdd3f138020bbadd5c847e8f3847b77d2", null);
+		public static final MavenObject JETTY_AJP = new MavenObject("Jetty-AJP",
+				"org/eclipse/jetty", "jetty-ajp", "7.6.7.v20120910", 32000, 22000,
+				97000, "578d502bc78ed7aa1c0b6afef4cd59477041ec37", "6cfed9a1354f720fcde12ec15d5e1ae9cf97000c", "");
+		
+		public static final MavenObject SERVLET = new MavenObject("Servlet 3.0", "javax/servlet",
+				"javax.servlet-api", "3.0.1", 84000, 211000, 0,
+				"6bf0ebb7efd993e222fc1112377b5e92a13b38dd",
+				"01952f91d84016a39e31346c9d18bd8c9c4a128a", null);
 
 		public static final MavenObject SLF4JAPI = new MavenObject("SLF4J API", "org/slf4j",
-				"slf4j-api", "1.6.1", 25500, 45000, 182000,
-				"6f3b8a24bf970f17289b234284c94f43eb42f0e4",
-				"46a386136c901748e6a3af67ebde6c22bc6b4524",
-				"e223571d77769cdafde59040da235842f3326453");
+				"slf4j-api", "1.6.6", 25500, 45000, 182000,
+				"ce53b0a0e2cfbb27e8a59d38f79a18a5c6a8d2b0",
+				"bcd0e21b1572960cefd449f8a16efab5b6b8e644",
+				"4253b52aabf1c5a5f20c191a261e6ada0fcf621d");
 
 		public static final MavenObject SLF4LOG4J = new MavenObject("SLF4J LOG4J", "org/slf4j",
-				"slf4j-log4j12", "1.6.1", 9800, 9500, 52400,
-				"bd245d6746cdd4e6203e976e21d597a46f115802",
-				"7a26b08b265f55622fa1fed3bda68bbd37a465ba",
-				"6e4b16bce7994e3692e82002f322a0dd2f32741e");
+				"slf4j-log4j12", "1.6.6", 9800, 9500, 52400,
+				"5cd9b4fbc3ff6a97beaade3206137d76f65df805",
+				"497bfac9a678118e7ff75d1f3b8c3bcc06dc9c8c",
+				"69855e2a85d9249bb577df3c5076bc2cb34975d7");
 
 		public static final MavenObject LOG4J = new MavenObject("Apache LOG4J", "log4j", "log4j",
-				"1.2.16", 481000, 471000, 1455000, "7999a63bfccbc7c247a9aea10d83d4272bd492c6",
-				"bf945d1dc995be7fe64923625f842fbb6bf443be",
-				"78aa1cbf0fa3b259abdc7d87f9f6788d785aac2a");
+				"1.2.17", 481000, 471000, 1455000, "5af35056b4d257e4b64b9e8069c0746e8b08629f",
+				"677abe279b68c5e7490d6d50c6951376238d7d3e",
+				"c10c20168206896442f3192d5417815df7fcbf9a");
 
 		public static final MavenObject WICKET = new MavenObject("Apache Wicket",
-				"org/apache/wicket", "wicket", "1.4.19", 1960000, 1906000, 6818000,
-				"7e6af5cadaf6c9b7e068e45cf2ffbea3cc91592f",
-				"5e91cf00efaf2fedeef98e13464a4230e5966588",
-				"5dde8afbe5eb2314a704cb74938c1b651b2cf190");
+				"org/apache/wicket", "wicket", "1.4.21", 1960000, 1906000, 6818000,
+				"cce9dfd3088e18a3cdcf9be33b5b76caa48dc4c6",
+				"e8c2bfe2c96a2da7a0eca947a2f60dc3242e7229",
+				"");
 
 		public static final MavenObject WICKET_EXT = new MavenObject("Apache Wicket Extensions",
-				"org/apache/wicket", "wicket-extensions", "1.4.19", 1180000, 1118000, 1458000,
-				"c7a1d343e216cdc2e692b6fabc6eaeca9aa24ca4",
-				"6c2e2ad89b69fc9977c24467e3aa0d7f6c75a579",
-				"3a3082fb106173f7ca069a6f5969cc8d347d9f44");
+				"org/apache/wicket", "wicket-extensions", "1.4.21", 1180000, 1118000, 1458000,
+				"fac510c7ee4399a29b927405ec3de40b67d105d8",
+				"ee3409ce9ed64ad8cc8d69abbd7d63f07e10851a",
+				"");
 
 		public static final MavenObject WICKET_AUTH_ROLES = new MavenObject(
-				"Apache Wicket Auth Roles", "org/apache/wicket", "wicket-auth-roles", "1.4.19",
-				44000, 45000, 166000, "70c26ac4cd167bf7323372d2d49eb2a9beff73b9",
-				"ca219726c1768a9483e4a0bb6550881babfe46d6",
-				"17753908f8a9e997c464a69765b4682126fa1fd6");
+				"Apache Wicket Auth Roles", "org/apache/wicket", "wicket-auth-roles", "1.4.21",
+				44000, 45000, 166000, "e78df70ca942e2e15287c393f236b32fbe6f9a30",
+				"47c301212cce43a70caa72f41a9a1aefcf26a533",
+				"");
 
 		public static final MavenObject WICKET_GOOGLE_CHARTS = new MavenObject(
-				"Apache Wicket Google Charts Add-On", "org/wicketstuff", "googlecharts", "1.4.18",
-				34000, 18750, 161000, "1f763cc8a04e62840b63787a77a479b04ad99c75",
-				"1521ed6397192c464e89787502f937bc96ece8f8",
-				"8b0398d58bce63ba7f7a9232c4ca24160c9b1a11");
+				"Apache Wicket Google Charts Add-On", "org/wicketstuff", "googlecharts", "1.4.21",
+				34000, 18750, 161000, "73d7540267afc3a0e91ca6148d3073e050dba180",
+				"627b125cc6029d4d5c59c3a910c1bef347384d97",
+				"");
 
-		public static final MavenObject JUNIT = new MavenObject("JUnit", "junit", "junit", "4.8.2",
-				237000, 0, 0, "c94f54227b08100974c36170dcb53329435fe5ad", "", "");
+		public static final MavenObject JUNIT = new MavenObject("JUnit", "junit", "junit", "4.10",
+				253000, 141000, 0, "e4f1766ce7404a08f45d859fb9c226fc9e41a861", "6c98d6766e72d5575f96c9479d1c1d3b865c6e25", "");
+
+		public static final MavenObject HAMCREST = new MavenObject("Hamcrest Core", "org/hamcrest", "hamcrest-core", "1.1",
+				77000, 0, 0, "860340562250678d1a344907ac75754e259cdb14", null, "");
 
 		public static final MavenObject MARKDOWNPAPERS = new MavenObject("MarkdownPapers",
-				"org/tautua/markdownpapers", "markdownpapers-core", "1.2.5", 87000, 58000, 268000,
-				"295910b1893d73d4803f9ea2790ee1d10c466364",
-				"2170f358f29886aea8794c4bfdb6f1b27b152b9b",
-				"481599f34cb2abe4a9ebc771d8d81823375ec1ce");
+				"org/tautua/markdownpapers", "markdownpapers-core", "1.2.7", 87000, 58000, 268000,
+				"84ac5636ac7ddfad9d2ee8456a0f4f69709b6ee0",
+				"453cf00a289c46a0e4f6f019a28d2a2605f652c8",
+				"");
 
 		public static final MavenObject BOUNCYCASTLE = new MavenObject("BouncyCastle",
 				"org/bouncycastle", "bcprov-jdk16", "1.46", 1900000, 1400000, 4670000,
@@ -457,16 +601,16 @@
 				"3b7c5f3938f202311bdca0bf7ed46bc0118af081");
 
 		public static final MavenObject JGIT = new MavenObject("JGit", "org/eclipse/jgit",
-				"org.eclipse.jgit", "1.2.0.201112221803-r", 1318000, 1354000, 3300000,
-				"f3bbea50b64c2c8e20176f412d2f063bd132878f",
-				"f6c616413540e226a6b72bc573a40410412e234f",
-				"a77e5ee65ba284d12ae444ac42e12948a9314c20");
+				"org.eclipse.jgit", "2.1.0.201209190230-r", 1600000, 1565000, 3460000,
+				"5e7296d21645a479a1054fc96f3ec8469cede137",
+				"5f492aaeae1beda2a31d1efa182f5d34e76d7b77",
+				"");
 
 		public static final MavenObject JGIT_HTTP = new MavenObject("JGit", "org/eclipse/jgit",
-				"org.eclipse.jgit.http.server", "1.2.0.201112221803-r", 68000, 62000, 110000,
-				"0d0004423b71bf7c29cd4ad85010c293c4fab95f",
-				"89be774b6db17bbc47b4757ae9e5178750064880",
-				"4cde29a085200ccf46ac677aeb1abb39352a3a6a");
+				"org.eclipse.jgit.http.server", "2.1.0.201209190230-r", 68000, 62000, 110000,
+				"0bd9e5801c246d6f8ad9268d18c45ca9915f9a50",
+				"210c434c38ddcf2126af250018d5845ea41ff502",
+				"");
 
 		public static final MavenObject JSCH = new MavenObject("JSch", "com/jcraft", "jsch",
 				"0.1.44-1", 214000, 211000, 413000, "2e9ae08de5a71bd0e0d3ba2558598181bfa71d4e",
@@ -482,25 +626,54 @@
 				"226f851dc44fd94fe70b9c471881b71f88949cbf",
 				"8d7d867b97eeb3a9196c3926da550ad042941c1b");
 
-		public static final MavenObject JDOM = new MavenObject("jdom", "org/jdom", "jdom", "1.1",
-				153000, 235000, 445000, "1d04c0f321ea337f3661cf7ede8f4c6f653a8fdd",
-				"a7ed425c4c46605b8f2bf2ee118c1609682f4f2c",
-				"f3df91edccba2f07a0fced70887c2f7b7836cb75");
+		public static final MavenObject JDOM = new MavenObject("jdom", "jdom", "jdom", "1.0",
+				153000, 235000, 445000, "a2ac1cd690ab4c80defe7f9bce14d35934c35cec",
+				"662abe0196cf554d4d7374f5d6382034171b652c",
+				"");
 
 		public static final MavenObject GSON = new MavenObject("gson", "com/google/code/gson",
-				"gson", "1.7.1", 174000, 142000, 247000,
-				"0697e3a1fa094a983cd12f7f6f61abf9c6ea52e2",
-				"51f6f78aec2d30d0c2bfb4a5f00d456a6f7a5e7e",
-				"f0872fe17d484815328538b89909d5e46d85db74");
+				"gson", "1.7.2", 174000, 142000, 247000,
+				"112366d8158749e25532ebce162232c6e0fb20a5",
+				"a6fe3006df46174a9c1c56b3c51357b9bfde5874",
+				"537f729ac63b6132a795a3c1f2e13b327e872333");
 
 		public static final MavenObject MAIL = new MavenObject("javax.mail", "javax/mail", "mail",
 				"1.4.3", 462000, 642000, 0, "8154bf8d666e6db154c548dc31a8d512c273f5ee",
 				"5875e2729de83a4e46391f8f979ec8bd03810c10", null);
 
 		public static final MavenObject GROOVY = new MavenObject("groovy", "org/codehaus/groovy", "groovy-all",
-				"1.8.5", 6143000, 2290000, 4608000, "3be3914c49ca7d8e8afb29a7772a74c30a1f1b28",
-				"1435cc8c90e3a91e5fee7bb53e83aad96e93aeb7", "5a214b52286523f9e2a4b5fed526506c763fa6f1");
+				"1.8.8", 6143000, 2290000, 4608000, "98a489343d3c30da817d36cbea5de11ed07bef31",
+				"5f847ed18009f8a034bad3906e39f771c01728c1", "");
 
+		public static final MavenObject LUCENE = new MavenObject("lucene", "org/apache/lucene", "lucene-core",
+				"3.6.1", 1540000, 1431000, 3608000, "6ae2c83c77a1ffa5840b9151a271ab3f451f6e0c",
+				"6925deb6b78e63bbcac382004f00b98133327057", "");
+
+		public static final MavenObject LUCENE_HIGHLIGHTER = new MavenObject("lucene highlighter", "org/apache/lucene", "lucene-highlighter",
+				"3.6.1", 89200, 85000, 0, "2bd49695e9891697c5f290aa94c3412dfb95b096",
+				"20ae81816ce9c27186ef0f2e92a57812c9ee3b6c", "");
+
+		public static final MavenObject LUCENE_MEMORY = new MavenObject("lucene memory", "org/apache/lucene", "lucene-memory",
+				"3.6.1", 30000, 23000, 0, "8c7ca5572edea50973dc0d26cf75c27047eebe7e",
+				"2e291e96d25132e002b1c8240e361d1272d113e1", "");
+
+		public static final MavenObject LUCENE_QUERIES = new MavenObject("lucene queries", "org/apache/lucene", "lucene-queries",
+				"3.6.1", 47400, 48600, 0, "4ed6022dd4aa80b932a1546e7e39e3b8bbe7acb7",
+				"dc425c75d988e4975d314772035a46b6a17dcc8d", "");
+
+		public static final MavenObject JAKARTA_REGEXP = new MavenObject("jakarta regexp", "jakarta-regexp", "jakarta-regexp",
+				"1.4", 28500, 0, 0, "0ea514a179ac1dd7e81c7e6594468b9b9910d298",
+				null, "");
+		
+		public static final MavenObject UNBOUND_ID = new MavenObject("unbound id", "com/unboundid", "unboundid-ldapsdk",
+				"2.3.0", 1383417, 1439721, 0, "6fde8d9fb4ee3e7e3d7e764e3ea57195971e2eb2",
+				"5276d3d29630693dba99ab9f7ea54f4c471d3af1", "");
+		
+		public static final MavenObject IVY = new MavenObject("ivy", "org/apache/ivy", "ivy",
+				"2.2.0", 948000, 744000, 0, "f9d1e83e82fc085093510f7d2e77d81d52bc2081",
+				"0312527950ad0e8fbab37228fbed3bf41a6fe0a1", "");
+
+		
 		public final String name;
 		public final String group;
 		public final String artifact;

--
Gitblit v1.9.1