ittayd-buildr 1.3.4

Sign up to get free protection for your applications and to get access to all the features.
Files changed (171) hide show
  1. data/CHANGELOG +915 -0
  2. data/DISCLAIMER +7 -0
  3. data/LICENSE +176 -0
  4. data/NOTICE +26 -0
  5. data/README.rdoc +146 -0
  6. data/Rakefile +64 -0
  7. data/_buildr +28 -0
  8. data/addon/buildr/antlr.rb +65 -0
  9. data/addon/buildr/cobertura.rb +22 -0
  10. data/addon/buildr/drb.rb +281 -0
  11. data/addon/buildr/emma.rb +22 -0
  12. data/addon/buildr/hibernate.rb +142 -0
  13. data/addon/buildr/javacc.rb +85 -0
  14. data/addon/buildr/jdepend.rb +60 -0
  15. data/addon/buildr/jetty.rb +248 -0
  16. data/addon/buildr/jibx.rb +86 -0
  17. data/addon/buildr/nailgun.rb +221 -0
  18. data/addon/buildr/openjpa.rb +90 -0
  19. data/addon/buildr/org/apache/buildr/BuildrNail$Main.class +0 -0
  20. data/addon/buildr/org/apache/buildr/BuildrNail.class +0 -0
  21. data/addon/buildr/org/apache/buildr/BuildrNail.java +41 -0
  22. data/addon/buildr/org/apache/buildr/JettyWrapper$1.class +0 -0
  23. data/addon/buildr/org/apache/buildr/JettyWrapper$BuildrHandler.class +0 -0
  24. data/addon/buildr/org/apache/buildr/JettyWrapper.class +0 -0
  25. data/addon/buildr/org/apache/buildr/JettyWrapper.java +144 -0
  26. data/addon/buildr/path.rb +136 -0
  27. data/addon/buildr/xmlbeans.rb +93 -0
  28. data/bin/buildr +19 -0
  29. data/buildr.buildfile +53 -0
  30. data/buildr.gemspec +58 -0
  31. data/doc/css/default.css +228 -0
  32. data/doc/css/print.css +100 -0
  33. data/doc/css/syntax.css +52 -0
  34. data/doc/images/apache-incubator-logo.png +0 -0
  35. data/doc/images/buildr-hires.png +0 -0
  36. data/doc/images/buildr.png +0 -0
  37. data/doc/images/favicon.png +0 -0
  38. data/doc/images/growl-icon.tiff +0 -0
  39. data/doc/images/note.png +0 -0
  40. data/doc/images/project-structure.png +0 -0
  41. data/doc/images/tip.png +0 -0
  42. data/doc/images/zbuildr.tif +0 -0
  43. data/doc/pages/artifacts.textile +207 -0
  44. data/doc/pages/building.textile +240 -0
  45. data/doc/pages/contributing.textile +208 -0
  46. data/doc/pages/download.textile +62 -0
  47. data/doc/pages/extending.textile +175 -0
  48. data/doc/pages/getting_started.textile +273 -0
  49. data/doc/pages/index.textile +42 -0
  50. data/doc/pages/languages.textile +407 -0
  51. data/doc/pages/mailing_lists.textile +17 -0
  52. data/doc/pages/more_stuff.textile +314 -0
  53. data/doc/pages/packaging.textile +427 -0
  54. data/doc/pages/projects.textile +274 -0
  55. data/doc/pages/recipes.textile +103 -0
  56. data/doc/pages/settings_profiles.textile +274 -0
  57. data/doc/pages/testing.textile +212 -0
  58. data/doc/pages/troubleshooting.textile +103 -0
  59. data/doc/pages/whats_new.textile +323 -0
  60. data/doc/print.haml +51 -0
  61. data/doc/print.toc.yaml +29 -0
  62. data/doc/scripts/buildr-git.rb +412 -0
  63. data/doc/scripts/install-jruby.sh +44 -0
  64. data/doc/scripts/install-linux.sh +64 -0
  65. data/doc/scripts/install-osx.sh +52 -0
  66. data/doc/site.haml +56 -0
  67. data/doc/site.toc.yaml +47 -0
  68. data/etc/KEYS +151 -0
  69. data/etc/git-svn-authors +16 -0
  70. data/lib/buildr/core/application.rb +665 -0
  71. data/lib/buildr/core/build.rb +311 -0
  72. data/lib/buildr/core/checks.rb +254 -0
  73. data/lib/buildr/core/common.rb +150 -0
  74. data/lib/buildr/core/compile.rb +590 -0
  75. data/lib/buildr/core/environment.rb +117 -0
  76. data/lib/buildr/core/filter.rb +366 -0
  77. data/lib/buildr/core/generate.rb +195 -0
  78. data/lib/buildr/core/help.rb +119 -0
  79. data/lib/buildr/core/osx.rb +49 -0
  80. data/lib/buildr/core/progressbar.rb +156 -0
  81. data/lib/buildr/core/project.rb +923 -0
  82. data/lib/buildr/core/test.rb +715 -0
  83. data/lib/buildr/core/transports.rb +560 -0
  84. data/lib/buildr/core/util.rb +294 -0
  85. data/lib/buildr/core.rb +29 -0
  86. data/lib/buildr/groovy/bdd.rb +106 -0
  87. data/lib/buildr/groovy/compiler.rb +138 -0
  88. data/lib/buildr/groovy.rb +18 -0
  89. data/lib/buildr/ide/eclipse.rb +222 -0
  90. data/lib/buildr/ide/idea.ipr.template +300 -0
  91. data/lib/buildr/ide/idea.rb +190 -0
  92. data/lib/buildr/ide/idea7x.ipr.template +290 -0
  93. data/lib/buildr/ide/idea7x.rb +212 -0
  94. data/lib/buildr/ide.rb +19 -0
  95. data/lib/buildr/java/ant.rb +92 -0
  96. data/lib/buildr/java/bdd.rb +451 -0
  97. data/lib/buildr/java/cobertura.rb +236 -0
  98. data/lib/buildr/java/commands.rb +211 -0
  99. data/lib/buildr/java/compiler.rb +348 -0
  100. data/lib/buildr/java/deprecated.rb +141 -0
  101. data/lib/buildr/java/emma.rb +238 -0
  102. data/lib/buildr/java/jruby.rb +117 -0
  103. data/lib/buildr/java/jtestr_runner.rb.erb +116 -0
  104. data/lib/buildr/java/org/apache/buildr/JavaTestFilter.class +0 -0
  105. data/lib/buildr/java/org/apache/buildr/JavaTestFilter.java +119 -0
  106. data/lib/buildr/java/packaging.rb +717 -0
  107. data/lib/buildr/java/pom.rb +174 -0
  108. data/lib/buildr/java/rjb.rb +155 -0
  109. data/lib/buildr/java/test_result.rb +307 -0
  110. data/lib/buildr/java/tests.rb +329 -0
  111. data/lib/buildr/java/version_requirement.rb +172 -0
  112. data/lib/buildr/java.rb +23 -0
  113. data/lib/buildr/packaging/archive.rb +488 -0
  114. data/lib/buildr/packaging/artifact.rb +759 -0
  115. data/lib/buildr/packaging/artifact_namespace.rb +972 -0
  116. data/lib/buildr/packaging/artifact_search.rb +140 -0
  117. data/lib/buildr/packaging/gems.rb +102 -0
  118. data/lib/buildr/packaging/package.rb +233 -0
  119. data/lib/buildr/packaging/tar.rb +186 -0
  120. data/lib/buildr/packaging/version_requirement.rb +172 -0
  121. data/lib/buildr/packaging/zip.rb +64 -0
  122. data/lib/buildr/packaging/ziptask.rb +313 -0
  123. data/lib/buildr/packaging.rb +24 -0
  124. data/lib/buildr/resources/buildr.icns +0 -0
  125. data/lib/buildr/scala/compiler.rb +109 -0
  126. data/lib/buildr/scala/tests.rb +203 -0
  127. data/lib/buildr/scala.rb +19 -0
  128. data/lib/buildr.rb +33 -0
  129. data/rakelib/apache.rake +191 -0
  130. data/rakelib/changelog.rake +57 -0
  131. data/rakelib/doc.rake +103 -0
  132. data/rakelib/package.rake +76 -0
  133. data/rakelib/release.rake +65 -0
  134. data/rakelib/rspec.rake +83 -0
  135. data/rakelib/rubyforge.rake +56 -0
  136. data/rakelib/scm.rake +49 -0
  137. data/rakelib/setup.rake +81 -0
  138. data/rakelib/stage.rake +48 -0
  139. data/spec/addon/drb_spec.rb +328 -0
  140. data/spec/core/application_spec.rb +419 -0
  141. data/spec/core/build_spec.rb +423 -0
  142. data/spec/core/checks_spec.rb +519 -0
  143. data/spec/core/common_spec.rb +670 -0
  144. data/spec/core/compile_spec.rb +582 -0
  145. data/spec/core/generate_spec.rb +33 -0
  146. data/spec/core/project_spec.rb +776 -0
  147. data/spec/core/test_spec.rb +1098 -0
  148. data/spec/core/transport_spec.rb +500 -0
  149. data/spec/groovy/bdd_spec.rb +80 -0
  150. data/spec/groovy/compiler_spec.rb +239 -0
  151. data/spec/ide/eclipse_spec.rb +311 -0
  152. data/spec/java/ant.rb +33 -0
  153. data/spec/java/bdd_spec.rb +358 -0
  154. data/spec/java/cobertura_spec.rb +77 -0
  155. data/spec/java/compiler_spec.rb +446 -0
  156. data/spec/java/emma_spec.rb +120 -0
  157. data/spec/java/java_spec.rb +96 -0
  158. data/spec/java/packaging_spec.rb +1120 -0
  159. data/spec/java/test_coverage_spec.rb +255 -0
  160. data/spec/java/tests_spec.rb +471 -0
  161. data/spec/packaging/archive_spec.rb +503 -0
  162. data/spec/packaging/artifact_namespace_spec.rb +646 -0
  163. data/spec/packaging/artifact_spec.rb +795 -0
  164. data/spec/packaging/packaging_helper.rb +63 -0
  165. data/spec/packaging/packaging_spec.rb +589 -0
  166. data/spec/sandbox.rb +139 -0
  167. data/spec/scala/compiler_spec.rb +228 -0
  168. data/spec/scala/tests_spec.rb +215 -0
  169. data/spec/spec_helpers.rb +327 -0
  170. data/spec/version_requirement_spec.rb +123 -0
  171. 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
@@ -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
+ */