svenjacobs
02/11/2019, 11:48 AMChannelsuspend fun Query.onSnapshotAsync(scope: CoroutineScope) =
    scope.produce {
        addSnapshotListener { snapshot ->
            send(snapshot.documents)
        }
    }send()suspension functions can be called only within coroutine bodysuspendCoroutinesvenjacobs
02/11/2019, 11:52 AMsend()scope.launch { send() }Dico
02/11/2019, 12:16 PMofferDico
02/11/2019, 12:17 PMsvenjacobs
02/11/2019, 12:17 PMDico
02/11/2019, 12:18 PMoffersvenjacobs
02/11/2019, 12:19 PMsvenjacobs
02/11/2019, 1:11 PMaddSnapshotListenerproduce {}Channel was closedoffer()bdawg.io
02/11/2019, 3:25 PMaddSnapshotListeneronSnapshotAsyncfun Query.onSnapshotAsync(scope: CoroutineScope) = scope.produce(capacity = Channel.CONFLATED) {
    addSnapshotListener { snapshot ->
        // utilizes your coroutine scope's exception handler
        // does not block your snapshot listener thread (potential bug if you move from a conflated channel)
        launch { send(snapshot.documents) }
    }
}svenjacobs
02/11/2019, 3:27 PMaddSnapshotListenerbdawg.io
02/11/2019, 3:32 PM= Channel<List<Snapshot.Document>>(capacity = Channel.CONFLATED).apply {
    // attach channel to the lifecycle of the scope (which is based on the Job, if one is attached)
    scope.coroutineContext[Job]?.invokeOnCompletion { 
        close()
    }
    addSnapshotListener { ... }
}Dico
02/11/2019, 3:34 PMsvenjacobs
02/11/2019, 3:35 PMsvenjacobs
02/11/2019, 3:36 PMDico
02/11/2019, 3:36 PMsvenjacobs
02/11/2019, 3:39 PMsvenjacobs
02/11/2019, 3:40 PMDico
02/11/2019, 3:42 PMsvenjacobs
02/11/2019, 3:42 PMbdawg.io
02/11/2019, 3:42 PMDico
02/11/2019, 3:43 PMDico
02/11/2019, 3:44 PMproducesvenjacobs
02/11/2019, 3:44 PMDico
02/11/2019, 3:44 PMDico
02/11/2019, 3:44 PMDico
02/11/2019, 3:45 PMbdawg.io
02/11/2019, 3:50 PMproduceJobChannelDico
02/11/2019, 3:57 PMsvenjacobs
02/12/2019, 6:14 AMChannelbdawg.io
02/12/2019, 2:58 PM