[ https://issues.apache.org/jira/browse/GROOVY-7672?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=15001669#comment-15001669 ]
ASF GitHub Bot commented on GROOVY-7672: ---------------------------------------- GitHub user paulk-asert opened a pull request: https://github.com/apache/incubator-groovy/pull/187 GROOVY-7672: TupleConstructor should have only SOURCE retention policy You can merge this pull request into a Git repository by running: $ git pull https://github.com/paulk-asert/incubator-groovy groovy7672 Alternatively you can review and apply these changes as the patch at: https://github.com/apache/incubator-groovy/pull/187.patch To close this pull request, make a commit to your master/trunk branch with (at least) the following in the commit message: This closes #187 ---- commit 36d7a58f2b6ad84a6b6b8ac2bcb4bd8cc335bd0b Author: paulk <pa...@asert.com.au> Date: 2015-11-12T04:18:48Z GROOVY-7672: TupleConstructor should have only SOURCE retention policy ---- > TupleConstructor should have only SOURCE retention policy > --------------------------------------------------------- > > Key: GROOVY-7672 > URL: https://issues.apache.org/jira/browse/GROOVY-7672 > Project: Groovy > Issue Type: Bug > Affects Versions: 2.4.5 > Reporter: Paul King > Assignee: Paul King > > We originally gave TupleConstructor RUNTIME retention policy since it might > provide a small amount of introspection information for future tools. But so > far, as far as I know, it hasn't been used. Given that it makes certain > usages impossible, I propose to put back to SOURCE retention policy. This > will allow code such as shown below to be possible: > {code} > import groovy.transform.* > import java.awt.Color > class Named { > String name > } > @ToString(includeSuperProperties=true, ignoreNulls=true, includeNames=true, > includeFields=true) > @TupleConstructor(force=true, defaults=false) > @TupleConstructor(force=true, defaults=false, includeFields=true) > @TupleConstructor(force=true, defaults=false, includeSuperProperties=true) > class Cat extends Named { > int age > private Color color > } > assert new Cat("Felix", 3).toString() == 'Cat(age:3, name:Felix)' > assert new Cat(3, Color.BLACK).toString() == 'Cat(age:3, > color:java.awt.Color[r=0,g=0,b=0])' > assert new Cat(3).toString() == 'Cat(age:3)' > {code} -- This message was sent by Atlassian JIRA (v6.3.4#6332)