blob: dafdbeeaa133bbb5a24d9883362c02f81248522e [file] [log] [blame]
//////////////////////////////////////////
Licensed to the Apache Software Foundation (ASF) under one
or more contributor license agreements. See the NOTICE file
distributed with this work for additional information
regarding copyright ownership. The ASF licenses this file
to you under the Apache License, Version 2.0 (the
"License"); you may not use this file except in compliance
with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing,
software distributed under the License is distributed on an
"AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
KIND, either express or implied. See the License for the
specific language governing permissions and limitations
under the License.
//////////////////////////////////////////
= Getting started
== Download
In this download area, you will be able to download the distribution (binary and source), the Windows installer and the documentation for **Groovy**.
For a quick and effortless start on Mac OSX, Linux or Cygwin, you can use http://sdkman.io/[SDKMAN!] (The Software Development Kit Manager) to download and configure any **Groovy** version of your choice. Basic <<SDKMAN,instructions>> can be found below.
=== Stable
- **Download zip**: https://bintray.com/artifact/download/groovy/maven/apache-groovy-binary-{groovy-full-version}.zip[**Binary Release**] | https://bintray.com/artifact/download/groovy/maven/groovy-src-{groovy-full-version}.zip[Source Release]
- **Download documentation**: https://bintray.com/artifact/download/groovy/maven/apache-groovy-docs-{groovy-full-version}.zip[**JavaDoc and zipped online documentation**]
- **Combined binary / source / documentation bundle**: https://bintray.com/artifact/download/groovy/maven/apache-groovy-sdk-{groovy-full-version}.zip[**Distribution bundle**]
You can learn more about this version in the http://groovy-lang.org/releasenotes/groovy-{groovy-short-version}.html[release notes] or in the http://groovy-lang.org/changelogs/changelog-{groovy-full-version}.html[changelog].
If you plan on using invokedynamic support, link:invokedynamic-support.html[read those notes].
=== Snapshots
For those who want to test the very latest versions of Groovy and live on the bleeding edge, you can use our https://oss.jfrog.org/oss-snapshot-local/org/codehaus/groovy[snapshot builds]. As soon as a build succeeds on our continuous integration server a snapshot is deployed to Artifactory's OSS snapshot repository.
=== Prerequisites
Groovy {groovy-short-version} requires Java 6+ with full support up to Java 8.
There are currently some known issues for some aspects when using Java 9 snapshots.
The `groovy-nio` module requires Java 7+.
Using Groovy's invokeDynamic features require Java 7+ but we recommend Java 8.
The Groovy CI server is also useful to look at to confirm supported Java versions for different Groovy releases.
The test suite (getting close to 10000 tests) runs for the currently supported streams of Groovy across
all the main versions of Java each stream supports.
== Maven Repository
If you wish to embed Groovy in your application, you may just prefer to point to your favourite maven repositories or the https://oss.jfrog.org/oss-release-local/org/codehaus/groovy[JCenter maven repository].
=== Stable Release
[cols="1,1,2" options="header"]
|===
|Gradle
|Maven
|Explanation
|&#39;org.codehaus.groovy:groovy:{groovy-full-version}'
|<groupId>org.codehaus.groovy</groupId> +
<artifactId>groovy</artifactId> +
<version>{groovy-full-version}</version>
|Just the core of groovy without the modules (see below).
|&#39;org.codehaus.groovy:groovy-$module:{groovy-full-version}'
|<groupId>org.codehaus.groovy</groupId> +
<artifactId>groovy-$module</artifactId> +
<version>{groovy-full-version}</version>
|"$module" stands for the different optional groovy modules "ant", "bsf", "console", "docgenerator", "groovydoc", "groovysh", "jmx", "json", "jsr223", "servlet", "sql", "swing", "test", "testng" and "xml". Example: <artifactId>groovy-sql</artifactId>
|&#39;org.codehaus.groovy:groovy-all:{groovy-full-version}'
|<groupId>org.codehaus.groovy</groupId> +
<artifactId>groovy-all</artifactId> +
<version>{groovy-full-version}</version> +
<type>pom</type> <!-- required JUST since Groovy 2.5.0 +-->+
|The core plus all the modules. Optional dependencies are marked as optional. You may need to include some of the optional dependencies to use some features of Groovy, e.g. AntBuilder, GroovyMBeans, etc.
|===
To use the link:invokedynamic-support.html[InvokeDynamic] version of the jars just append &#39;:indy' for Gradle or <classifier>indy</classifier> for Maven.
[[SDKMAN]]
== SDKMAN! (The Software Development Kit Manager)
This tool makes installing Groovy on any Bash platform (Mac OSX, Linux, Cygwin, Solaris or FreeBSD) very easy.
Simply open a new terminal and enter:
[source,shell]
----
$ curl -s get.sdkman.io | bash
----
Follow the instructions on-screen to complete installation.
Open a new terminal or type the command:
[source,shell]
----
$ source "$HOME/.sdkman/bin/sdkman-init.sh"
----
Then install the latest stable Groovy:
[source,shell]
----
$ sdk install groovy
----
After installation is complete and you've made it your default version, test it with:
[source,shell]
----
$ groovy -version
----
That's all there is to it!
== Other ways to get Groovy
=== Installation on Mac OS X
==== MacPorts
If you're on MacOS and have http://www.macports.org[MacPorts] installed, you can run:
[source,shell]
----
sudo port install groovy
----
==== Homebrew
If you're on MacOS and have http://mxcl.github.com/homebrew[Homebrew] installed, you can run:
[source,shell]
----
brew install groovy
----
=== Installation on Windows
If you're on Windows, you can also use the https://bintray.com/groovy/Distributions/Windows-Installer[NSIS Windows installer].
=== Other Distributions
You may download other distributions of Groovy from https://bintray.com/groovy/maven[this site].
=== Source Code
If you prefer to live on the bleeding edge, you can also grab the https://github.com/apache/groovy[source code from GitHub].
=== IDE plugin
If you are an IDE user, you can just grab the latest link:tools-ide.html[IDE plugin] and follow the plugin installation instructions.
== Install Binary
These instructions describe how to install a binary distribution of **Groovy**.
* First, <<download-groovy,Download>> a binary distribution of Groovy and unpack it into some file on your local file system.
* Set your `GROOVY_HOME` environment variable to the directory you unpacked the distribution.
* Add `GROOVY_HOME/bin` to your `PATH` environment variable.
* Set your `JAVA_HOME` environment variable to point to your JDK. On OS X this is `/Library/Java/Home`, on other unixes its often `/usr/java` etc. If you've already installed tools like Ant or Maven you've probably already done this step.
You should now have Groovy installed properly. You can test this by typing the following in a command shell:
[source,shell]
----
groovysh
----
Which should create an interactive groovy shell where you can type Groovy statements. Or to run the <<{projectdir}/subprojects/groovy-console/{specfolder}/groovy-console.adoc,Swing interactive console>> type:
[source,shell]
----
groovyConsole
----
To run a specific Groovy script type:
[source,shell]
----
groovy SomeScript
----