You are viewing a plain text version of this content. The canonical link for it is here.
Posted to dev@flink.apache.org by "Marshall Pierce (Jira)" <ji...@apache.org> on 2020/06/12 16:34:00 UTC

[jira] [Created] (FLINK-18280) Kotlin adapters for Flink types?

Marshall Pierce created FLINK-18280:
---------------------------------------

             Summary: Kotlin adapters for Flink types?
                 Key: FLINK-18280
                 URL: https://issues.apache.org/jira/browse/FLINK-18280
             Project: Flink
          Issue Type: Wish
    Affects Versions: 1.10.1
            Reporter: Marshall Pierce


Currently, using a Kotlin lambda for, say, a {{KeySelector}} doesn't work – it needs to be an {{object}} expression for the runtime type detection to work. At my day job we have started building up a handful of wrappers, like this one for {{KeySelector}}:

{code:kotlin}
inline fun <T, K> keySelector(crossinline block: (T) -> K): KeySelector<T, K> {
    return object : KeySelector<T, K> {
        override fun getKey(value: T): K {
            return block(value)
        }
    }
}
{code}

Usage looks like: {{keySelector { it.fooId }}}. Surely not the only way to solve that problem, but it's been working smoothly for us so far.

Is there any interested in shipping these sorts of extensions as part of the Flink project so users don't need to write them? It could be a wholly separate artifact (or rather multiple artifacts, as there would probably be one for flink core, one for flink streaming, etc). 



--
This message was sent by Atlassian Jira
(v8.3.4#803005)