[ 
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)

Reply via email to