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