ix
Version:
The Interactive Extensions for JavaScript
71 lines (58 loc) • 1.91 kB
text/typescript
import { IterableX } from './iterablex.js';
import { returnIterator } from '../util/returniterator.js';
/** @ignore */
export class CatchIterable<TSource> extends IterableX<TSource> {
private _source: Iterable<Iterable<TSource>>;
constructor(source: Iterable<Iterable<TSource>>) {
super();
this._source = source;
}
*[Symbol.iterator]() {
let error = null;
let hasError = false;
for (const source of this._source) {
const it = source[Symbol.iterator]();
error = null;
hasError = false;
while (1) {
let c = <TSource>{};
try {
const { done, value } = it.next();
if (done) {
returnIterator(it);
break;
}
c = value;
} catch (e) {
error = e;
hasError = true;
returnIterator(it);
break;
}
yield c;
}
if (!hasError) {
break;
}
}
if (hasError) {
throw error;
}
}
}
/**
* Creates a sequence by concatenating source sequences until a source sequence completes successfully.
* @param {Iterable<Iterable<TSource>>} source Source sequences.
* @return {Iterable<TSource>} Sequence that continues to concatenate source sequences while errors occur.
*/
export function catchAll<TSource>(source: Iterable<Iterable<TSource>>): IterableX<TSource> {
return new CatchIterable<TSource>(source);
}
/**
* Creates a sequence by concatenating source sequences until a source sequence completes successfully.
* @param {...Iterable<TSource>} source Sequence that continues to concatenate source sequences while errors occur.
* @return {Iterable<TSource>} Sequence that continues to concatenate source sequences while errors occur.
*/
export function catchError<TSource>(...source: Iterable<TSource>[]): IterableX<TSource> {
return new CatchIterable<TSource>(source);
}