ittayd-buildr 1.3.4
Sign up to get free protection for your applications and to get access to all the features.
- data/CHANGELOG +915 -0
- data/DISCLAIMER +7 -0
- data/LICENSE +176 -0
- data/NOTICE +26 -0
- data/README.rdoc +146 -0
- data/Rakefile +64 -0
- data/_buildr +28 -0
- data/addon/buildr/antlr.rb +65 -0
- data/addon/buildr/cobertura.rb +22 -0
- data/addon/buildr/drb.rb +281 -0
- data/addon/buildr/emma.rb +22 -0
- data/addon/buildr/hibernate.rb +142 -0
- data/addon/buildr/javacc.rb +85 -0
- data/addon/buildr/jdepend.rb +60 -0
- data/addon/buildr/jetty.rb +248 -0
- data/addon/buildr/jibx.rb +86 -0
- data/addon/buildr/nailgun.rb +221 -0
- data/addon/buildr/openjpa.rb +90 -0
- data/addon/buildr/org/apache/buildr/BuildrNail$Main.class +0 -0
- data/addon/buildr/org/apache/buildr/BuildrNail.class +0 -0
- data/addon/buildr/org/apache/buildr/BuildrNail.java +41 -0
- data/addon/buildr/org/apache/buildr/JettyWrapper$1.class +0 -0
- data/addon/buildr/org/apache/buildr/JettyWrapper$BuildrHandler.class +0 -0
- data/addon/buildr/org/apache/buildr/JettyWrapper.class +0 -0
- data/addon/buildr/org/apache/buildr/JettyWrapper.java +144 -0
- data/addon/buildr/path.rb +136 -0
- data/addon/buildr/xmlbeans.rb +93 -0
- data/bin/buildr +19 -0
- data/buildr.buildfile +53 -0
- data/buildr.gemspec +58 -0
- data/doc/css/default.css +228 -0
- data/doc/css/print.css +100 -0
- data/doc/css/syntax.css +52 -0
- data/doc/images/apache-incubator-logo.png +0 -0
- data/doc/images/buildr-hires.png +0 -0
- data/doc/images/buildr.png +0 -0
- data/doc/images/favicon.png +0 -0
- data/doc/images/growl-icon.tiff +0 -0
- data/doc/images/note.png +0 -0
- data/doc/images/project-structure.png +0 -0
- data/doc/images/tip.png +0 -0
- data/doc/images/zbuildr.tif +0 -0
- data/doc/pages/artifacts.textile +207 -0
- data/doc/pages/building.textile +240 -0
- data/doc/pages/contributing.textile +208 -0
- data/doc/pages/download.textile +62 -0
- data/doc/pages/extending.textile +175 -0
- data/doc/pages/getting_started.textile +273 -0
- data/doc/pages/index.textile +42 -0
- data/doc/pages/languages.textile +407 -0
- data/doc/pages/mailing_lists.textile +17 -0
- data/doc/pages/more_stuff.textile +314 -0
- data/doc/pages/packaging.textile +427 -0
- data/doc/pages/projects.textile +274 -0
- data/doc/pages/recipes.textile +103 -0
- data/doc/pages/settings_profiles.textile +274 -0
- data/doc/pages/testing.textile +212 -0
- data/doc/pages/troubleshooting.textile +103 -0
- data/doc/pages/whats_new.textile +323 -0
- data/doc/print.haml +51 -0
- data/doc/print.toc.yaml +29 -0
- data/doc/scripts/buildr-git.rb +412 -0
- data/doc/scripts/install-jruby.sh +44 -0
- data/doc/scripts/install-linux.sh +64 -0
- data/doc/scripts/install-osx.sh +52 -0
- data/doc/site.haml +56 -0
- data/doc/site.toc.yaml +47 -0
- data/etc/KEYS +151 -0
- data/etc/git-svn-authors +16 -0
- data/lib/buildr/core/application.rb +665 -0
- data/lib/buildr/core/build.rb +311 -0
- data/lib/buildr/core/checks.rb +254 -0
- data/lib/buildr/core/common.rb +150 -0
- data/lib/buildr/core/compile.rb +590 -0
- data/lib/buildr/core/environment.rb +117 -0
- data/lib/buildr/core/filter.rb +366 -0
- data/lib/buildr/core/generate.rb +195 -0
- data/lib/buildr/core/help.rb +119 -0
- data/lib/buildr/core/osx.rb +49 -0
- data/lib/buildr/core/progressbar.rb +156 -0
- data/lib/buildr/core/project.rb +923 -0
- data/lib/buildr/core/test.rb +715 -0
- data/lib/buildr/core/transports.rb +560 -0
- data/lib/buildr/core/util.rb +294 -0
- data/lib/buildr/core.rb +29 -0
- data/lib/buildr/groovy/bdd.rb +106 -0
- data/lib/buildr/groovy/compiler.rb +138 -0
- data/lib/buildr/groovy.rb +18 -0
- data/lib/buildr/ide/eclipse.rb +222 -0
- data/lib/buildr/ide/idea.ipr.template +300 -0
- data/lib/buildr/ide/idea.rb +190 -0
- data/lib/buildr/ide/idea7x.ipr.template +290 -0
- data/lib/buildr/ide/idea7x.rb +212 -0
- data/lib/buildr/ide.rb +19 -0
- data/lib/buildr/java/ant.rb +92 -0
- data/lib/buildr/java/bdd.rb +451 -0
- data/lib/buildr/java/cobertura.rb +236 -0
- data/lib/buildr/java/commands.rb +211 -0
- data/lib/buildr/java/compiler.rb +348 -0
- data/lib/buildr/java/deprecated.rb +141 -0
- data/lib/buildr/java/emma.rb +238 -0
- data/lib/buildr/java/jruby.rb +117 -0
- data/lib/buildr/java/jtestr_runner.rb.erb +116 -0
- data/lib/buildr/java/org/apache/buildr/JavaTestFilter.class +0 -0
- data/lib/buildr/java/org/apache/buildr/JavaTestFilter.java +119 -0
- data/lib/buildr/java/packaging.rb +717 -0
- data/lib/buildr/java/pom.rb +174 -0
- data/lib/buildr/java/rjb.rb +155 -0
- data/lib/buildr/java/test_result.rb +307 -0
- data/lib/buildr/java/tests.rb +329 -0
- data/lib/buildr/java/version_requirement.rb +172 -0
- data/lib/buildr/java.rb +23 -0
- data/lib/buildr/packaging/archive.rb +488 -0
- data/lib/buildr/packaging/artifact.rb +759 -0
- data/lib/buildr/packaging/artifact_namespace.rb +972 -0
- data/lib/buildr/packaging/artifact_search.rb +140 -0
- data/lib/buildr/packaging/gems.rb +102 -0
- data/lib/buildr/packaging/package.rb +233 -0
- data/lib/buildr/packaging/tar.rb +186 -0
- data/lib/buildr/packaging/version_requirement.rb +172 -0
- data/lib/buildr/packaging/zip.rb +64 -0
- data/lib/buildr/packaging/ziptask.rb +313 -0
- data/lib/buildr/packaging.rb +24 -0
- data/lib/buildr/resources/buildr.icns +0 -0
- data/lib/buildr/scala/compiler.rb +109 -0
- data/lib/buildr/scala/tests.rb +203 -0
- data/lib/buildr/scala.rb +19 -0
- data/lib/buildr.rb +33 -0
- data/rakelib/apache.rake +191 -0
- data/rakelib/changelog.rake +57 -0
- data/rakelib/doc.rake +103 -0
- data/rakelib/package.rake +76 -0
- data/rakelib/release.rake +65 -0
- data/rakelib/rspec.rake +83 -0
- data/rakelib/rubyforge.rake +56 -0
- data/rakelib/scm.rake +49 -0
- data/rakelib/setup.rake +81 -0
- data/rakelib/stage.rake +48 -0
- data/spec/addon/drb_spec.rb +328 -0
- data/spec/core/application_spec.rb +419 -0
- data/spec/core/build_spec.rb +423 -0
- data/spec/core/checks_spec.rb +519 -0
- data/spec/core/common_spec.rb +670 -0
- data/spec/core/compile_spec.rb +582 -0
- data/spec/core/generate_spec.rb +33 -0
- data/spec/core/project_spec.rb +776 -0
- data/spec/core/test_spec.rb +1098 -0
- data/spec/core/transport_spec.rb +500 -0
- data/spec/groovy/bdd_spec.rb +80 -0
- data/spec/groovy/compiler_spec.rb +239 -0
- data/spec/ide/eclipse_spec.rb +311 -0
- data/spec/java/ant.rb +33 -0
- data/spec/java/bdd_spec.rb +358 -0
- data/spec/java/cobertura_spec.rb +77 -0
- data/spec/java/compiler_spec.rb +446 -0
- data/spec/java/emma_spec.rb +120 -0
- data/spec/java/java_spec.rb +96 -0
- data/spec/java/packaging_spec.rb +1120 -0
- data/spec/java/test_coverage_spec.rb +255 -0
- data/spec/java/tests_spec.rb +471 -0
- data/spec/packaging/archive_spec.rb +503 -0
- data/spec/packaging/artifact_namespace_spec.rb +646 -0
- data/spec/packaging/artifact_spec.rb +795 -0
- data/spec/packaging/packaging_helper.rb +63 -0
- data/spec/packaging/packaging_spec.rb +589 -0
- data/spec/sandbox.rb +139 -0
- data/spec/scala/compiler_spec.rb +228 -0
- data/spec/scala/tests_spec.rb +215 -0
- data/spec/spec_helpers.rb +327 -0
- data/spec/version_requirement_spec.rb +123 -0
- metadata +377 -0
@@ -0,0 +1,248 @@
|
|
1
|
+
# Licensed to the Apache Software Foundation (ASF) under one or more
|
2
|
+
# contributor license agreements. See the NOTICE file distributed with this
|
3
|
+
# work for additional information regarding copyright ownership. The ASF
|
4
|
+
# licenses this file to you under the Apache License, Version 2.0 (the
|
5
|
+
# "License"); you may not use this file except in compliance with the License.
|
6
|
+
# You may obtain a copy of the License at
|
7
|
+
#
|
8
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
9
|
+
#
|
10
|
+
# Unless required by applicable law or agreed to in writing, software
|
11
|
+
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
12
|
+
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
13
|
+
# License for the specific language governing permissions and limitations under
|
14
|
+
# the License.
|
15
|
+
|
16
|
+
|
17
|
+
require 'uri'
|
18
|
+
require 'net/http'
|
19
|
+
require 'buildr/core/project'
|
20
|
+
require 'buildr/java'
|
21
|
+
require 'buildr/packaging'
|
22
|
+
require 'thread'
|
23
|
+
|
24
|
+
|
25
|
+
module Buildr
|
26
|
+
|
27
|
+
# Provides a collection of tasks and methods for using Jetty, specifically as a server
|
28
|
+
# for testing your application.
|
29
|
+
#
|
30
|
+
# Build files should always start Jetty by invoking the #use task, typically as
|
31
|
+
# a prerequisite. This task will start Jetty once during the build, and shut it down
|
32
|
+
# when the build completes.
|
33
|
+
#
|
34
|
+
# If you want to keep Jetty running across builds, and look at error messages, you can
|
35
|
+
# start Jetty in a separate console with:
|
36
|
+
# buildr jetty:start
|
37
|
+
# To stop this instance of Jetty, simply kill the process (Ctrl-C) or run:
|
38
|
+
# buildr jetty:stop
|
39
|
+
#
|
40
|
+
# If you start Jetty separately from the build, the #use task will connect to that
|
41
|
+
# existing server. Since you are using Jetty across several builds, you will want to
|
42
|
+
# cleanup any mess created by each build. You can use the #setup and #teardown tasks,
|
43
|
+
# which are called when Jetty is first used in the build, and when the build ends.
|
44
|
+
class Jetty
|
45
|
+
|
46
|
+
# Which version of Jetty we're using by default (change with options.jetty.version).
|
47
|
+
VERSION = "6.1.3"
|
48
|
+
SLF4J_VERSION = "1.4.3"
|
49
|
+
|
50
|
+
# Libraries used by Jetty.
|
51
|
+
REQUIRES = [ "org.mortbay.jetty:jetty:jar:#{VERSION}", "org.mortbay.jetty:jetty-util:jar:#{VERSION}",
|
52
|
+
"org.mortbay.jetty:servlet-api-2.5:jar:#{VERSION}", "org.slf4j:slf4j-api:jar:#{SLF4J_VERSION}",
|
53
|
+
"org.slf4j:slf4j-simple:jar:#{SLF4J_VERSION}", "org.slf4j:jcl104-over-slf4j:jar:#{SLF4J_VERSION}" ]
|
54
|
+
|
55
|
+
Java.classpath << REQUIRES
|
56
|
+
Java.classpath << File.dirname(__FILE__)
|
57
|
+
|
58
|
+
# Default URL for Jetty (change with options.jetty.url).
|
59
|
+
URL = "http://localhost:8080"
|
60
|
+
|
61
|
+
class << self
|
62
|
+
|
63
|
+
# :call-seq:
|
64
|
+
# instance() => Jetty
|
65
|
+
#
|
66
|
+
# Returns an instance of Jetty.
|
67
|
+
def instance()
|
68
|
+
@instance ||= Jetty.new("jetty", URL)
|
69
|
+
end
|
70
|
+
|
71
|
+
end
|
72
|
+
|
73
|
+
def initialize(name, url) #:nodoc:
|
74
|
+
@url = url
|
75
|
+
namespace name do
|
76
|
+
@setup = task("setup")
|
77
|
+
@teardown = task("teardown")
|
78
|
+
@use = task("use") { fire }
|
79
|
+
end
|
80
|
+
end
|
81
|
+
|
82
|
+
# The URL for the Jetty server. Leave as is if you want to use the default server
|
83
|
+
# (http://localhost:8080).
|
84
|
+
attr_accessor :url
|
85
|
+
|
86
|
+
# :call-seq:
|
87
|
+
# start(pipe?)
|
88
|
+
#
|
89
|
+
# Starts Jetty. This method does not return, it keeps the thread running until
|
90
|
+
# Jetty is stopped. If you want to run Jetty parallel with other tasks in the build,
|
91
|
+
# invoke the #use task instead.
|
92
|
+
def start(sync = nil)
|
93
|
+
begin
|
94
|
+
puts "classpath #{Java.classpath.inspect}"
|
95
|
+
port = URI.parse(url).port
|
96
|
+
puts "Starting Jetty at http://localhost:#{port}" if verbose
|
97
|
+
Java.load
|
98
|
+
jetty = Java.org.apache.buildr.JettyWrapper.new(port)
|
99
|
+
sync << "Started" if sync
|
100
|
+
sleep # Forever
|
101
|
+
rescue Interrupt # Stopped from console
|
102
|
+
rescue Exception=>error
|
103
|
+
puts "#{error.class}: #{error.message}"
|
104
|
+
end
|
105
|
+
exit! # No at_exit
|
106
|
+
end
|
107
|
+
|
108
|
+
# :call-seq:
|
109
|
+
# stop()
|
110
|
+
#
|
111
|
+
# Stops Jetty. Stops a server running in a separate process.
|
112
|
+
def stop()
|
113
|
+
uri = URI.parse(url)
|
114
|
+
begin
|
115
|
+
Net::HTTP.start(uri.host, uri.port) do |http|
|
116
|
+
http.request_post "/buildr/stop", ""
|
117
|
+
end
|
118
|
+
rescue Errno::ECONNREFUSED
|
119
|
+
# Expected if Jetty server not running.
|
120
|
+
rescue EOFError
|
121
|
+
# We get EOFError because Jetty is brutally killed.
|
122
|
+
end
|
123
|
+
puts "Jetty server stopped"
|
124
|
+
end
|
125
|
+
|
126
|
+
# :call-seq:
|
127
|
+
# running?() => boolean
|
128
|
+
#
|
129
|
+
# Returns true if it finds a running Jetty server that supports the Buildr
|
130
|
+
# requests for deploying, stopping, etc.
|
131
|
+
def running?()
|
132
|
+
uri = URI.parse(url)
|
133
|
+
begin
|
134
|
+
Net::HTTP.start(uri.host, uri.port) do |http|
|
135
|
+
response = http.request_get("/buildr/")
|
136
|
+
response.is_a?(Net::HTTPSuccess) && response.body =~ /Alive/
|
137
|
+
end
|
138
|
+
rescue Errno::ECONNREFUSED, Errno::EBADF
|
139
|
+
false
|
140
|
+
end
|
141
|
+
end
|
142
|
+
|
143
|
+
# :call-seq:
|
144
|
+
# deploy(url, webapp) => path
|
145
|
+
#
|
146
|
+
# Deploy a WAR in the specified URL.
|
147
|
+
def deploy(url, webapp)
|
148
|
+
use.invoke
|
149
|
+
uri = URI.parse(url)
|
150
|
+
Net::HTTP.start(uri.host, uri.port) do |http|
|
151
|
+
response = http.request_post("/buildr/deploy", "webapp=#{webapp}&path=#{uri.path}")
|
152
|
+
if Net::HTTPOK === response && response.body =~ /Deployed/
|
153
|
+
path = response.body.split[1]
|
154
|
+
puts "Deployed #{webapp}, context path #{uri.path}" if Rake.application.options.trace
|
155
|
+
path
|
156
|
+
else
|
157
|
+
fail "Deployment failed: #{response}"
|
158
|
+
end
|
159
|
+
end
|
160
|
+
end
|
161
|
+
|
162
|
+
# :call-seq:
|
163
|
+
# undeploy(url) => boolean
|
164
|
+
#
|
165
|
+
# Undeploys a WAR from the specified URL.
|
166
|
+
def undeploy(url)
|
167
|
+
use.invoke
|
168
|
+
uri = URI.parse(url)
|
169
|
+
Net::HTTP.start(uri.host, uri.port) do |http|
|
170
|
+
response = http.request_post("/buildr/undeploy", "path=#{uri.path}")
|
171
|
+
if Net::HTTPOK === response && response.body =~ /Undeployed/
|
172
|
+
true
|
173
|
+
else
|
174
|
+
fail "Deployment failed: #{response}"
|
175
|
+
end
|
176
|
+
end
|
177
|
+
end
|
178
|
+
|
179
|
+
# :call-seq:
|
180
|
+
# setup(*prereqs) => task
|
181
|
+
# setup(*prereqs) { |task| .. } => task
|
182
|
+
#
|
183
|
+
# This task executes when Jetty is first used in the build. You can use it to
|
184
|
+
# deploy artifacts into Jetty.
|
185
|
+
def setup(*prereqs, &block)
|
186
|
+
@setup.enhance prereqs, &block
|
187
|
+
end
|
188
|
+
|
189
|
+
# :call-seq:
|
190
|
+
# teardown(*prereqs) => task
|
191
|
+
# teardown(*prereqs) { |task| .. } => task
|
192
|
+
#
|
193
|
+
# This task executes when the build is done. You can use it to undeploy artifacts
|
194
|
+
# previously deployed into Jetty.
|
195
|
+
def teardown(*prereqs, &block)
|
196
|
+
@teardown.enhance prereqs, &block
|
197
|
+
end
|
198
|
+
|
199
|
+
# :call-seq:
|
200
|
+
# use(*prereqs) => task
|
201
|
+
# use(*prereqs) { |task| .. } => task
|
202
|
+
#
|
203
|
+
# If you intend to use Jetty, invoke this task. It will start a new instance of
|
204
|
+
# Jetty and close it when the build is done. However, if you already have a server
|
205
|
+
# running in the background (e.g. jetty:start), it will use that server and will
|
206
|
+
# not close it down.
|
207
|
+
def use(*prereqs, &block)
|
208
|
+
@use.enhance prereqs, &block
|
209
|
+
end
|
210
|
+
|
211
|
+
protected
|
212
|
+
|
213
|
+
# If you want to start Jetty inside the build, call this method instead of #start.
|
214
|
+
# It will spawn a separate process that will run Jetty, and will stop Jetty when
|
215
|
+
# the build ends. However, if you already started Jetty from the console (with
|
216
|
+
# take jetty:start), it will use the existing instance without shutting it down.
|
217
|
+
def fire()
|
218
|
+
unless running?
|
219
|
+
sync = Queue.new
|
220
|
+
Thread.new { start sync }
|
221
|
+
# Wait for Jetty to fire up before doing anything else.
|
222
|
+
sync.pop == "Started" or fail "Jetty not started"
|
223
|
+
puts "Jetty started" if verbose
|
224
|
+
at_exit { stop }
|
225
|
+
end
|
226
|
+
@setup.invoke
|
227
|
+
at_exit { @teardown.invoke }
|
228
|
+
end
|
229
|
+
|
230
|
+
end
|
231
|
+
|
232
|
+
namespace "jetty" do
|
233
|
+
desc "Start an instance of Jetty running in the background"
|
234
|
+
task("start") { Jetty.instance.start }
|
235
|
+
desc "Stop an instance of Jetty running in the background"
|
236
|
+
task("stop") { Jetty.instance.stop }
|
237
|
+
end
|
238
|
+
|
239
|
+
# :call-seq:
|
240
|
+
# jetty() => Jetty
|
241
|
+
#
|
242
|
+
# Returns a Jetty object. You can use this to discover the Jetty#use task,
|
243
|
+
# configure the Jetty#setup and Jetty#teardown tasks, deploy and undeploy to Jetty.
|
244
|
+
def jetty()
|
245
|
+
@jetty ||= Jetty.instance
|
246
|
+
end
|
247
|
+
|
248
|
+
end
|
@@ -0,0 +1,86 @@
|
|
1
|
+
# Licensed to the Apache Software Foundation (ASF) under one or more
|
2
|
+
# contributor license agreements. See the NOTICE file distributed with this
|
3
|
+
# work for additional information regarding copyright ownership. The ASF
|
4
|
+
# licenses this file to you under the Apache License, Version 2.0 (the
|
5
|
+
# "License"); you may not use this file except in compliance with the License.
|
6
|
+
# You may obtain a copy of the License at
|
7
|
+
#
|
8
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
9
|
+
#
|
10
|
+
# Unless required by applicable law or agreed to in writing, software
|
11
|
+
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
12
|
+
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
13
|
+
# License for the specific language governing permissions and limitations under
|
14
|
+
# the License.
|
15
|
+
|
16
|
+
|
17
|
+
require 'java/java'
|
18
|
+
|
19
|
+
|
20
|
+
module Buildr
|
21
|
+
|
22
|
+
# Provides JiBX bytecode enhancement. Require explicitly using <code>require 'buildr/jibx'</code>.
|
23
|
+
module JiBX
|
24
|
+
|
25
|
+
JIBX_VERSION = '1.1.5'
|
26
|
+
BCEL_VERSION = '5.2'
|
27
|
+
STAX_VERSION = '1.0-2'
|
28
|
+
XPP3_VERSION = '1.1.4c'
|
29
|
+
|
30
|
+
REQUIRES = [ "org.jibx:jibx-bind:jar:#{JIBX_VERSION}",
|
31
|
+
"org.jibx:jibx-run:jar:#{JIBX_VERSION}",
|
32
|
+
"org.apache.bcel:bcel:jar:#{BCEL_VERSION}",
|
33
|
+
"javax.xml.stream:stax-api:jar:#{STAX_VERSION}",
|
34
|
+
"xpp3:xpp3:jar:#{XPP3_VERSION}" ]
|
35
|
+
|
36
|
+
Java.classpath << REQUIRES
|
37
|
+
|
38
|
+
class << self
|
39
|
+
|
40
|
+
def bind(options)
|
41
|
+
rake_check_options options, :classpath, :output, :binding, :target, :verbose, :load
|
42
|
+
artifacts = Buildr.artifacts(options[:classpath]).each { |a| a.invoke }.map(&:to_s) + [options[:output].to_s]
|
43
|
+
binding = file(options[:binding]).tap { |task| task.invoke }.to_s
|
44
|
+
|
45
|
+
Buildr.ant 'jibx' do |ant|
|
46
|
+
ant.taskdef :name=>'bind', :classname=>'org.jibx.binding.ant.CompileTask',
|
47
|
+
:classpath => requires.join(File::PATH_SEPARATOR)
|
48
|
+
ant.bind :verbose => options[:verbose].to_s, :load => options[:load].to_s, :binding=>options[:binding].to_s do
|
49
|
+
ant.classpath :path => artifacts.join(File::PATH_SEPARATOR)
|
50
|
+
end
|
51
|
+
end
|
52
|
+
end
|
53
|
+
|
54
|
+
private
|
55
|
+
|
56
|
+
def requires()
|
57
|
+
@requires ||= Buildr.artifacts(REQUIRES).each { |artifact| artifact.invoke }.map(&:to_s)
|
58
|
+
end
|
59
|
+
|
60
|
+
end
|
61
|
+
|
62
|
+
def jibx_bind(options = nil)
|
63
|
+
|
64
|
+
# FIXME - add support for :bindingfileset and :classpathset
|
65
|
+
# Note: either :binding or :bindingfileset should be set, and either
|
66
|
+
# :classpath or :classpathset should be set, and options passed to
|
67
|
+
# ant.bind should be adjusted accordingly. At present, only :binding
|
68
|
+
# and :classpath are supported (which should be fine for most!)
|
69
|
+
jibx_options = { :output => compile.target,
|
70
|
+
:classpath => compile.classpath,
|
71
|
+
:binding => path_to(:source, :main, :resources, 'META-INF/binding.xml'),
|
72
|
+
:target => compile.target,
|
73
|
+
:load => false,
|
74
|
+
:verbose => false
|
75
|
+
}
|
76
|
+
|
77
|
+
JiBX.bind jibx_options.merge(options || {})
|
78
|
+
end
|
79
|
+
|
80
|
+
end
|
81
|
+
|
82
|
+
class Project
|
83
|
+
include JiBX
|
84
|
+
end
|
85
|
+
end
|
86
|
+
|
@@ -0,0 +1,221 @@
|
|
1
|
+
# Licensed to the Apache Software Foundation (ASF) under one or more
|
2
|
+
# contributor license agreements. See the NOTICE file distributed with this
|
3
|
+
# work for additional information regarding copyright ownership. The ASF
|
4
|
+
# licenses this file to you under the Apache License, Version 2.0 (the
|
5
|
+
# "License"); you may not use this file except in compliance with the License.
|
6
|
+
# You may obtain a copy of the License at
|
7
|
+
#
|
8
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
9
|
+
#
|
10
|
+
# Unless required by applicable law or agreed to in writing, software
|
11
|
+
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
12
|
+
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
13
|
+
# License for the specific language governing permissions and limitations under
|
14
|
+
# the License.
|
15
|
+
|
16
|
+
|
17
|
+
require 'jruby'
|
18
|
+
require 'rbconfig'
|
19
|
+
require 'tmpdir'
|
20
|
+
require 'buildr/drb'
|
21
|
+
|
22
|
+
|
23
|
+
module Buildr
|
24
|
+
|
25
|
+
# This addon is provided for fast interaction with a DRb BuildrServer (buildr/drb).
|
26
|
+
#
|
27
|
+
# This module delegates task invocation to the BuildrServer, it only implements
|
28
|
+
# nailgun required logic (server/client).
|
29
|
+
#
|
30
|
+
# Usage:
|
31
|
+
#
|
32
|
+
# buildr -r buildr/nailgun nailgun:start
|
33
|
+
#
|
34
|
+
# Once the server has been started you can invoke tasks using the nailgun client
|
35
|
+
# installed on $JRUBY_HOME/tool/nailgun. It's recommended to add this path to
|
36
|
+
# your PATH environment variable, so that the ng command is available at any dir.
|
37
|
+
#
|
38
|
+
# ng build # invoke the build task
|
39
|
+
#
|
40
|
+
module Nailgun
|
41
|
+
extend self
|
42
|
+
|
43
|
+
VERSION = '0.7.1'
|
44
|
+
NAME = "nailgun-#{VERSION}"
|
45
|
+
URL = "http://downloads.sourceforge.net/nailgun/#{NAME}.zip"
|
46
|
+
ARTIFACT_SPEC = "com.martiansoftware:nailgun:jar:#{VERSION}"
|
47
|
+
PORT = DRbApplication::PORT + 2
|
48
|
+
ADDON_BIN = File.dirname(__FILE__)
|
49
|
+
|
50
|
+
# Returns the path to JRUBY_HOME.
|
51
|
+
def jruby_home
|
52
|
+
ENV['JRUBY_HOME'] || Config::CONFIG['prefix']
|
53
|
+
end
|
54
|
+
|
55
|
+
# Returns the path to NAILGUN_HOME.
|
56
|
+
def nailgun_home
|
57
|
+
ENV['NAILGUN_HOME'] || File.expand_path('tool/nailgun', jruby_home)
|
58
|
+
end
|
59
|
+
|
60
|
+
def tmp_path(*paths)
|
61
|
+
File.join(Dir.tmpdir, 'nailgun', *paths)
|
62
|
+
end
|
63
|
+
|
64
|
+
module Util
|
65
|
+
extend self
|
66
|
+
|
67
|
+
def add_to_sysloader(path)
|
68
|
+
sysloader = java.lang.ClassLoader.getSystemClassLoader
|
69
|
+
add_url_method = java.lang.Class.forName('java.net.URLClassLoader').
|
70
|
+
getDeclaredMethod('addURL', [java.net.URL.java_class].to_java(java.lang.Class))
|
71
|
+
add_url_method.setAccessible(true)
|
72
|
+
add_url_method.invoke(sysloader, [java.io.File.new(path).toURI.toURL].to_java(java.net.URL))
|
73
|
+
end
|
74
|
+
|
75
|
+
# invoke a java constructor
|
76
|
+
def ctor(on_class, *args)
|
77
|
+
parameters = []
|
78
|
+
classes = []
|
79
|
+
args.each do |obj|
|
80
|
+
case obj
|
81
|
+
when nil
|
82
|
+
classes.push(nil)
|
83
|
+
parameters.push(nil)
|
84
|
+
when Hash
|
85
|
+
vclass = obj.keys.first
|
86
|
+
value = obj[vclass]
|
87
|
+
classes.push(vclass.java_class)
|
88
|
+
parameters.push(value)
|
89
|
+
else
|
90
|
+
parameters.push obj
|
91
|
+
classes.push obj.class.java_class
|
92
|
+
end
|
93
|
+
end
|
94
|
+
on_class = [on_class.java_class].to_java(java.lang.Class)[0]
|
95
|
+
ctor = on_class.getDeclaredConstructor(classes.to_java(java.lang.Class))
|
96
|
+
ctor.setAccessible(true)
|
97
|
+
ctor.newInstance(parameters.to_java(java.lang.Object))
|
98
|
+
end
|
99
|
+
|
100
|
+
end # Util
|
101
|
+
|
102
|
+
module Client
|
103
|
+
|
104
|
+
def main(nail)
|
105
|
+
nail.out.println "Connected to #{nail.getNGServer}"
|
106
|
+
|
107
|
+
runtime = JRuby.runtime
|
108
|
+
|
109
|
+
stdout = Util.ctor(org.jruby.RubyIO, runtime, java.io.OutputStream => nail.out)
|
110
|
+
stderr = Util.ctor(org.jruby.RubyIO, runtime, java.io.OutputStream => nail.err)
|
111
|
+
stdin = Util.ctor(org.jruby.RubyIO, runtime, java.io.InputStream => nail.in)
|
112
|
+
|
113
|
+
dir = nail.getWorkingDirectory
|
114
|
+
argv = [nail.command] + nail.args
|
115
|
+
|
116
|
+
DRbApplication.remote_run :dir => dir, :argv => argv,
|
117
|
+
:in => stdin, :out => stdout, :err => stderr
|
118
|
+
rescue => e
|
119
|
+
nail.err.println e unless SystemExit === e
|
120
|
+
nail.exit 1
|
121
|
+
end
|
122
|
+
|
123
|
+
end # Client
|
124
|
+
|
125
|
+
module Server
|
126
|
+
def initialize(host, port)
|
127
|
+
@host = host || "*"
|
128
|
+
@port = port
|
129
|
+
super(host, port)
|
130
|
+
end
|
131
|
+
|
132
|
+
def start
|
133
|
+
self.allow_nails_by_class_name = false
|
134
|
+
|
135
|
+
NGClient::Main.nail = NGClient.new
|
136
|
+
self.default_nail_class = NGClient::Main
|
137
|
+
|
138
|
+
@thread = java.lang.Thread.new(self)
|
139
|
+
@thread.setName(to_s)
|
140
|
+
@thread.start
|
141
|
+
|
142
|
+
sleep 1 while getPort == 0
|
143
|
+
info "#{self} Started."
|
144
|
+
end
|
145
|
+
|
146
|
+
def stop
|
147
|
+
@thread.kill
|
148
|
+
end
|
149
|
+
|
150
|
+
def to_s
|
151
|
+
version = "Buildr #{Buildr::VERSION} #{RUBY_PLATFORM[/java/] && '(JRuby '+JRUBY_VERSION+')'}"
|
152
|
+
self.class.name+'('+[version, @host, @port].join(', ')+')'
|
153
|
+
end
|
154
|
+
end # Server
|
155
|
+
|
156
|
+
namespace(:nailgun) do
|
157
|
+
|
158
|
+
dist_zip = Buildr.download(tmp_path(NAME + '.zip') => URL)
|
159
|
+
dist_dir = Buildr.unzip(tmp_path(NAME) => dist_zip)
|
160
|
+
|
161
|
+
nailgun_jar = file(tmp_path(NAME, NAME, NAME + '.jar'))
|
162
|
+
nailgun_jar.enhance [dist_dir] unless File.exist?(nailgun_jar.to_s)
|
163
|
+
|
164
|
+
attr_reader :artifact
|
165
|
+
@artifact = Buildr.artifact(ARTIFACT_SPEC).from(nailgun_jar)
|
166
|
+
|
167
|
+
compiled_bin = file(tmp_path(NAME, NAME, 'ng' + Config::CONFIG['EXEEXT']) => dist_dir.target) do |task|
|
168
|
+
unless task.to_s.pathmap('%x') == '.exe'
|
169
|
+
Dir.chdir(task.to_s.pathmap('%d')) do
|
170
|
+
info "Compiling #{task.to_s}"
|
171
|
+
system('make', task.to_s.pathmap('%f')) or
|
172
|
+
fail "Nailgun binary compilation failed."
|
173
|
+
end
|
174
|
+
end
|
175
|
+
end
|
176
|
+
|
177
|
+
attr_reader :installed_bin
|
178
|
+
@installed_bin = file(File.expand_path(compiled_bin.to_s.pathmap('%f'), nailgun_home) => compiled_bin) do |task|
|
179
|
+
mkpath task.to_s.pathmap('%d'), :verbose => false
|
180
|
+
cp compiled_bin.to_s, task.to_s, :verbose => false
|
181
|
+
end
|
182
|
+
|
183
|
+
task('drb-notice') do
|
184
|
+
info ''
|
185
|
+
info 'Running in JRuby, a nailgun server will be started so that'
|
186
|
+
info 'you can use your nailgun client to invoke buildr tasks: '
|
187
|
+
info ''
|
188
|
+
info ' '+Nailgun.installed_bin.to_s
|
189
|
+
info ''
|
190
|
+
end
|
191
|
+
|
192
|
+
task('drb' => ['drb-notice', 'start'])
|
193
|
+
|
194
|
+
desc 'Start the nailgun server'
|
195
|
+
task('start' => [installed_bin, 'setup']) do |task|
|
196
|
+
server = NGServer.new(nil, PORT)
|
197
|
+
server.start
|
198
|
+
end
|
199
|
+
|
200
|
+
task('setup' => artifact) do
|
201
|
+
module Util
|
202
|
+
include Buildr::Util
|
203
|
+
end
|
204
|
+
|
205
|
+
Util.add_to_sysloader artifact.to_s
|
206
|
+
Util.add_to_sysloader ADDON_BIN
|
207
|
+
|
208
|
+
class NGClient
|
209
|
+
include org.apache.buildr.BuildrNail
|
210
|
+
include Client
|
211
|
+
end
|
212
|
+
|
213
|
+
class NGServer < com.martiansoftware.nailgun.NGServer
|
214
|
+
include Server
|
215
|
+
end
|
216
|
+
end
|
217
|
+
|
218
|
+
end # ng_tasks
|
219
|
+
|
220
|
+
end # module Nailgun
|
221
|
+
end
|
@@ -0,0 +1,90 @@
|
|
1
|
+
# Licensed to the Apache Software Foundation (ASF) under one or more
|
2
|
+
# contributor license agreements. See the NOTICE file distributed with this
|
3
|
+
# work for additional information regarding copyright ownership. The ASF
|
4
|
+
# licenses this file to you under the Apache License, Version 2.0 (the
|
5
|
+
# "License"); you may not use this file except in compliance with the License.
|
6
|
+
# You may obtain a copy of the License at
|
7
|
+
#
|
8
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
9
|
+
#
|
10
|
+
# Unless required by applicable law or agreed to in writing, software
|
11
|
+
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
12
|
+
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
13
|
+
# License for the specific language governing permissions and limitations under
|
14
|
+
# the License.
|
15
|
+
|
16
|
+
|
17
|
+
require 'buildr/java'
|
18
|
+
|
19
|
+
|
20
|
+
module Buildr
|
21
|
+
|
22
|
+
# Provides OpenJPA bytecode enhancement and Mapping tool task. Require explicitly using <code>require "buildr/openjpa"</code>.
|
23
|
+
module OpenJPA
|
24
|
+
|
25
|
+
VERSION = "1.0.1"
|
26
|
+
|
27
|
+
REQUIRES = [ "org.apache.openjpa:openjpa:jar:#{VERSION}",
|
28
|
+
"commons-collections:commons-collections:jar:3.1",
|
29
|
+
"commons-dbcp:commons-dbcp:jar:1.2.1",
|
30
|
+
"commons-lang:commons-lang:jar:2.1",
|
31
|
+
"commons-pool:commons-pool:jar:1.2",
|
32
|
+
"javax.persistence:persistence-api:jar:1.0",
|
33
|
+
"org.apache.geronimo.specs:geronimo-j2ee-connector_1.5_spec:jar:1.0",
|
34
|
+
"org.apache.geronimo.specs:geronimo-jta_1.0.1B_spec:jar:1.0",
|
35
|
+
"net.sourceforge.serp:serp:jar:1.11.0" ]
|
36
|
+
|
37
|
+
Java.classpath << REQUIRES
|
38
|
+
|
39
|
+
class << self
|
40
|
+
|
41
|
+
def enhance(options)
|
42
|
+
rake_check_options options, :classpath, :properties, :output
|
43
|
+
artifacts = Buildr.artifacts(options[:classpath]).each { |a| a.invoke }.map(&:to_s) + [options[:output].to_s]
|
44
|
+
properties = file(options[:properties]).tap { |task| task.invoke }.to_s
|
45
|
+
|
46
|
+
Buildr.ant "openjpa" do |ant|
|
47
|
+
ant.taskdef :name=>"enhancer", :classname=>"org.apache.openjpa.ant.PCEnhancerTask",
|
48
|
+
:classpath=>requires.join(File::PATH_SEPARATOR)
|
49
|
+
ant.enhancer :directory=>options[:output].to_s do
|
50
|
+
ant.config :propertiesFile=>properties
|
51
|
+
ant.classpath :path=>artifacts.join(File::PATH_SEPARATOR)
|
52
|
+
end
|
53
|
+
end
|
54
|
+
end
|
55
|
+
|
56
|
+
def mapping_tool(options)
|
57
|
+
rake_check_options options, :classpath, :properties, :sql, :action
|
58
|
+
artifacts = Buildr.artifacts(options[:classpath]).each{ |a| a.invoke }.map(&:to_s)
|
59
|
+
properties = file(options[:properties].to_s).tap { |task| task.invoke }.to_s
|
60
|
+
|
61
|
+
Buildr.ant("openjpa") do |ant|
|
62
|
+
ant.taskdef :name=>"mapping", :classname=>"org.apache.openjpa.jdbc.ant.MappingToolTask",
|
63
|
+
:classpath=>requires.join(File::PATH_SEPARATOR)
|
64
|
+
ant.mapping :schemaAction=>options[:action], :sqlFile=>options[:sql].to_s, :ignoreErrors=>"true" do
|
65
|
+
ant.config :propertiesFile=>properties
|
66
|
+
ant.classpath :path=>artifacts.join(File::PATH_SEPARATOR)
|
67
|
+
end
|
68
|
+
end
|
69
|
+
end
|
70
|
+
|
71
|
+
private
|
72
|
+
|
73
|
+
def requires()
|
74
|
+
@requires ||= Buildr.artifacts(REQUIRES).each { |artifact| artifact.invoke }.map(&:to_s)
|
75
|
+
end
|
76
|
+
|
77
|
+
end
|
78
|
+
|
79
|
+
def open_jpa_enhance(options = nil)
|
80
|
+
jpa_options = { :output=>compile.target, :classpath=>compile.dependencies,
|
81
|
+
:properties=>path_to(:source, :main, :resources, 'META-INF/persistence.xml') }
|
82
|
+
OpenJPA.enhance jpa_options.merge(options || {})
|
83
|
+
end
|
84
|
+
|
85
|
+
end
|
86
|
+
|
87
|
+
class Project
|
88
|
+
include OpenJPA
|
89
|
+
end
|
90
|
+
end
|
Binary file
|
Binary file
|
@@ -0,0 +1,41 @@
|
|
1
|
+
/* Licensed to the Apache Software Foundation (ASF) under one or more
|
2
|
+
* contributor license agreements. See the NOTICE file distributed with this
|
3
|
+
* work for additional information regarding copyright ownership. The ASF
|
4
|
+
* licenses this file to you under the Apache License, Version 2.0 (the
|
5
|
+
* "License"); you may not use this file except in compliance with the License.
|
6
|
+
* You may obtain a copy of the License at
|
7
|
+
*
|
8
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
9
|
+
*
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
11
|
+
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
12
|
+
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
13
|
+
* License for the specific language governing permissions and limitations
|
14
|
+
* under the License.
|
15
|
+
*/
|
16
|
+
|
17
|
+
|
18
|
+
package org.apache.buildr;
|
19
|
+
|
20
|
+
import com.martiansoftware.nailgun.NGContext;
|
21
|
+
|
22
|
+
public interface BuildrNail {
|
23
|
+
|
24
|
+
public void main(NGContext ctx);
|
25
|
+
|
26
|
+
public static class Main {
|
27
|
+
private static BuildrNail nail;
|
28
|
+
public static void setNail(BuildrNail _nail) { nail = _nail; }
|
29
|
+
public static void nailMain(NGContext ctx) {
|
30
|
+
nail.main(ctx);
|
31
|
+
}
|
32
|
+
}
|
33
|
+
|
34
|
+
}
|
35
|
+
|
36
|
+
/*
|
37
|
+
* Local Variables:
|
38
|
+
* indent-tabs-mode: nil
|
39
|
+
* c-basic-offset: 2
|
40
|
+
* End:
|
41
|
+
*/
|
Binary file
|
Binary file
|
Binary file
|