forked from seam2/jboss-seam
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathGroovy.xml
executable file
·218 lines (170 loc) · 9.66 KB
/
Groovy.xml
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
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.3//EN" "http://www.oasis-open.org/docbook/xml/4.3/docbookx.dtd">
<chapter id="groovy">
<title>Groovy integration</title>
<para>One aspect of JBoss Seam is its RAD (Rapid Application Development) capability. While not synonymous with RAD,
one interesting tool in this space is dynamic languages. Until recently, choosing a dynamic language was
required choosing a completely different development platform (a development platform with a set of APIs and a
runtime so great that you would no longer want to use you old legacy Java [sic] APIs anymore, which would be
lucky because you would be forced to use those proprietary APIs anyway). Dynamic languages built on top of the
Java Virtual Machine, and <ulink url="http://groovy.codehaus.org">Groovy</ulink> in particular broke this
approach in silos.</para>
<para>JBoss Seam now unites the dynamic language world with the Java EE world by seamlessly integrating both static
and dynamic languages. JBoss Seam lets the application developer use the best tool for the task, without context
switching. Writing dynamic Seam components is exactly like writing regular Seam components. You use the same
annotations, the same APIs, the same everything.</para>
<section>
<title id="groovy-intro">Groovy introduction</title>
<para>Groovy is an agile dynamic language based on the Java language but with additional features inspired by
Python, Ruby and Smalltalk. The strengths of Groovy are twofold:</para>
<itemizedlist>
<listitem>
<para>Java syntax is supported in Groovy: Java code is Groovy code, making the learning curve very
smooth</para>
</listitem>
<listitem>
<para>Groovy objects are Java objects, and Groovy classes are Java classes: Groovy integrates smoothly
with existing Java libraries and frameworks.</para>
</listitem>
</itemizedlist>
</section>
<section>
<title>Writing Seam applications in Groovy</title>
<para>There is not much to say about it. Since a Groovy object is a Java object, you can virtually write any
Seam component, or any class for what it worth, in Groovy and deploy it. You can also mix Groovy classes and
Java classes in the same application.</para>
<section>
<title>Writing Groovy components</title>
<para>As you should have noticed by now, Seam uses annotations heavily. Be sure to use Groovy 1.1 or
above for annotation support. Here are some example of groovy code used in a Seam application.</para>
<section>
<title>Entity</title>
<programlisting role="JAVA"> @Entity
@Name("hotel")
class Hotel implements Serializable
{
@Id @GeneratedValue
Long id
@Size(max=50) @NotNull
String name
@Size(max=100) @NotNull
String address
@Size(max=40) @NotNull
String city
@Size(min=2, max=10) @NotNull
String state
@Size(min=4, max=6) @NotNull
String zip
@Size(min=2, max=40) @NotNull
String country
@Column(precision=6, scale=2)
BigDecimal price
@Override
String toString()
{
return "Hotel(${name},${address},${city},${zip})"
}
}</programlisting>
<para>Groovy natively support the notion of properties (getter/setter), so there is no need to
explicitly write verbose getters and setters: in the previous example, the hotel class can be
accessed from Java as <code>hotel.getCity()</code>, the getters and setters being generated by the
Groovy compiler. This type of syntactic sugar makes the entity code very concise.</para>
</section>
<section>
<title>Seam component</title>
<para>Writing Seam components in Groovy is in no way different than in Java: annotations are used to
mark the class as a Seam component.</para>
<programlisting role="JAVA">@Scope(ScopeType.SESSION)
@Name("bookingList")
class BookingListAction implements Serializable
{
@In EntityManager em
@In User user
@DataModel List<Booking> bookings
@DataModelSelection Booking booking
@Logger Log log
@Factory public void getBookings()
{
bookings = em.createQuery('''
select b from Booking b
where b.user.username = :username
order by b.checkinDate''')
.setParameter("username", user.username)
.getResultList()
}
public void cancel()
{
log.info("Cancel booking: #{bookingList.booking.id} for #{user.username}")
Booking cancelled = em.find(Booking.class, booking.id)
if (cancelled != null) em.remove( cancelled )
getBookings()
FacesMessages.instance().add("Booking cancelled for confirmation number #{bookingList.booking.id}", new Object[0])
}
}</programlisting>
<para/>
</section>
</section>
<section>
<title>seam-gen</title>
<para>Seam gen has a transparent integration with Groovy. You can write Groovy code in seam-gen backed
projects without any additional infrastructure requirement. When writing a Groovy entity, simply place
your <filename>.groovy</filename> files in <filename>src/main</filename>. Unsurprisingly, when writing
an action, simply place your <filename>.groovy</filename> files in
<filename>src/hot</filename>.</para>
</section>
</section>
<section>
<title>Deployment</title>
<para>Deploying Groovy classes is very much like deploying Java classes (surprisingly, no need to write nor
comply with a 3-letter composite specification to support a multi-language component framework).</para>
<para>Beyond standard deployments, JBoss Seam has the ability, at development time, to redeploy JavaBeans Seam
component classes without having to restart the application, saving a lot of time in the development / test
cycle. The same support is provided for GroovyBeans Seam components when the <filename>.groovy</filename>
files are deployed.</para>
<section>
<title>Deploying Groovy code</title>
<para>A Groovy class <emphasis>is</emphasis> a Java class, with a bytecode representation just like a Java
class. To deploy, a Groovy entity, a Groovy Session bean or a Groovy Seam component, a compilation step
is necessary. A common approach is to use the <ulink url="http://docs.codehaus.org/display/GMAVEN/Home">gmaven-plugin</ulink>
maven plugin. Once compiles, a Groovy class is in no way different than a Java class and the application server will treat them
equally. Note that this allow a seamless mix of Groovy and Java code.</para>
</section>
<section>
<title>Native .groovy file deployment at development time</title>
<para>JBoss Seam natively supports the deployment of <literal>.groovy</literal> files (ie without
compilation) in incremental hotdeployment mode (development only). This enables a very fast edit/test
cycle. To set up .groovy deployments, follow the configuration at <xref
linkend="gettingstarted-hotdeployment"/> and deploy your Groovy code (<filename>.groovy</filename>
files) into the <filename>WEB-INF/dev</filename> directory. The GroovyBean components will be picked up
incrementally with no need to restart the application (and obviously not the application server either).</para>
<para>Be aware that the native .groovy file deployment suffers the same limitations as the regular Seam
hotdeployment:</para>
<itemizedlist>
<listitem>
<para>The components must be JavaBeans or GroovyBeans. They cannot be EJB3 bean</para>
</listitem>
<listitem>
<para>Entities cannot be hotdeployed</para>
</listitem>
<listitem>
<para>The hot-deployable components will not be visible to any classes deployed outside of
<literal>WEB-INF/dev</literal></para>
</listitem>
<listitem>
<para>Seam debug mode must be enabled</para>
</listitem>
</itemizedlist>
<para/>
</section>
<section>
<title>seam-gen</title>
<para>Seam-gen transparently supports Groovy files deployment and compilation. This includes the native
<filename>.groovy</filename> file deployment in development mode (compilation-less). If you create a
seam-gen project of type WAR, Java and Groovy classes in <filename>src/hot</filename> will
automatically be candidate for the incremental hot deployment. If you are in production mode, the Groovy
files will simply be compiled before deployment.</para>
<para>You will find a live example of the Booking demo written completely in Groovy and supporting
incremental hot deployment in <filename>examples/groovybooking</filename>.</para>
</section>
</section>
</chapter>