If we define our own DSL or use dynamically added methods or properties we can use GroovyDSL to enable code completion in our project. Normally IntelliJ IDEA doesn't know about a DSL or dynamically added properties and methods, but we can describe them in GroovyDSL. GroovyDSL is a small framework we use to describe new behaviour of Groovy scripts. In an earlier post we saw how can use Dynamic properties to get a similar effect.
In this post we write a GroovyDSL script to enable code completion for Groovlets' implicit variables, like request
, repsonse
and application
. We start by creating a new Groovy script in our project. We right-click on the src
node and select Groovy script from the popup menu. We get a dialog window where we fill in the name of our script, groovletTransform, and change the Kind to GroovyDSL script:

We click the OK button and IntelliJ IDEA adds the file groovletTransform.gdsl
to our project. We use the following code to define the DSL:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | // Create context for Groovy script files which names end with groovlet. def groovletContext = context(filetypes: [ 'groovlet' ], scope: scriptScope()) contributor(groovletContext) { property name: 'request' , type: 'javax.servlet.http.HttpServletRequest' property name: 'response' , type: 'javax.servlet.http.HttpServletResponse' property name: 'session' , type: 'javax.servlet.http.HttpSession' property name: 'application' , type: 'javax.servlet.ServletContext' property name: 'context' , type: 'javax.servlet.ServletContext' property name: 'params' , type: 'java.util.LinkedHashMap' property name: 'headers' , type: 'java.util.LinkedHashMap' property name: 'html' , type: 'groovy.xml.MarkupBuilder' property name: 'out' , type: 'java.io.PrintWriter' property name: 'sout' , type: 'javax.servlet.ServletOutputStream' method name: 'forward' , type: 'void' , params: [path: 'java.lang.String' ] method name: 'include' , type: 'void' , params: [path: 'java.lang.String' ] method name: 'redirect' , type: 'void' , params: [path: 'java.lang.String' ] } |
At the top of our editor window we get the following message: DSL descriptor file has been changed and isn't currently executed. Click to activate it back. We click on this message and a popup menu with the action Activate appears:

We select Activate and now the rules in our DSL are active for our project. So we can create a new Groovy script with the extension groovlet
and in the editor we get code completion for the variables and methods that are available for Groovlets:


It takes some extra effort, but especially when we define our own DSL or on a large project adding code completion for dynamic properties and methods can save a lot of time (and errors) in the long run.