[
https://issues.apache.org/jira/browse/GROOVY-9971?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17302644#comment-17302644
]
mgroovy commented on GROOVY-9971:
---------------------------------
* @broader picture: Absolutely :)
* @to-String operator: Yes, a one-char operator like # .
** Alas toString is such a bulky method name, and the alternatives
(cast/coerce) are on the same level of noisy
** If one has e.g.
{code:java}
String s = "x=$x" // GString autoconverted toString
List<String> list = [ "abc", "c0=$c0", NV(x) ] // no toString autoconversion
takes place
{code}
one way to get the desired List that actually contains String|s is of course:
{code:java}
List<String> list = [ "abc", "c0=$c0", NV(x) ].collect { it.toString() } // or
.*toString, but IntelliJ is alas not good friends with this notation
{code}
but it would be much nicer if we could do
{code:java}
List<String> list = #[ "abc", "c0=$c0", NV(x) ] // = [ "abc".toString(),
"c0=$c0".toString(), NV(x).toString() ]
{code}
Or for a Closure
{code:java}
Closure<String> cls = { x -> x == 0 ? "zero" : #"x=$x" }
{code}
> @TypeChecked: Closure<String> no longer compatible with Closure<GString>
> argument
> ---------------------------------------------------------------------------------
>
> Key: GROOVY-9971
> URL: https://issues.apache.org/jira/browse/GROOVY-9971
> Project: Groovy
> Issue Type: Bug
> Components: Compiler
> Affects Versions: 3.0.7
> Environment: Windows 10
> jdk-11.0.10.9-hotspot
> IntelliJ 2020.3.2
> Reporter: mgroovy
> Priority: Major
>
> *Problem*
> A Closure<String> is in Groovy 3 no longer compatible with a closure that
> returns a GString (or String|GString), even though GString is autoconverted
> to String in Groovy.
> *Expected*
> A Closure returning a GString or a String|GString should be compatible with
> Closure<String>
> *Sample Code*
> {code:java}
> import groovy.transform.TypeChecked
> import org.junit.Ignore
> import org.junit.Test
> @TypeChecked
> class Groovy3_ClosureOfString_GString_Compatible {
> @Test @Ignore
> void 'Groovy 3-0-7 Closure with String return type not compatible with
> GString argument'() {
> final x = 123
> // Cannot find matching method
> execStringCls(Closure<groovy.lang.GString>)
> assert execStringCls { "x=$x" } == 'x=123'
> //assert execStringCls { "x=$x".toString() } == 'x=123' //
> works
> }
> @Test @Ignore
> void 'Groovy 3-0-7 Closure with String return type not compatible with
> GString argument 2'() {
> final x = 123
> // Cannot find matching method
> execStringCls(Closure<java.io.Serializable>)
> assert execStringCls { false ? 'abc' : "x=$x" } == 'x=123'
> //assert execStringCls { true ? 'abc' : "x=$x".toString() } ==
> 'x=123' // works
> }
> String execStringCls(Closure<String> cls) {
> cls()
> }
> }
> {code}
--
This message was sent by Atlassian Jira
(v8.3.4#803005)