SlideShare a Scribd company logo
1 of 37
Download to read offline
1
               Groovy and Grails




                  What are they, and what are
                    the benefits and risks?



JUG Trento, 11 June 2008
2
              Who am I?

                 John Leach, Chief Technical Officer for Syger
                    Java developer from the start – and still learning
                 Syger - a small software consultancy in Verona, Italy

              Who are you?
                 Who's heard of Groovy?
                 Who's heard of Grails?
                 Who writes web applications?

              Pleased to meet you
                 Warning! Intensive content session
                   Lots to see, not much time
                 Questions at the end

JUG Trento, 11 June 2008
3
              Overview of


                           Dynamic scripting language
                           Similar syntax to Java
                           Evolution not revolution

                           But...
                              with closures
                              and meta programming
                              and relaxed typing
                              and lots of syntax sugar
                              and a silly name - sigh




JUG Trento, 11 June 2008
4
              Overview of


       Ruby on Rails philosophy – evolution not revolution
       Convention over configuration
       Uses 20% Groovy and 80% Java (elegance and power)

       But...
          with Spring, Hibernate, and SiteMesh
          has a plugin architecture
          no XML (though it's there when you need it)
          no HQL/SQL (though they're there when you need them)
          no Ruby, JRuby or Rails




JUG Trento, 11 June 2008
5
              Java to Groovy – Step 1 HelloWorld.groovy

                 public class HelloWorld {
                   private String name;

                     public void setName(String name) {
                       this.name = name;
                     }
                     public String getName() {
                       return name;
                     }
                     public String greet() {
                       return quot;Hello quot; + name;
                     }
                     public static void main(String... args) {
                       HelloWorld helloWorld = new HelloWorld();
                       helloWorld.setName(quot;Groovyquot;);
                       System.out.println(helloWorld.greet());
                     }
                 }

JUG Trento, 11 June 2008
6
              Java to Groovy – Step 2 HelloWorld.groovy

                 class HelloWorld {
                   String name

                     String greet() {
                       return quot;Hello quot; + name
                     }

                     static void main(String... args) {
                       HelloWorld helloWorld = new HelloWorld()
                       helloWorld.name = 'Groovy'
                       println(helloWorld.greet())
                     }
                 }




JUG Trento, 11 June 2008
7
              Java to Groovy – Step 3 HelloWorld.groovy

                 class HelloWorld {
                   String name

                     String greet() {
                       quot;Hello ${name}quot;
                     }

                     static void main(String... args) {
                       println new HelloWorld(name: 'Groovy').greet()
                     }
                 }

                            Plain Ordinary Groovy Objects
                               Reduced clutter
                               Simple constructors
     Adapted from: http://groovy.dzone.com/news/java-groovy-few-easy-steps


JUG Trento, 11 June 2008
8
              Java to Groovy – Check HelloWorld.class

 Groovy: JUGTrento>groovy HelloWorld.groovy
           Hello Groovy

    Java: JUGTrento>groovyc HelloWorld.groovy
           JUGTrento>java -cp %GROOVY_HOME%embeddablegroovy-all-1.5.4.jar;.
            HelloWorld
           Hello Groovy

  Javap: JUGTrento>javap HelloWorld
           Compiled from quot;HelloWorld.groovyquot;
           public class HelloWorld extends java.lang.Object
                   implements groovy.lang.GroovyObject {
               public HelloWorld();
               public java.lang.String greet();
               public java.lang.String getName();
               public void setName(java.lang.String);
               public static java.lang.Object main(java.lang.String[]);
               ...
           }


JUG Trento, 11 June 2008
9
              Groovy Closures – Step 1 ListTests.groovy
import   static java.lang.System.out;
import   static java.util.Arrays.asList;
import   java.util.ArrayList;
import   java.util.List;

public class ListTests {
   public static void main(String... args) {
     List<String> names = asList(quot;Tedquot;, quot;Fredquot;, quot;Jedquot;, quot;Nedquot;);
     out.println(names.getClass().toString() + quot; quot; + names);
     List<String> shortNames = new ArrayList<String>();
     for(String s : names) {
        if (s.length() < 4) {        JUGTrento>groovy ListTests.groovy
           shortNames.add(s);        class java.util.Arrays$ArrayList
        }                              [quot;Tedquot;, quot;Fredquot;, quot;Jedquot;, quot;Nedquot;]
     }                               3
     out.println(shortNames.size()); Ted
     for(String s : shortNames) {    Jed
        out.println(s);              Ned
     }
   }
} JUG Trento, 11 June 2008
10
              Groovy Closures – Step 2 ListTests.groovy

        class ListTests {
          static void main(String... args) {
            List<String> names = ['Ted', 'Fred', 'Jed', 'Ned']
            println quot;${names.class} ${names}quot;
            List<String> shortNames = new ArrayList()
            for(String s : names) {
              if (s.length() < 4) {
                shortNames << s
              }
            }
            println shortNames.size()
            shortNames.each { println it }
          }
        }




JUG Trento, 11 June 2008
11
              Groovy Closures – Step 3 ListTests.groovy

        List<String> names = ['Ted', 'Fred', 'Jed', 'Ned']
        println quot;${names.class} ${names}quot;
        List<String> shortNames = names.findAll { it.length() < 4 }
        println shortNames.size()
        shortNames.each { println it }
          JUGTrento>groovy ListTests.groovy
          class java.util.ArrayList [quot;Tedquot;, quot;Fredquot;, quot;Jedquot;, quot;Nedquot;]
          3
          Ted
          Jed
          Ned
                           Idiomatic Groovy
                               Reduced clutter
                               Simple concise syntax
  Adapted from: http://groovy.dzone.com/news/java-groovy-part-2-closures-an


JUG Trento, 11 June 2008
12
              Meta Object Protocol - MOP

         Introspection:
            MyClass.metaClass.methods.each { println it.name }
            MyClass.metaClass.properties.each { println it.name }
            MyClass.metaClass.respondsTo(obj, 'execute')
            MyClass.metaClass.hasProperty(obj, 'status')

         Dynamic method invocation:
            obj.quot;$namequot;()

         Dynamic property getters and setters:
            Object value = obj.quot;$namequot;
            obj.quot;$namequot; = value



JUG Trento, 11 June 2008
13
              Meta Object Protocol - MOP


Intercepting (Aspect Oriented Programming)
  def invokeMethod = { String name, args -> println quot;$name invokedquot; }
  def getProperty = { String name -> println quot;getting $namequot; }
  def setProperty = { String name, value -> println quot;setting $namequot; }

Changing behaviour at run time:
  def methodMissing = { String name, args -> quot;No $name methodquot; }
  def propertyMissing = { String name -> quot;No $name propertyquot; }
  Duck.metaClass.quack = { quot;Quack!quot; } // duck.quack()
  Duck.metaClass.getSpecies = { -> quot;Canardquot; } // duck.species




JUG Trento, 11 June 2008
14
              Domain Specific Language: AntBuilder

 AntBuilder ant = new AntBuilder()
 String myDir = 'target/AntTest/'
 ant.sequential {
   echo('inside sequential')
   mkdir(dir: myDir)
   copy(todir: myDir) {
     fileset(dir: 'src/test') {
       include(name: '**/*.groovy')
     }
   }
   echo('done')
 }
 File file = new File('target/AntTest/groovy/util/AntTest.groovy')
 assert file.exists() // yes it does
          Adapted from:    http://groovy.codehaus.org/Using+Ant+from+Groovy

     Gant – Groovy, Ant, but no XML: http://gant.codehaus.org/

JUG Trento, 11 June 2008
15
              Domain Specific Language: MarkupBuilder

    Groovy snippet:
    MarkupBuilder xml = new MarkupBuilder(writer)
    xml.'rec:records'('xmlns:rec':'http://groovy.codehaus.org') {
      car(name:'HSV Maloo', make:'Holden', year:2006) {
        country('Australia')
        record(type:'speed', ' Truck with speed of 271kph')
      }
    }

    Output snippet:
    <rec:records xmlns:rec='http://groovy.codehaus.org'>
      <car name='HSV Maloo' make='Holden' year='2006'>
        <country>Australia</country>
        <record type='speed'> Truck with speed of 271kph</record>
      </car>
    </rec:records>
  Adapted from: http://groovy.codehaus.org/Creating+XML+using+Groovy's+MarkupBuilder


JUG Trento, 11 June 2008
16
              But Wait, there's More!

Ranges – 0..9, 0.<10
Curried closures
Regular expression syntax sugar - /d+/
Extended switch operator – switch(title) { case 'Groovy': ...
Operator overloading – list << item
Elvis operator – value = value ?: defaultValue;
Safe dereferencing - person?.parents?.grandParents
The Expando class – saves writing a 'real' class
Unit testing, the Groovy Mock Library
SwingBuilder
Joint compiler (compile Groovy and Java source code together)
...
But we don't have time for all that now

JUG Trento, 11 June 2008
17
              Groovy – the Good News

Past the version 1.0 barrier (2 Jan 2007)

IDE support is maturing (Eclipse, NetBeans, and IntelliJ IDEA)

Being used in industry

Currently around 30th place according to TIOBE (http://www.tiobe.com)

G2One Inc., support from the Lead developer (Guillaume Laforge)

IBM Project Zero

“Drill down” to Java when you need the speed


JUG Trento, 11 June 2008
18
              Groovy – the Bad News




                  IDE support is still maturing

                  Slow execution speed (but not s-l-o-w)

                  Idiomatic Groovy is not Java

                  Won't get you a Job




JUG Trento, 11 June 2008
19
              Groovy – the Fear, Uncertainty, and Doubt



          Interpreted language – no, compiled to Java bytecode

          Not a standard – no, JSR 241

          Orphan project – no Sun, Oracle, IBM, IntelliJ support

          Usurping Java – no, augmenting Java

          No Groovy programmers – no, most Java programmers
             should understand it




JUG Trento, 11 June 2008
20
               Pragmatic Groovy



          Start in places where execution speed is less important:

               Build scripts – AntBuilder, Gant

               Unit testing, and mocking

               Swing User Interfaces – SwingBuilder

               Domain Specific Languages




JUG Trento, 11 June 2008
21
              Grails – What's in the Box?


                    Generators
                    Predefined application layout (folders)
                    Model View Controller pattern - surprise!
                    GORM – Hibernate made easy
                    Spring and Spring MVC under the covers
                    SiteMesh powering the views
                    Groovy Server Pages (GSP)
                    Tag Libraries but no XML
                    Plug-in architecture
                    Testing – unit, integration, web
                    Excellent, concise documentation



JUG Trento, 11 June 2008
22
               Generators

         grails create-app      Creates (and populates) the application directories
grails create-domain-class      Creates an empty domain (model) class
     grails create-service      Creates a transactional business logic class
     grails create-tag-lib      Creates an empty tag library class
   grails create-unit-test      Creates a unit test class
grails generate-controller      Generates a CRUD controller class for a domain class
     grails generate-views      Generates the four CRUD views for a domain class
            grails run-app      Runs the web application in Jetty
           grails test-app      Runs the unit tests
            grails console      Runs the Grails Swing interactive console
              grails shell      Runs the Grails interactive shell
                grails war      Creates a war file for JEE deployment
             Run grails create-app, then grails run-app,
 and you've got an (empty) running web application, in less than 30 seconds
                    You'll still have to write some code yourself

 JUG Trento, 11 June 2008
23
                Domain Models
class Album {                             class Picture {
  User user                                User user
  String caption                           Album album
  String description                POGO   Set images
  Set pictures                             String file
                                           String caption

                                 Associations
  static belongsTo = User                  static belongsTo = [ User, Album ]
  static hasMany = [ pictures:Picture ]    static hasMany = [ images:Image ]


  static constraints = {
                             Validation    Transient properties
    caption(size:1..40, blank:false)       static transients = [ 'file' ]
  }

                        Object Relational Mapping
  static mapping = {                      static mapping = {
    pictures cascade:'all', inverse:true    images cascade:'all', inverse:true
    description type:'text'               }
    user index:'user_idx', unique:false }
  }
} JUG Trento, 11 June 2008
24
              Views

                                            views/layouts/main.gsp
     <!DOCTYPE html ... >
     <html xmlns=quot;http://www.w3.org/1999/xhtmlquot;>
       <head>
         <title><g:layoutTitle default=quot;WebAlbumquot; /></title>
         <link rel=quot;stylesheetquot; type=quot;text/cssquot;
           href=quot;${createLinkTo(dir:'css', file:'main.css')}quot;/>
         <g:layoutHead />
       </head>
       <body>
         <div class='title'>WebAlbum</div>
         <div class='content'>
           <g:layoutBody />
         </div>
       </body>
     </html>



JUG Trento, 11 June 2008
25
            Views
<html>
  <head>
    <meta name=quot;layoutquot; content=quot;mainquot; /> views/picture/create.gsp
    <title>WebAlbum : Create Picture</title>              <g:layoutTitle />
    <script type=quot;text/javascriptquot;> ... </script>
  </head>                                                 <g:layoutHead />
  <body>
    <h1>Create Picture</h1>                               <g:layoutBody />
       <g:uploadForm action=quot;savequot;>
               ...
          <td valign=quot;topquot; class=quot;namequot;>
              <label for=quot;captionquot;>Caption:</label>
          </td>
          <td valign=quot;topquot; class=quot;valuequot;>
              <input type=quot;textquot; size=quot;40quot; maxlength=quot;40quot;
                 id=quot;captionquot; name=quot;captionquot;
                 value=quot;${fieldValue(bean: picture, field: 'caption')}quot;/>
          </td>
               ...
       </g:uploadForm>                             domain/Picture.groovy
  </body>
</html>
 JUG Trento, 11 June 2008
26
              Controllers

class PictureController {

    def list = {
      [list:Picture.list(params), paginateCount:Picture.count()]
    }

    def show = {
      Picture picture = Picture.get(params.id)
      if (!picture) {
        flash.message = quot;Picture not foundquot;
        redirect(action:list)
      }
      else {
        return [picture:picture]
      }
    }
    ...
}

JUG Trento, 11 June 2008
27
               Controllers

class PictureController {

    def beforeInterceptor = [ action:this.&intercept, only:['create']]

    def create = {
      ...
    }

    def intercept() {
      User user = sessionUser()
      if (!user || user.albumsCount == 0) {
        flash.warning = quot;You must create an album first!quot;
        redirect(controller: 'album', action: 'create')
        return false
      }
      true
    }
}

JUG Trento, 11 June 2008
28
               Tag Libraries

                                           views/picture/show.gsp


...
<tr class=quot;propquot;>
  <td valign=quot;topquot; class=quot;namequot;>Caption:</td>
  <td valign=quot;topquot; class=quot;valuequot;>
    <wa:pictureAnchor picture=quot;${picture}quot; size=quot;${Image.Original}quot;>
      ${picture.caption ?: '...'}
    </wa:pictureAnchor>
  </td>
</tr>
...




JUG Trento, 11 June 2008
29
              Tag Libraries

class WebAlbumTagLib {                 taglib/WebAlbumTagLib.groovy
    static namespace = quot;waquot;

    def pictureAnchor = { attrs, body ->
      Picture picture = attrs.remove('picture')
      def size = attrs.remove('size')
      String link = createPictureLink(picture.id, size).encodeAsHTML()
      out << quot;<a href=quot;${link}quot;quot;
      attrs.each { key, value ->
        out << quot; $key=quot;$valuequot;quot;
      }
      out << '>'
      out << body()
      out << '</a>'
    }
    ...
}

JUG Trento, 11 June 2008
30
              But Wait, there's More!

Filters – conf/WebAlbumFilter.groovy
Create Gant scripts – scripts/CompileSources.groovy
GORM many-to-many, composition, inheritance, eager fetching, ...
GORM dynamic finders – findByFirstNameAndLastName(...)
GORM transactions – User.withTransaction { status -> ... }
Controller chaining
Shared templates
URL mappings - quot;/salequot;(controller:'product', action:'sale')
Multiple request conversations – Web Flow
Ajax support – Prototype, Dojo, Yahoo UI, GWT
Content negotiation
Web Services – REST and SOAP
...
But we don't have time for all that now

JUG Trento, 11 June 2008
31
              Grails – the Good News



    Past the version 1.0 barrier (4 Feb 2008)

    IDE support is maturing (Eclipse, NetBeans, and IntelliJ IDEA)

    Being used in industry

    G2One Inc., support from the Lead developer (Graeme Rocher)

    “Drill down” to Java when you need to




JUG Trento, 11 June 2008
32
              Grails – the Bad News




                   IDE support is still maturing

                   Slow execution speed (but not s-l-o-w)

                   Won't get you a Job




JUG Trento, 11 June 2008
33
               Grails – the Fear, Uncertainty, and Doubt


 Another Rails clone – no, uses the philosophy in a Groovy/Java way

 Built with an interpreted language (Groovy) – no, 20% Groovy which
    compiles to bytecode anyway

 No Grails programmers – no, see no Groovy programmers

 Only good for CRUD applications – no, you can do any full stack JEE
    application, SOAP and REST included

 Much slower than JEE – no, Sun engineers results showed JEE
   to be 2 to 4 times faster with 100 to 500 concurrent users
     http://developers.sun.com/learning/javaoneonline/j1sessn.jsp?sessn=TS-9535&yr=2007&track=9




JUG Trento, 11 June 2008
34
               Pragmatic Grails



          Start in places where execution speed is less important:

               In-house web applications

               “Long tail” applications (10 – 50 concurrent users)

               Prototyping a JEE web application




JUG Trento, 11 June 2008
35
               What's Next?



 Groovy: http://groovy.codehaus.org/
 Grails: http://grails.org/
 About Groovy: http://aboutgroovy.com/
 Groovy Zone: http://groovy.dzone.com/
 InfoQ Groovy: http://www.infoq.com/groovy
 InfoQ Grails: http://www.infoq.com/grails
 Graeme Rocher's blog: http://graemerocher.blogspot.com/
 Guillaume Laforge's blog: http://glaforge.free.fr/weblog/
 G2One Inc.: http://www.g2one.com/index.html




JUG Trento, 11 June 2008
36
               Read the Books, Watch the Movies



   Books:
     Groovy Recipes: http://pragprog.com/titles/sdgrvr
     Programming Groovy: http://pragprog.com/titles/vslg
     Groovy in Action: http://www.manning.com/koenig/
     The Definitive Guide to Grails:
         http://www.apress.com/book/view/1590597583

   Films:
       Grails eXchange 2007: http://grails-exchange.com/




JUG Trento, 11 June 2008
37
               Thank You, any Questions?


                 Syger: http://www.syger.it/

Grails WebAlbum:
  http://www.syger.it/Tutorials/GrailsWebAlbum.html

Ruby on Rails WebAlbum (a comparison, written first):
  http://www.syger.it/Tutorials/RubyOnRailsWebAlbum.html

             My personal site: http://www.jhl.it/

                 Contact: john.leach@syger.it



JUG Trento, 11 June 2008

More Related Content

What's hot

Introduction httpClient on Java11 / Java11時代のHTTPアクセス再入門
Introduction httpClient on Java11 / Java11時代のHTTPアクセス再入門Introduction httpClient on Java11 / Java11時代のHTTPアクセス再入門
Introduction httpClient on Java11 / Java11時代のHTTPアクセス再入門tamtam180
 
Java Bytecode For Discriminating Developers - GeeCON 2011
Java Bytecode For Discriminating Developers - GeeCON 2011Java Bytecode For Discriminating Developers - GeeCON 2011
Java Bytecode For Discriminating Developers - GeeCON 2011Anton Arhipov
 
Demystifying dependency Injection: Dagger and Toothpick
Demystifying dependency Injection: Dagger and ToothpickDemystifying dependency Injection: Dagger and Toothpick
Demystifying dependency Injection: Dagger and ToothpickDanny Preussler
 
Back to the future with Java 7 (Geekout June/2011)
Back to the future with Java 7 (Geekout June/2011)Back to the future with Java 7 (Geekout June/2011)
Back to the future with Java 7 (Geekout June/2011)Martijn Verburg
 
Software Testing - Invited Lecture at UNSW Sydney
Software Testing - Invited Lecture at UNSW SydneySoftware Testing - Invited Lecture at UNSW Sydney
Software Testing - Invited Lecture at UNSW Sydneyjulien.ponge
 
Vaadin7 modern-web-apps-in-java
Vaadin7 modern-web-apps-in-javaVaadin7 modern-web-apps-in-java
Vaadin7 modern-web-apps-in-javaJoonas Lehtinen
 
Using the Groovy Ecosystem for Rapid JVM Development
Using the Groovy Ecosystem for Rapid JVM DevelopmentUsing the Groovy Ecosystem for Rapid JVM Development
Using the Groovy Ecosystem for Rapid JVM DevelopmentSchalk Cronjé
 
Construire une application JavaFX 8 avec gradle
Construire une application JavaFX 8 avec gradleConstruire une application JavaFX 8 avec gradle
Construire une application JavaFX 8 avec gradleThierry Wasylczenko
 
JEEConf 2017 - The hitchhiker’s guide to Java class reloading
JEEConf 2017 - The hitchhiker’s guide to Java class reloadingJEEConf 2017 - The hitchhiker’s guide to Java class reloading
JEEConf 2017 - The hitchhiker’s guide to Java class reloadingAnton Arhipov
 
Kotlin coroutine - the next step for RxJava developer?
Kotlin coroutine - the next step for RxJava developer?Kotlin coroutine - the next step for RxJava developer?
Kotlin coroutine - the next step for RxJava developer?Artur Latoszewski
 
Tomasz Polanski - Automated mobile testing 2016 - Testing: why, when, how
Tomasz Polanski - Automated mobile testing 2016 - Testing: why, when, howTomasz Polanski - Automated mobile testing 2016 - Testing: why, when, how
Tomasz Polanski - Automated mobile testing 2016 - Testing: why, when, howTomasz Polanski
 
15 tips to improve your unit tests (Droidcon Berlin 2016 Barcamp)
15 tips to improve your unit tests (Droidcon Berlin 2016 Barcamp)15 tips to improve your unit tests (Droidcon Berlin 2016 Barcamp)
15 tips to improve your unit tests (Droidcon Berlin 2016 Barcamp)Danny Preussler
 
soft-shake.ch - Java SE 7: The Fork/Join Framework and Project Coin
soft-shake.ch - Java SE 7: The Fork/Join Framework and Project Coinsoft-shake.ch - Java SE 7: The Fork/Join Framework and Project Coin
soft-shake.ch - Java SE 7: The Fork/Join Framework and Project Coinsoft-shake.ch
 

What's hot (20)

Introduction httpClient on Java11 / Java11時代のHTTPアクセス再入門
Introduction httpClient on Java11 / Java11時代のHTTPアクセス再入門Introduction httpClient on Java11 / Java11時代のHTTPアクセス再入門
Introduction httpClient on Java11 / Java11時代のHTTPアクセス再入門
 
Java Bytecode For Discriminating Developers - GeeCON 2011
Java Bytecode For Discriminating Developers - GeeCON 2011Java Bytecode For Discriminating Developers - GeeCON 2011
Java Bytecode For Discriminating Developers - GeeCON 2011
 
Demystifying dependency Injection: Dagger and Toothpick
Demystifying dependency Injection: Dagger and ToothpickDemystifying dependency Injection: Dagger and Toothpick
Demystifying dependency Injection: Dagger and Toothpick
 
Back to the future with Java 7 (Geekout June/2011)
Back to the future with Java 7 (Geekout June/2011)Back to the future with Java 7 (Geekout June/2011)
Back to the future with Java 7 (Geekout June/2011)
 
Software Testing - Invited Lecture at UNSW Sydney
Software Testing - Invited Lecture at UNSW SydneySoftware Testing - Invited Lecture at UNSW Sydney
Software Testing - Invited Lecture at UNSW Sydney
 
Vaadin7
Vaadin7Vaadin7
Vaadin7
 
Vaadin7 modern-web-apps-in-java
Vaadin7 modern-web-apps-in-javaVaadin7 modern-web-apps-in-java
Vaadin7 modern-web-apps-in-java
 
groovy & grails - lecture 7
groovy & grails - lecture 7groovy & grails - lecture 7
groovy & grails - lecture 7
 
Vaadin 7
Vaadin 7Vaadin 7
Vaadin 7
 
Using the Groovy Ecosystem for Rapid JVM Development
Using the Groovy Ecosystem for Rapid JVM DevelopmentUsing the Groovy Ecosystem for Rapid JVM Development
Using the Groovy Ecosystem for Rapid JVM Development
 
Code Samples
Code SamplesCode Samples
Code Samples
 
Construire une application JavaFX 8 avec gradle
Construire une application JavaFX 8 avec gradleConstruire une application JavaFX 8 avec gradle
Construire une application JavaFX 8 avec gradle
 
JEEConf 2017 - The hitchhiker’s guide to Java class reloading
JEEConf 2017 - The hitchhiker’s guide to Java class reloadingJEEConf 2017 - The hitchhiker’s guide to Java class reloading
JEEConf 2017 - The hitchhiker’s guide to Java class reloading
 
Vaadin 7
Vaadin 7Vaadin 7
Vaadin 7
 
Kotlin coroutine - the next step for RxJava developer?
Kotlin coroutine - the next step for RxJava developer?Kotlin coroutine - the next step for RxJava developer?
Kotlin coroutine - the next step for RxJava developer?
 
Tomasz Polanski - Automated mobile testing 2016 - Testing: why, when, how
Tomasz Polanski - Automated mobile testing 2016 - Testing: why, when, howTomasz Polanski - Automated mobile testing 2016 - Testing: why, when, how
Tomasz Polanski - Automated mobile testing 2016 - Testing: why, when, how
 
15 tips to improve your unit tests (Droidcon Berlin 2016 Barcamp)
15 tips to improve your unit tests (Droidcon Berlin 2016 Barcamp)15 tips to improve your unit tests (Droidcon Berlin 2016 Barcamp)
15 tips to improve your unit tests (Droidcon Berlin 2016 Barcamp)
 
#JavaFX.forReal() - ElsassJUG
#JavaFX.forReal() - ElsassJUG#JavaFX.forReal() - ElsassJUG
#JavaFX.forReal() - ElsassJUG
 
soft-shake.ch - Java SE 7: The Fork/Join Framework and Project Coin
soft-shake.ch - Java SE 7: The Fork/Join Framework and Project Coinsoft-shake.ch - Java SE 7: The Fork/Join Framework and Project Coin
soft-shake.ch - Java SE 7: The Fork/Join Framework and Project Coin
 
Thread dumps
Thread dumpsThread dumps
Thread dumps
 

Viewers also liked

Ideas for Developing Financial Resources
Ideas for Developing Financial ResourcesIdeas for Developing Financial Resources
Ideas for Developing Financial ResourcesNew World Foundation
 
Passover 2011
Passover 2011Passover 2011
Passover 2011Jaki Levy
 
Social Media for Small Businesses
Social Media for Small BusinessesSocial Media for Small Businesses
Social Media for Small BusinessesJaki Levy
 
Socially Networked Arts Groups
Socially Networked Arts GroupsSocially Networked Arts Groups
Socially Networked Arts GroupsJaki Levy
 
Soundstreams Presentation by Jaki Levy
Soundstreams Presentation by Jaki LevySoundstreams Presentation by Jaki Levy
Soundstreams Presentation by Jaki LevyJaki Levy
 
Backup e restore - rdiff backup
Backup e restore - rdiff backupBackup e restore - rdiff backup
Backup e restore - rdiff backupJohn Leach
 

Viewers also liked (6)

Ideas for Developing Financial Resources
Ideas for Developing Financial ResourcesIdeas for Developing Financial Resources
Ideas for Developing Financial Resources
 
Passover 2011
Passover 2011Passover 2011
Passover 2011
 
Social Media for Small Businesses
Social Media for Small BusinessesSocial Media for Small Businesses
Social Media for Small Businesses
 
Socially Networked Arts Groups
Socially Networked Arts GroupsSocially Networked Arts Groups
Socially Networked Arts Groups
 
Soundstreams Presentation by Jaki Levy
Soundstreams Presentation by Jaki LevySoundstreams Presentation by Jaki Levy
Soundstreams Presentation by Jaki Levy
 
Backup e restore - rdiff backup
Backup e restore - rdiff backupBackup e restore - rdiff backup
Backup e restore - rdiff backup
 

Similar to Groovy And Grails JUG Trento

Apache Groovy: the language and the ecosystem
Apache Groovy: the language and the ecosystemApache Groovy: the language and the ecosystem
Apache Groovy: the language and the ecosystemKostas Saidis
 
Metaprogramming with Groovy
Metaprogramming with GroovyMetaprogramming with Groovy
Metaprogramming with GroovyAli Tanwir
 
Eclipsecon08 Introduction To Groovy
Eclipsecon08 Introduction To GroovyEclipsecon08 Introduction To Groovy
Eclipsecon08 Introduction To GroovyAndres Almiray
 
Groovy for Java Developers
Groovy for Java DevelopersGroovy for Java Developers
Groovy for Java DevelopersAndres Almiray
 
Boosting Your Testing Productivity with Groovy
Boosting Your Testing Productivity with GroovyBoosting Your Testing Productivity with Groovy
Boosting Your Testing Productivity with GroovyJames Williams
 
Javaone2008 Bof 5101 Groovytesting
Javaone2008 Bof 5101 GroovytestingJavaone2008 Bof 5101 Groovytesting
Javaone2008 Bof 5101 GroovytestingAndres Almiray
 
Introduction To Groovy
Introduction To GroovyIntroduction To Groovy
Introduction To Groovymanishkp84
 
名古屋SGGAE/J勉強会 Grails、Gaelykでハンズオン
名古屋SGGAE/J勉強会 Grails、Gaelykでハンズオン名古屋SGGAE/J勉強会 Grails、Gaelykでハンズオン
名古屋SGGAE/J勉強会 Grails、GaelykでハンズオンTsuyoshi Yamamoto
 
Groovy for java developers
Groovy for java developersGroovy for java developers
Groovy for java developersPuneet Behl
 
Grooscript gr8conf
Grooscript gr8confGrooscript gr8conf
Grooscript gr8confGR8Conf
 
Groovy and Grails in Action - Devoxx 2008 - University - Guillaume Laforge
Groovy and Grails in Action - Devoxx 2008 - University - Guillaume LaforgeGroovy and Grails in Action - Devoxx 2008 - University - Guillaume Laforge
Groovy and Grails in Action - Devoxx 2008 - University - Guillaume LaforgeGuillaume Laforge
 
Oscon Java Testing on the Fast Lane
Oscon Java Testing on the Fast LaneOscon Java Testing on the Fast Lane
Oscon Java Testing on the Fast LaneAndres Almiray
 
2007 09 10 Fzi Training Groovy Grails V Ws
2007 09 10 Fzi Training Groovy Grails V Ws2007 09 10 Fzi Training Groovy Grails V Ws
2007 09 10 Fzi Training Groovy Grails V Wsloffenauer
 
GTAC Boosting your Testing Productivity with Groovy
GTAC Boosting your Testing Productivity with GroovyGTAC Boosting your Testing Productivity with Groovy
GTAC Boosting your Testing Productivity with GroovyAndres Almiray
 
Atlassian Groovy Plugins
Atlassian Groovy PluginsAtlassian Groovy Plugins
Atlassian Groovy PluginsPaul King
 
Android and the Seven Dwarfs from Devox'15
Android and the Seven Dwarfs from Devox'15Android and the Seven Dwarfs from Devox'15
Android and the Seven Dwarfs from Devox'15Murat Yener
 

Similar to Groovy And Grails JUG Trento (20)

Apache Groovy: the language and the ecosystem
Apache Groovy: the language and the ecosystemApache Groovy: the language and the ecosystem
Apache Groovy: the language and the ecosystem
 
Metaprogramming with Groovy
Metaprogramming with GroovyMetaprogramming with Groovy
Metaprogramming with Groovy
 
MetaProgramming with Groovy
MetaProgramming with GroovyMetaProgramming with Groovy
MetaProgramming with Groovy
 
Eclipsecon08 Introduction To Groovy
Eclipsecon08 Introduction To GroovyEclipsecon08 Introduction To Groovy
Eclipsecon08 Introduction To Groovy
 
Groovy for Java Developers
Groovy for Java DevelopersGroovy for Java Developers
Groovy for Java Developers
 
Boosting Your Testing Productivity with Groovy
Boosting Your Testing Productivity with GroovyBoosting Your Testing Productivity with Groovy
Boosting Your Testing Productivity with Groovy
 
Javaone2008 Bof 5101 Groovytesting
Javaone2008 Bof 5101 GroovytestingJavaone2008 Bof 5101 Groovytesting
Javaone2008 Bof 5101 Groovytesting
 
Introduction To Groovy
Introduction To GroovyIntroduction To Groovy
Introduction To Groovy
 
名古屋SGGAE/J勉強会 Grails、Gaelykでハンズオン
名古屋SGGAE/J勉強会 Grails、Gaelykでハンズオン名古屋SGGAE/J勉強会 Grails、Gaelykでハンズオン
名古屋SGGAE/J勉強会 Grails、Gaelykでハンズオン
 
What's New in Groovy 1.6?
What's New in Groovy 1.6?What's New in Groovy 1.6?
What's New in Groovy 1.6?
 
Groovy for java developers
Groovy for java developersGroovy for java developers
Groovy for java developers
 
Grooscript gr8conf
Grooscript gr8confGrooscript gr8conf
Grooscript gr8conf
 
Groovy and Grails in Action - Devoxx 2008 - University - Guillaume Laforge
Groovy and Grails in Action - Devoxx 2008 - University - Guillaume LaforgeGroovy and Grails in Action - Devoxx 2008 - University - Guillaume Laforge
Groovy and Grails in Action - Devoxx 2008 - University - Guillaume Laforge
 
Project Coin
Project CoinProject Coin
Project Coin
 
Oscon Java Testing on the Fast Lane
Oscon Java Testing on the Fast LaneOscon Java Testing on the Fast Lane
Oscon Java Testing on the Fast Lane
 
2007 09 10 Fzi Training Groovy Grails V Ws
2007 09 10 Fzi Training Groovy Grails V Ws2007 09 10 Fzi Training Groovy Grails V Ws
2007 09 10 Fzi Training Groovy Grails V Ws
 
GTAC Boosting your Testing Productivity with Groovy
GTAC Boosting your Testing Productivity with GroovyGTAC Boosting your Testing Productivity with Groovy
GTAC Boosting your Testing Productivity with Groovy
 
Atlassian Groovy Plugins
Atlassian Groovy PluginsAtlassian Groovy Plugins
Atlassian Groovy Plugins
 
Android and the Seven Dwarfs from Devox'15
Android and the Seven Dwarfs from Devox'15Android and the Seven Dwarfs from Devox'15
Android and the Seven Dwarfs from Devox'15
 
OpenLogic
OpenLogicOpenLogic
OpenLogic
 

Recently uploaded

Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...
Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...
Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...Neo4j
 
The Role of Taxonomy and Ontology in Semantic Layers - Heather Hedden.pdf
The Role of Taxonomy and Ontology in Semantic Layers - Heather Hedden.pdfThe Role of Taxonomy and Ontology in Semantic Layers - Heather Hedden.pdf
The Role of Taxonomy and Ontology in Semantic Layers - Heather Hedden.pdfEnterprise Knowledge
 
Injustice - Developers Among Us (SciFiDevCon 2024)
Injustice - Developers Among Us (SciFiDevCon 2024)Injustice - Developers Among Us (SciFiDevCon 2024)
Injustice - Developers Among Us (SciFiDevCon 2024)Allon Mureinik
 
CNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of ServiceCNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of Servicegiselly40
 
IAC 2024 - IA Fast Track to Search Focused AI Solutions
IAC 2024 - IA Fast Track to Search Focused AI SolutionsIAC 2024 - IA Fast Track to Search Focused AI Solutions
IAC 2024 - IA Fast Track to Search Focused AI SolutionsEnterprise Knowledge
 
Finology Group – Insurtech Innovation Award 2024
Finology Group – Insurtech Innovation Award 2024Finology Group – Insurtech Innovation Award 2024
Finology Group – Insurtech Innovation Award 2024The Digital Insurer
 
Slack Application Development 101 Slides
Slack Application Development 101 SlidesSlack Application Development 101 Slides
Slack Application Development 101 Slidespraypatel2
 
A Call to Action for Generative AI in 2024
A Call to Action for Generative AI in 2024A Call to Action for Generative AI in 2024
A Call to Action for Generative AI in 2024Results
 
Maximizing Board Effectiveness 2024 Webinar.pptx
Maximizing Board Effectiveness 2024 Webinar.pptxMaximizing Board Effectiveness 2024 Webinar.pptx
Maximizing Board Effectiveness 2024 Webinar.pptxOnBoard
 
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptxHampshireHUG
 
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...Igalia
 
Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024BookNet Canada
 
The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024Rafal Los
 
Salesforce Community Group Quito, Salesforce 101
Salesforce Community Group Quito, Salesforce 101Salesforce Community Group Quito, Salesforce 101
Salesforce Community Group Quito, Salesforce 101Paola De la Torre
 
My Hashitalk Indonesia April 2024 Presentation
My Hashitalk Indonesia April 2024 PresentationMy Hashitalk Indonesia April 2024 Presentation
My Hashitalk Indonesia April 2024 PresentationRidwan Fadjar
 
Understanding the Laravel MVC Architecture
Understanding the Laravel MVC ArchitectureUnderstanding the Laravel MVC Architecture
Understanding the Laravel MVC ArchitecturePixlogix Infotech
 
Unblocking The Main Thread Solving ANRs and Frozen Frames
Unblocking The Main Thread Solving ANRs and Frozen FramesUnblocking The Main Thread Solving ANRs and Frozen Frames
Unblocking The Main Thread Solving ANRs and Frozen FramesSinan KOZAK
 
08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking Men08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking MenDelhi Call girls
 
Presentation on how to chat with PDF using ChatGPT code interpreter
Presentation on how to chat with PDF using ChatGPT code interpreterPresentation on how to chat with PDF using ChatGPT code interpreter
Presentation on how to chat with PDF using ChatGPT code interpreternaman860154
 
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...HostedbyConfluent
 

Recently uploaded (20)

Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...
Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...
Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...
 
The Role of Taxonomy and Ontology in Semantic Layers - Heather Hedden.pdf
The Role of Taxonomy and Ontology in Semantic Layers - Heather Hedden.pdfThe Role of Taxonomy and Ontology in Semantic Layers - Heather Hedden.pdf
The Role of Taxonomy and Ontology in Semantic Layers - Heather Hedden.pdf
 
Injustice - Developers Among Us (SciFiDevCon 2024)
Injustice - Developers Among Us (SciFiDevCon 2024)Injustice - Developers Among Us (SciFiDevCon 2024)
Injustice - Developers Among Us (SciFiDevCon 2024)
 
CNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of ServiceCNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of Service
 
IAC 2024 - IA Fast Track to Search Focused AI Solutions
IAC 2024 - IA Fast Track to Search Focused AI SolutionsIAC 2024 - IA Fast Track to Search Focused AI Solutions
IAC 2024 - IA Fast Track to Search Focused AI Solutions
 
Finology Group – Insurtech Innovation Award 2024
Finology Group – Insurtech Innovation Award 2024Finology Group – Insurtech Innovation Award 2024
Finology Group – Insurtech Innovation Award 2024
 
Slack Application Development 101 Slides
Slack Application Development 101 SlidesSlack Application Development 101 Slides
Slack Application Development 101 Slides
 
A Call to Action for Generative AI in 2024
A Call to Action for Generative AI in 2024A Call to Action for Generative AI in 2024
A Call to Action for Generative AI in 2024
 
Maximizing Board Effectiveness 2024 Webinar.pptx
Maximizing Board Effectiveness 2024 Webinar.pptxMaximizing Board Effectiveness 2024 Webinar.pptx
Maximizing Board Effectiveness 2024 Webinar.pptx
 
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
 
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
 
Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
Transcript: #StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
 
The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024
 
Salesforce Community Group Quito, Salesforce 101
Salesforce Community Group Quito, Salesforce 101Salesforce Community Group Quito, Salesforce 101
Salesforce Community Group Quito, Salesforce 101
 
My Hashitalk Indonesia April 2024 Presentation
My Hashitalk Indonesia April 2024 PresentationMy Hashitalk Indonesia April 2024 Presentation
My Hashitalk Indonesia April 2024 Presentation
 
Understanding the Laravel MVC Architecture
Understanding the Laravel MVC ArchitectureUnderstanding the Laravel MVC Architecture
Understanding the Laravel MVC Architecture
 
Unblocking The Main Thread Solving ANRs and Frozen Frames
Unblocking The Main Thread Solving ANRs and Frozen FramesUnblocking The Main Thread Solving ANRs and Frozen Frames
Unblocking The Main Thread Solving ANRs and Frozen Frames
 
08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking Men08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking Men
 
Presentation on how to chat with PDF using ChatGPT code interpreter
Presentation on how to chat with PDF using ChatGPT code interpreterPresentation on how to chat with PDF using ChatGPT code interpreter
Presentation on how to chat with PDF using ChatGPT code interpreter
 
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
 

Groovy And Grails JUG Trento

  • 1. 1 Groovy and Grails What are they, and what are the benefits and risks? JUG Trento, 11 June 2008
  • 2. 2 Who am I? John Leach, Chief Technical Officer for Syger Java developer from the start – and still learning Syger - a small software consultancy in Verona, Italy Who are you? Who's heard of Groovy? Who's heard of Grails? Who writes web applications? Pleased to meet you Warning! Intensive content session Lots to see, not much time Questions at the end JUG Trento, 11 June 2008
  • 3. 3 Overview of Dynamic scripting language Similar syntax to Java Evolution not revolution But... with closures and meta programming and relaxed typing and lots of syntax sugar and a silly name - sigh JUG Trento, 11 June 2008
  • 4. 4 Overview of Ruby on Rails philosophy – evolution not revolution Convention over configuration Uses 20% Groovy and 80% Java (elegance and power) But... with Spring, Hibernate, and SiteMesh has a plugin architecture no XML (though it's there when you need it) no HQL/SQL (though they're there when you need them) no Ruby, JRuby or Rails JUG Trento, 11 June 2008
  • 5. 5 Java to Groovy – Step 1 HelloWorld.groovy public class HelloWorld { private String name; public void setName(String name) { this.name = name; } public String getName() { return name; } public String greet() { return quot;Hello quot; + name; } public static void main(String... args) { HelloWorld helloWorld = new HelloWorld(); helloWorld.setName(quot;Groovyquot;); System.out.println(helloWorld.greet()); } } JUG Trento, 11 June 2008
  • 6. 6 Java to Groovy – Step 2 HelloWorld.groovy class HelloWorld { String name String greet() { return quot;Hello quot; + name } static void main(String... args) { HelloWorld helloWorld = new HelloWorld() helloWorld.name = 'Groovy' println(helloWorld.greet()) } } JUG Trento, 11 June 2008
  • 7. 7 Java to Groovy – Step 3 HelloWorld.groovy class HelloWorld { String name String greet() { quot;Hello ${name}quot; } static void main(String... args) { println new HelloWorld(name: 'Groovy').greet() } } Plain Ordinary Groovy Objects Reduced clutter Simple constructors Adapted from: http://groovy.dzone.com/news/java-groovy-few-easy-steps JUG Trento, 11 June 2008
  • 8. 8 Java to Groovy – Check HelloWorld.class Groovy: JUGTrento>groovy HelloWorld.groovy Hello Groovy Java: JUGTrento>groovyc HelloWorld.groovy JUGTrento>java -cp %GROOVY_HOME%embeddablegroovy-all-1.5.4.jar;. HelloWorld Hello Groovy Javap: JUGTrento>javap HelloWorld Compiled from quot;HelloWorld.groovyquot; public class HelloWorld extends java.lang.Object implements groovy.lang.GroovyObject { public HelloWorld(); public java.lang.String greet(); public java.lang.String getName(); public void setName(java.lang.String); public static java.lang.Object main(java.lang.String[]); ... } JUG Trento, 11 June 2008
  • 9. 9 Groovy Closures – Step 1 ListTests.groovy import static java.lang.System.out; import static java.util.Arrays.asList; import java.util.ArrayList; import java.util.List; public class ListTests { public static void main(String... args) { List<String> names = asList(quot;Tedquot;, quot;Fredquot;, quot;Jedquot;, quot;Nedquot;); out.println(names.getClass().toString() + quot; quot; + names); List<String> shortNames = new ArrayList<String>(); for(String s : names) { if (s.length() < 4) { JUGTrento>groovy ListTests.groovy shortNames.add(s); class java.util.Arrays$ArrayList } [quot;Tedquot;, quot;Fredquot;, quot;Jedquot;, quot;Nedquot;] } 3 out.println(shortNames.size()); Ted for(String s : shortNames) { Jed out.println(s); Ned } } } JUG Trento, 11 June 2008
  • 10. 10 Groovy Closures – Step 2 ListTests.groovy class ListTests { static void main(String... args) { List<String> names = ['Ted', 'Fred', 'Jed', 'Ned'] println quot;${names.class} ${names}quot; List<String> shortNames = new ArrayList() for(String s : names) { if (s.length() < 4) { shortNames << s } } println shortNames.size() shortNames.each { println it } } } JUG Trento, 11 June 2008
  • 11. 11 Groovy Closures – Step 3 ListTests.groovy List<String> names = ['Ted', 'Fred', 'Jed', 'Ned'] println quot;${names.class} ${names}quot; List<String> shortNames = names.findAll { it.length() < 4 } println shortNames.size() shortNames.each { println it } JUGTrento>groovy ListTests.groovy class java.util.ArrayList [quot;Tedquot;, quot;Fredquot;, quot;Jedquot;, quot;Nedquot;] 3 Ted Jed Ned Idiomatic Groovy Reduced clutter Simple concise syntax Adapted from: http://groovy.dzone.com/news/java-groovy-part-2-closures-an JUG Trento, 11 June 2008
  • 12. 12 Meta Object Protocol - MOP Introspection: MyClass.metaClass.methods.each { println it.name } MyClass.metaClass.properties.each { println it.name } MyClass.metaClass.respondsTo(obj, 'execute') MyClass.metaClass.hasProperty(obj, 'status') Dynamic method invocation: obj.quot;$namequot;() Dynamic property getters and setters: Object value = obj.quot;$namequot; obj.quot;$namequot; = value JUG Trento, 11 June 2008
  • 13. 13 Meta Object Protocol - MOP Intercepting (Aspect Oriented Programming) def invokeMethod = { String name, args -> println quot;$name invokedquot; } def getProperty = { String name -> println quot;getting $namequot; } def setProperty = { String name, value -> println quot;setting $namequot; } Changing behaviour at run time: def methodMissing = { String name, args -> quot;No $name methodquot; } def propertyMissing = { String name -> quot;No $name propertyquot; } Duck.metaClass.quack = { quot;Quack!quot; } // duck.quack() Duck.metaClass.getSpecies = { -> quot;Canardquot; } // duck.species JUG Trento, 11 June 2008
  • 14. 14 Domain Specific Language: AntBuilder AntBuilder ant = new AntBuilder() String myDir = 'target/AntTest/' ant.sequential { echo('inside sequential') mkdir(dir: myDir) copy(todir: myDir) { fileset(dir: 'src/test') { include(name: '**/*.groovy') } } echo('done') } File file = new File('target/AntTest/groovy/util/AntTest.groovy') assert file.exists() // yes it does Adapted from: http://groovy.codehaus.org/Using+Ant+from+Groovy Gant – Groovy, Ant, but no XML: http://gant.codehaus.org/ JUG Trento, 11 June 2008
  • 15. 15 Domain Specific Language: MarkupBuilder Groovy snippet: MarkupBuilder xml = new MarkupBuilder(writer) xml.'rec:records'('xmlns:rec':'http://groovy.codehaus.org') { car(name:'HSV Maloo', make:'Holden', year:2006) { country('Australia') record(type:'speed', ' Truck with speed of 271kph') } } Output snippet: <rec:records xmlns:rec='http://groovy.codehaus.org'> <car name='HSV Maloo' make='Holden' year='2006'> <country>Australia</country> <record type='speed'> Truck with speed of 271kph</record> </car> </rec:records> Adapted from: http://groovy.codehaus.org/Creating+XML+using+Groovy's+MarkupBuilder JUG Trento, 11 June 2008
  • 16. 16 But Wait, there's More! Ranges – 0..9, 0.<10 Curried closures Regular expression syntax sugar - /d+/ Extended switch operator – switch(title) { case 'Groovy': ... Operator overloading – list << item Elvis operator – value = value ?: defaultValue; Safe dereferencing - person?.parents?.grandParents The Expando class – saves writing a 'real' class Unit testing, the Groovy Mock Library SwingBuilder Joint compiler (compile Groovy and Java source code together) ... But we don't have time for all that now JUG Trento, 11 June 2008
  • 17. 17 Groovy – the Good News Past the version 1.0 barrier (2 Jan 2007) IDE support is maturing (Eclipse, NetBeans, and IntelliJ IDEA) Being used in industry Currently around 30th place according to TIOBE (http://www.tiobe.com) G2One Inc., support from the Lead developer (Guillaume Laforge) IBM Project Zero “Drill down” to Java when you need the speed JUG Trento, 11 June 2008
  • 18. 18 Groovy – the Bad News IDE support is still maturing Slow execution speed (but not s-l-o-w) Idiomatic Groovy is not Java Won't get you a Job JUG Trento, 11 June 2008
  • 19. 19 Groovy – the Fear, Uncertainty, and Doubt Interpreted language – no, compiled to Java bytecode Not a standard – no, JSR 241 Orphan project – no Sun, Oracle, IBM, IntelliJ support Usurping Java – no, augmenting Java No Groovy programmers – no, most Java programmers should understand it JUG Trento, 11 June 2008
  • 20. 20 Pragmatic Groovy Start in places where execution speed is less important: Build scripts – AntBuilder, Gant Unit testing, and mocking Swing User Interfaces – SwingBuilder Domain Specific Languages JUG Trento, 11 June 2008
  • 21. 21 Grails – What's in the Box? Generators Predefined application layout (folders) Model View Controller pattern - surprise! GORM – Hibernate made easy Spring and Spring MVC under the covers SiteMesh powering the views Groovy Server Pages (GSP) Tag Libraries but no XML Plug-in architecture Testing – unit, integration, web Excellent, concise documentation JUG Trento, 11 June 2008
  • 22. 22 Generators grails create-app Creates (and populates) the application directories grails create-domain-class Creates an empty domain (model) class grails create-service Creates a transactional business logic class grails create-tag-lib Creates an empty tag library class grails create-unit-test Creates a unit test class grails generate-controller Generates a CRUD controller class for a domain class grails generate-views Generates the four CRUD views for a domain class grails run-app Runs the web application in Jetty grails test-app Runs the unit tests grails console Runs the Grails Swing interactive console grails shell Runs the Grails interactive shell grails war Creates a war file for JEE deployment Run grails create-app, then grails run-app, and you've got an (empty) running web application, in less than 30 seconds You'll still have to write some code yourself JUG Trento, 11 June 2008
  • 23. 23 Domain Models class Album { class Picture { User user User user String caption Album album String description POGO Set images Set pictures String file String caption Associations static belongsTo = User static belongsTo = [ User, Album ] static hasMany = [ pictures:Picture ] static hasMany = [ images:Image ] static constraints = { Validation Transient properties caption(size:1..40, blank:false) static transients = [ 'file' ] } Object Relational Mapping static mapping = { static mapping = { pictures cascade:'all', inverse:true images cascade:'all', inverse:true description type:'text' } user index:'user_idx', unique:false } } } JUG Trento, 11 June 2008
  • 24. 24 Views views/layouts/main.gsp <!DOCTYPE html ... > <html xmlns=quot;http://www.w3.org/1999/xhtmlquot;> <head> <title><g:layoutTitle default=quot;WebAlbumquot; /></title> <link rel=quot;stylesheetquot; type=quot;text/cssquot; href=quot;${createLinkTo(dir:'css', file:'main.css')}quot;/> <g:layoutHead /> </head> <body> <div class='title'>WebAlbum</div> <div class='content'> <g:layoutBody /> </div> </body> </html> JUG Trento, 11 June 2008
  • 25. 25 Views <html> <head> <meta name=quot;layoutquot; content=quot;mainquot; /> views/picture/create.gsp <title>WebAlbum : Create Picture</title> <g:layoutTitle /> <script type=quot;text/javascriptquot;> ... </script> </head> <g:layoutHead /> <body> <h1>Create Picture</h1> <g:layoutBody /> <g:uploadForm action=quot;savequot;> ... <td valign=quot;topquot; class=quot;namequot;> <label for=quot;captionquot;>Caption:</label> </td> <td valign=quot;topquot; class=quot;valuequot;> <input type=quot;textquot; size=quot;40quot; maxlength=quot;40quot; id=quot;captionquot; name=quot;captionquot; value=quot;${fieldValue(bean: picture, field: 'caption')}quot;/> </td> ... </g:uploadForm> domain/Picture.groovy </body> </html> JUG Trento, 11 June 2008
  • 26. 26 Controllers class PictureController { def list = { [list:Picture.list(params), paginateCount:Picture.count()] } def show = { Picture picture = Picture.get(params.id) if (!picture) { flash.message = quot;Picture not foundquot; redirect(action:list) } else { return [picture:picture] } } ... } JUG Trento, 11 June 2008
  • 27. 27 Controllers class PictureController { def beforeInterceptor = [ action:this.&intercept, only:['create']] def create = { ... } def intercept() { User user = sessionUser() if (!user || user.albumsCount == 0) { flash.warning = quot;You must create an album first!quot; redirect(controller: 'album', action: 'create') return false } true } } JUG Trento, 11 June 2008
  • 28. 28 Tag Libraries views/picture/show.gsp ... <tr class=quot;propquot;> <td valign=quot;topquot; class=quot;namequot;>Caption:</td> <td valign=quot;topquot; class=quot;valuequot;> <wa:pictureAnchor picture=quot;${picture}quot; size=quot;${Image.Original}quot;> ${picture.caption ?: '...'} </wa:pictureAnchor> </td> </tr> ... JUG Trento, 11 June 2008
  • 29. 29 Tag Libraries class WebAlbumTagLib { taglib/WebAlbumTagLib.groovy static namespace = quot;waquot; def pictureAnchor = { attrs, body -> Picture picture = attrs.remove('picture') def size = attrs.remove('size') String link = createPictureLink(picture.id, size).encodeAsHTML() out << quot;<a href=quot;${link}quot;quot; attrs.each { key, value -> out << quot; $key=quot;$valuequot;quot; } out << '>' out << body() out << '</a>' } ... } JUG Trento, 11 June 2008
  • 30. 30 But Wait, there's More! Filters – conf/WebAlbumFilter.groovy Create Gant scripts – scripts/CompileSources.groovy GORM many-to-many, composition, inheritance, eager fetching, ... GORM dynamic finders – findByFirstNameAndLastName(...) GORM transactions – User.withTransaction { status -> ... } Controller chaining Shared templates URL mappings - quot;/salequot;(controller:'product', action:'sale') Multiple request conversations – Web Flow Ajax support – Prototype, Dojo, Yahoo UI, GWT Content negotiation Web Services – REST and SOAP ... But we don't have time for all that now JUG Trento, 11 June 2008
  • 31. 31 Grails – the Good News Past the version 1.0 barrier (4 Feb 2008) IDE support is maturing (Eclipse, NetBeans, and IntelliJ IDEA) Being used in industry G2One Inc., support from the Lead developer (Graeme Rocher) “Drill down” to Java when you need to JUG Trento, 11 June 2008
  • 32. 32 Grails – the Bad News IDE support is still maturing Slow execution speed (but not s-l-o-w) Won't get you a Job JUG Trento, 11 June 2008
  • 33. 33 Grails – the Fear, Uncertainty, and Doubt Another Rails clone – no, uses the philosophy in a Groovy/Java way Built with an interpreted language (Groovy) – no, 20% Groovy which compiles to bytecode anyway No Grails programmers – no, see no Groovy programmers Only good for CRUD applications – no, you can do any full stack JEE application, SOAP and REST included Much slower than JEE – no, Sun engineers results showed JEE to be 2 to 4 times faster with 100 to 500 concurrent users http://developers.sun.com/learning/javaoneonline/j1sessn.jsp?sessn=TS-9535&yr=2007&track=9 JUG Trento, 11 June 2008
  • 34. 34 Pragmatic Grails Start in places where execution speed is less important: In-house web applications “Long tail” applications (10 – 50 concurrent users) Prototyping a JEE web application JUG Trento, 11 June 2008
  • 35. 35 What's Next? Groovy: http://groovy.codehaus.org/ Grails: http://grails.org/ About Groovy: http://aboutgroovy.com/ Groovy Zone: http://groovy.dzone.com/ InfoQ Groovy: http://www.infoq.com/groovy InfoQ Grails: http://www.infoq.com/grails Graeme Rocher's blog: http://graemerocher.blogspot.com/ Guillaume Laforge's blog: http://glaforge.free.fr/weblog/ G2One Inc.: http://www.g2one.com/index.html JUG Trento, 11 June 2008
  • 36. 36 Read the Books, Watch the Movies Books: Groovy Recipes: http://pragprog.com/titles/sdgrvr Programming Groovy: http://pragprog.com/titles/vslg Groovy in Action: http://www.manning.com/koenig/ The Definitive Guide to Grails: http://www.apress.com/book/view/1590597583 Films: Grails eXchange 2007: http://grails-exchange.com/ JUG Trento, 11 June 2008
  • 37. 37 Thank You, any Questions? Syger: http://www.syger.it/ Grails WebAlbum: http://www.syger.it/Tutorials/GrailsWebAlbum.html Ruby on Rails WebAlbum (a comparison, written first): http://www.syger.it/Tutorials/RubyOnRailsWebAlbum.html My personal site: http://www.jhl.it/ Contact: john.leach@syger.it JUG Trento, 11 June 2008