A lot of the comments for duck typing don’t really substantiate the claims. Not “having to worry” about a type is not sustainable for maintenance or making an application extendable. I’ve really had a good opportunity to see Grails in action over my last contract and its quite funny to watch really. Everyone is happy about the gains in being able to “create-app” and get going – sadly it all catches up to you on the back end.
Groovy seems the same way to me. Sure you can write very succinct code and definitely there is some nice sugar in how we get to work with properties, collections, etc… But the cost of not knowing what the heck is being passed back and forth just gets worse and worse. At some point your scratching your head wondering why the project has become 80% testing and 20% work. The lesson here is that “smaller” does not make for “more readable” code. Sorry folks, its simple logic – the more you have to know intuitively then the more complex the process of understanding that code becomes. It’s why GUI’s have backed off becoming overly iconic over the years – sure looks pretty but WTH is going on is not always obvious.
People on that project seemed to have troubles “nailing down” the lessons learned, but when you have methods returning either a single element of type T, an array of T, an ErrorResult or a null … it becomes rather apparent.
One thing working with Groovy has done for me however – awesome billable hours woot!