-
Notifications
You must be signed in to change notification settings - Fork 14
/
Copy pathbuild.sbt
173 lines (149 loc) · 7.43 KB
/
build.sbt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
import AssemblyKeys._ // for sbt-assembly
name := "TextGrounder"
// If you change this, you also have to change bin/textgrounder
// (TEXTGROUNDER_VERSION)
version := "0.1.0"
organization := "OpenNLP"
// If you change this, you also have to change bin/textgrounder (SCALA_LIB)
scalaVersion := "2.10.4"
crossPaths := false
retrieveManaged := true
autoAPIMappings := true
(sourceGenerators in Compile) <+= (sourceManaged in Compile) map GenFeatureVector.gen
(sourceGenerators in Compile) <+= (sourceManaged in Compile) map GenMemoizer.gen
resolvers ++= Seq(
"OpenNLP Maven Repository" at "http://opennlp.sourceforge.net/maven2",
"repo.codahale.com" at "http://repo.codahale.com"
// Resolver for trove-scala source; nonexistent here yet
// "repo.codahale.com" at "http://repo.codahale.com",
// Resolver if you want to find stuff out of your local Maven cache
// "Local Maven Repository" at "file://"+Path.userHome+"/.m2/repository"
)
// The following needed for Scoobi
resolvers ++= Seq("Cloudera Maven Repository" at "https://repository.cloudera.com/content/repositories/releases/",
"Packaged Avro" at "http://nicta.github.com/scoobi/releases/")
// The following needed for Scoobi snapshots
resolvers += "snapshots" at "http://oss.sonatype.org/content/repositories/snapshots"
libraryDependencies ++= Seq(
// For FieldSpring:
"com.google.guava" % "guava" % "17.0",
//
// "org.jdom" % "jdom" % "2.0.5",
"org.apache.commons" % "commons-lang3" % "3.3.2",
"org.apache.commons" % "commons-compress" % "1.8.1",
"net.liftweb" %% "lift-json" % "3.0-M1",
// The following don't appear to be used currently.
// "com.google.inject" % "guice" % "3.0",
// "commons-cli" % "commons-cli" % "1.2",
// "org.xerial" % "sqlite-jdbc" % "3.7.2",
// "org.apache.opennlp" % "opennlp-maxent" % "3.0.3",
"org.apache.opennlp" % "opennlp-tools" % "1.5.3",
// The use of %% instead of % causes the Scala version to get appended,
// i.e. it's equivalent to the use of single % with "argot_2.10.2".
// This is for Scala-specific dependencies.
// Remove this for the moment because there's a modified version (styled
// as version "1.0.1-benwing") in the unmanaged lib/. (Fuck me, our
// unmanaged junto.jar includes a copy of Argot 0.3.5, so we will have
// class path problems with a newer managed version of Argot until we
// remove this!)
"org.clapper" %% "argot" % "1.0.1",
// If we remove Argot we need to include Argot's dependencies.
"org.clapper" %% "grizzled-scala" % "1.2",
//
// The following is the old way we got Hadoop added. Out of date, has lots
// of problems. Now it's included as a dependency of Scoobi.
// "org.apache.hadoop" % "hadoop-core" % "0.20.205.0",
// This was necessary because of a stupid bug in the Maven POM for Hadoop
// (the "old way") above, which leaves this out. (Supposedly Hadoop
// originally used version 1.5.2, but version 1.9.13 doesn't seem to cause
// problems.) But not needed at all if we don't use that Hadoop POM.
// "org.codehaus.jackson" % "jackson-mapper-asl" % "1.9.13",
//
// Trove
"net.sf.trove4j" % "trove4j" % "3.0.3",
//
// Scoobi
// The following is the library we actually use, but because it's not
// available on a web repository anywhere, we put a local copy in lib/.
// "com.nicta" % "scoobi_2.10" % "0.6.0-cdh3-SNAPSHOT-benwing",
//
// We used to specify the unmodified library so as to get its dependencies,
// but there's no build of 0.6.0-cdh3 for Scoobi 2.10 anywhere on the
// web. (No support any more for cdh3 in Scoobi at all.) The idea was that
// the local library in lib/ overrode the unmodified library itself.
// Now we need to specify all the dependencies (see below).
// "com.nicta" % "scoobi_2.9.2" % "0.6.0-cdh3",
// "provided" if we use Scoobi's package-hadoop instead of sbt-assembly.
// This is another way of building an assembly for Hadoop that includes all
// the dependent libraries into the JAR file. To do that, we have to move
// the file 'scoobi.scala' in 'project/' into 'project/project/', and
// comment out all the lines related to sbt-assembly (the import at the top,
// and everything below starting with 'seq(assemblySettings ...)'),
// because of stupid incompatibilities between the two. Then we can use
// 'textgrounder build package-hadoop' instead of
// 'textgrounder build assembly'.
// "com.nicta" % "scoobi_2.9.2" % "0.4.0" % "provided",
// Scoobi's dependencies.
"javassist" % "javassist" % "3.12.1.GA",
"org.apache.avro" % "avro-mapred" % "1.7.6",
"org.apache.avro" % "avro" % "1.7.6",
"org.apache.hadoop" % "hadoop-core" % "0.20.2-cdh3u1",
"com.thoughtworks.xstream" % "xstream" % "1.4.7" intransitive(),
"org.scalaz" %% "scalaz-core" % "7.1.0-M7",
// "org.scalaz" %% "scalaz-core" % "7.0.6",
"org.specs2" %% "specs2" % "1.14" % "optional",
"com.chuusai" %% "shapeless" % "1.2.4",
//
// Additional dependency related to Scoobi; not in Scoobi's build.sbt.
"log4j" % "log4j" % "1.2.17"
// Find repository for trove-scala; currently stored unmanaged
// "com.codahale" % "trove-scala_2.9.1" % "0.0.2-SNAPSHOT"
)
// turn on all warnings in Java code
javacOptions ++= Seq("-Xlint")
// turn on all Scala warnings; also turn on deprecation warnings.
scalacOptions ++= Seq("-deprecation", "-Xlint", "-unchecked", "-language:_")
// Add optimization
scalacOptions ++= Seq("-optimise")
// scalacOptions ++= Seq("-print")
seq(assemblySettings: _*)
// Don't try to compile or run test code.
test in assembly := {}
// Example of how to exclude jars from the assembly.
//excludedJars in assembly <<= (fullClasspath in assembly) map { cp =>
// cp filter {x => Seq("jasper-compiler-5.5.12.jar", "jasper-runtime-5.5.12.jar", "commons-beanutils-1.7.0.jar", "servlet-api-2.5-20081211.jar") contains x.data.getName }
//}
excludedJars in assembly <<= (fullClasspath in assembly) map { cp =>
cp filter {_.data.getName == "scoobi_2.9.2-0.5.0-cdh3.jar"}
}
// FUCK ME TO (JAR) HELL! This is an awful hack. Boys and girls, repeat after
// me: say "fragile library problem" and "Java sucks rocks compared with C#".
// Now repeat 100 times.
//
// Here the problem is that, as a program increases in size and includes
// dependencies from various sources, each with their own sub-dependencies,
// you'll inevitably end up with different versions of the same library as
// sub-dependencies of different dependencies. This is the infamous "fragile
// library problem" (aka DLL hell, JAR hell, etc.). Java has no solution to
// this problem. C# does. (As with 100 other nasty Java problems that don't
// exist in C#.)
//
// On top of this, SBT makes things even worse by not even providing a way
// of automatically picking the most recent library. In fact, it doesn't
// provide any solution at all that doesn't require you to write your own
// code (see below) -- a horrendous solution typical of packages written by
// programmers who are obsessed with the mantra of "customizability" but
// have no sense of proper design, no knowledge of how to write user
// interfaces, and no skill in creating understandable documentation.
// The "solution" below arbitrarily picks the first library version found.
// Is this newer or older? Will it cause weird random breakage? Who knows?
mergeStrategy in assembly <<= (mergeStrategy in assembly) { (old) =>
{
case x => {
val oldstrat = old(x)
if (oldstrat == MergeStrategy.deduplicate) MergeStrategy.first
else oldstrat
}
}
}
// jarName in assembly := "textgrounder-assembly.jar"