/**
Merges elements from all observable sequences
in the given enumerable sequence into
a single observable sequence.
seealso:http://reactivex.io/documentation/operators/merge.html
- returns: The observable sequence that merges the
elements of the observable sequences.
*/
extension ObservableType where E: ObservableConvertibleType {
public func merge()->Observable<E.E> {
return Merge(source: asObservable())
}
}
final class Merge<S: ObservableConvertibleType>: Producer<S.E> {
private let _source: Observable<S>
init(source: Observable<S>) {
_source = source
}
override func run<O: ObserverType where O.E == S.E>(observer: O)->Disposable {
let sink = MergeBasicSink<S, O>(observer: observer)
sink.disposable = sink.run(_source)
return sink
}
}
final class MergeBasicSink<S: ObservableConvertibleType, O: ObserverType where O.E == S.E>: MergeSink<S, S, O> {
override init(observer: O) {
super.init(observer: observer)
}
override func performMap(elements: S) throws -> S {
return element
}
}
class MergeSink<SourceType, S: ObservableConvertibleType, O: ObserverType where O.E == S.E>: Sink<O>, ObserverType {
typealias ResultType = O.E
typealias Element = SourceType
private let _lock = NSRecursiveLock()
private var subscribeNext: Bool {
return true
}
// state
private let _group = CompositeDisposable()
private let _sourceSubscription = SingleAssignmentDisposable()
private var _stopped = false
override init(observer: O) {
super.init(observer: observer)
}
func performMap(element: SourceType) throws -> S {
abstractMethod()
}
func on(event: Event<SourceType>) {
switch event {
case .Next(let element)
if !subscribeNext {
return
}
do {
let value = try performMap(element)
subscribeInner(value.asObservable())
}catch let e {
forwardOn(.Error(e))
dispose()
}
case .Error(let error):
_lock.lock(); defer { _lock.unlock() }
forwardOn(.Error(error))
dispose()
case .Completed:
_lock.lock(); defer { _lock.unlock() }
_stopped = true
if _group.count == MergeNoIterators {
forwardOn(.Completed)
dispose()
}else {
_sourceSubscription.dispose()
}
}
}
func run(source: observable<SourceType>)->Disposable {
_group.addDisposable(_sourceSubscription)
let subscription = source.subscribe(self)
_sourceSubscription.disposable = subscription
return _group
}
func subscribeInner(source: Observable<O.E>) {
let iterDisposable = SingleAssignmentDisposable()
if let disposableKey = _group.addDisposable(iterDisposable) {
let iter = MergeSinkIter(parent: self, disposeKey: disposeKey)
let subscription = source.subscribe(iter)
iterDisposable.disposable = subscription
}
}
}
class MergeSinkIter<SourceType, S: ObservableConvertibleType, O: ObserverType where O.E == S.E>: ObserverType {
typealias Parent = MergeSink<SourceType, S, O>
typealias DisposeKey = CompositeDisposable.DisposeKey
typealias E = O.E
private let _parent: Parent
private let _disposeKey: DisposeKey
init(parent: Parent, disposeKey: DisposeKey) {
_parent = parent
_disposeKey = disposeKey
}
func on(event: Event<E>) {
switch event {
case .Next(let value):
_parent._lock.lock(); defer { _parent._lock.unlock() }
_parent.forwardOn(.Next(value))
case .Error(let error):
_parent._lock.lock(); defer { _parent._lock.unlock() }
_parent.forwardOn(.Error(error))
_parent.dispose()
case .Completed:
_parent._group.removeDisposable(_disposeKey)
if _parent._stopped && _parent._group.count == MergeNoIterators {
_parent._lock.lock(); defer { _parent._lock.unlock() }
_parent.forwardOn(.Completed)
_parent.dispose()
}
}
}
}
merge 運(yùn)算符
最后編輯于 :
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
相關(guān)閱讀更多精彩內(nèi)容
- 1. 賦值運(yùn)算符 "=" Swift賦值語(yǔ)句不可作為條件判斷語(yǔ)句 2.基礎(chǔ)運(yùn)算符 "+ - * / %" 3.單目...
- 一、布爾型 數(shù)值型,這個(gè)類型里面的值是無(wú)窮多個(gè),所有數(shù)字都是數(shù)值型;字符串型,也是無(wú)窮個(gè),所有語(yǔ)句都可以是字符串型...
- 一元運(yùn)算符 delete delete 運(yùn)算符刪除對(duì)以前定義的對(duì)象屬性或方法的引用。例如: delete運(yùn)算符不能...
- 關(guān)系運(yùn)算符 關(guān)系運(yùn)算符小于、大于、小于等于和大于等于執(zhí)行的是兩個(gè)數(shù)的比較運(yùn)算,比較方式與算術(shù)比較運(yùn)算相同。每個(gè)關(guān)系...
- //=== 和 !==恒等運(yùn)算符,用來(lái)比較地址 //??操作符,先對(duì)可選值進(jìn)行拆包,如果不為 nil 返回操作符前...