Groovy (programming language)

del.icio.us del.icio.us
Digg Digg
Furl Furl
Reddit Reddit
Rojo Rojo
Add to OnlyWire
Groovy
Image:Groovy groovy.png
Paradigm object-oriented, scripting
Appeared in 2003
Designed by JCP
Developer Guillaume Laforge (Project Manager and JSR-241 Spec Lead)
Latest release 1.5.6/ April 25, 2008 (2008-04-25); 136 days ago
Latest unstable release 1.6-beta-1/ May 2, 2008 (2008-05-02); 129 days ago
Typing discipline dynamic, strong, duck
Influenced by Python, Ruby, Perl, Smalltalk, Java
OS Cross platform (JVM)
License Apache License V2.0
Website http://groovy.codehaus.org

Groovy is an object-oriented programming language for the Java Platform as an alternative to the Java programming language. It is a dynamic language with features similar to those of Python, Ruby, Perl, and Smalltalk. It can be used as a scripting language for the Java Platform.

Groovy uses a Java-like curly bracket syntax which is dynamically compiled to Java Virtual Machine bytecodes and which works seamlessly with other Java code and libraries. The Groovy compiler can be used to generate standard Java bytecode to be used by any Java project. Most Java code is valid Groovy syntax and can be used dynamically as a scripting language.

Groovy is currently undergoing standardization via the Java Community Process under JSR 241. Groovy 1.0 was released on January 2, 2007.

Contents

Features

Groovy has a number of features not found in standard Java:

Syntax comparison

The following presents a side-by-side comparison of Java with Groovy:

Standard Java (Java 5+)

 for (String item : new String [] {"Rod", "Carlos", "Chris"}) {
     if (item.length() <= 4) {
         System.out.println(item);
     }
}

Groovy

 ["Rod", "Carlos", "Chris"].findAll{it.size() <= 4}.each{println it}

Mark-up language support

One noteworthy feature of Groovy is its native support for various markup languages such as XML and HTML, accomplished via an inline DOM syntax. This feature enables the definition and manipulation of many types of heterogeneous data assets with a uniform and concise syntax and programming methodology. For example:

the following Groovy code ...

    import groovy.xml.MarkupBuilder
    def myXMLDoc = new MarkupBuilder()
    myXMLDoc.workbook {
       worksheet(caption:"Employees") {
          row(fname:"John", lname:"McDoe")
          row(fname:"Nancy", lname:"Davolio")
       }
       worksheet(caption:"Products") {
          row(name:"Veeblefeetzer", id:"sku34510")
          row(name:"Prune Unit Zappa", id:"sku3a550")
       }
    }
    println myXMLDoc

... produces the XML result:

<workbook>
  <worksheet caption='Employees'>
    <row fname="John" lname="McDoe" />
    <row fname="Nancy" lname="Davolio" />
  </worksheet>
  <worksheet caption='Products'>
    <row name="Veeblefeetzer" id="sku34510" />
    <row name="Prune Unit Zappa" id="sku3a550" />
  </worksheet>
</workbook>

For the sake of comparison, Java code to produce the equivalent XML is shown below. Note that, unlike the Groovy example, each XML element and attribute is created with an explicit method call.

equivalent Java code:

import java.io.StringWriter;
 
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.transform.OutputKeys;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
 
import org.w3c.dom.Document;
import org.w3c.dom.Element;
 
public class XMLFun {
 
        public static void main(String[] args) throws Exception {
                TransformerFactory factory = TransformerFactory.newInstance();
                factory.setAttribute("indent-number", 2);
                Transformer trans = factory.newTransformer();
                trans.setOutputProperty(OutputKeys.OMIT_XML_DECLARATION, "yes");
                trans.setOutputProperty(OutputKeys.INDENT, "yes");
 
                DocumentBuilderFactory dbfac = DocumentBuilderFactory.newInstance();
                DocumentBuilder docBuilder = dbfac.newDocumentBuilder();
                Document doc = docBuilder.newDocument();
                Element workbook = doc.createElement("workbook");
                doc.appendChild(workbook);
                Element worksheet = doc.createElement("worksheet");
                worksheet.setAttribute("caption", "Employees");
                workbook.appendChild(worksheet);
                Element row = doc.createElement("row");
                row.setAttribute("fname", "John");
                row.setAttribute("lname", "McDoe");
                worksheet.appendChild(row);
                row = doc.createElement("row");
                row.setAttribute("fname", "Nancy");
                row.setAttribute("lname", "Davolio");
                worksheet.appendChild(row);
 
                worksheet = doc.createElement("worksheet");
                worksheet.setAttribute("caption", "Products");
                workbook.appendChild(worksheet);
                row = doc.createElement("row");
                row.setAttribute("name", "Veeblefeetzer");
                row.setAttribute("id", "sku34510");
                worksheet.appendChild(row);
                row = doc.createElement("row");
                row.setAttribute("name", "Prune Unit Zappa");
                row.setAttribute("id", "sku3a550");
                worksheet.appendChild(row);
 
                StringWriter writer = new StringWriter();
                StreamResult out = new StreamResult(writer);
                DOMSource dsource = new DOMSource(doc);
                trans.transform(dsource, out);
                System.out.println(writer.toString());
        }
}

History

James Strachan first talked about the development of Groovy in his blog in August 2003. Several versions were released between 2004 and 2006. After the JCP standardization process began, the version numbering was changed and a version called "1.0" was released on Tuesday, January 2, 2007. After various betas and release candidates numbered 1.1, on December 7, 2007 Groovy 1.1 Final was released and immediately rebranded as Groovy 1.5 as a reflection of the great improvement made.

Integrated Development Environment

Many IDEs support Groovy.

Eclipse

IntelliJ IDEA

There are at least two plugins, but currently developed is the one released by JetBrains, Jet Groovy Plugin[1].

  • Code completion
    • You can complete Java code and Groovy code mutually. Not only you can complete Java classes from Groovy code, but also you can complete Groovy class from Java code in real time. You can mix Java and Groovy code in a project.
  • Jump to the definition by Ctrl with mouse click.
    • As same as completion, you can move between Java code and Groovy code.
  • Debugger
  • Quick-fix for coding errors.
  • Completions for GroovyDoc.
  • Refactoring such as extracting method.
  • Support for Grails and GSP.

NetBeans

Starting from version 6.5, NetBeans supports Groovy and Grails.

See also

References

External links

Look up groovy in Wiktionary, the free dictionary.

This article is from Wikipedia. All text is available under the terms of the GNU Free Documentation License.


Giant Panda

Mercedes Car
James Bond Guide
This site monitored by SitePinger.net