169 похожих чатов

Всем привет. Подскажите, как можно разрешить такую ситуацию. У меня есть

функция, назовём её getFlow, которая возвращает Flow в зависимости от переданного в него условия, пусть это будет некий enum.

private fun getFlow(type: Type): Flow<Int> {
return when (type) {
FIRST_TYPE -> repo1.reloadFirstType()
SECOND_TYPE -> repo2.reloadSecondType()
THIRD_TYPE -> repo3.reloadThirdType()
}
}

В этой функции из разных репозиториев получаются Flow: это запросы в сеть, которые делаются постранично, результаты обрабатываются в репозиториях, а наружу — просто отдаётся процент выполнения.

В эту функцию в самом начале я передаю FIRST_TYPE, а потом мне нужно после условия, что число = 100, вызвать getFlow со следующим типом.

Дело в том, что у меня одна подписка на Flow
var progressFlow = getFlow(FIRST_TYPE)

Вопрос: как можно сделать в данном случае переход от первого Flow ко второму?

5 ответов

4 просмотра

Порядок заранее известен? FIRST_TYPE -> SECOND_TYPE -> THIRD_TYPE?

Aleksandr-Gorshkov Автор вопроса
Ivan[UTC +8, msk +5] Erofeev
Порядок заранее известен? FIRST_TYPE -> SECOND_TYP...

Да, порядок я могу определить. И мне важно, чтобы этот порядок сохранялся

Aleksandr Gorshkov
Да, порядок я могу определить. И мне важно, чтобы ...

Мне кажется тебе нужно что-то вроде этого: val progressFlow = arrayOf(FIRST_TYPE, SECOND_TYPE, THIRD_TYPE) .asFlow() .flatMapConcat { type -> getFlow(type) .filter { it == 100 } }

Ivan[UTC +8, msk +5] Erofeev
Мне кажется тебе нужно что-то вроде этого: val pro...

Только по дороге надо ещё вставить, похоже, dropWhile, на случай, если надо начать, к примеру, со второго типа.

Aleksandr-Gorshkov Автор вопроса

Похожие вопросы

Обсуждают сегодня

Вопрос по диагностике ошибок (я знаю в чем, в данном конкретном примере, я знаю, как исправить, пример модельный, понятно, что в реальности бывает намного запутаннее). module...
ⰄⰎⰋⰐⰐⰑⰛⰤⰧⰧⰩⰄ ⰊⰑⰁⰓⰡⰛⰦⰕⰫ
10
А чем вам питонисты не угодили?😂
.
79
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
48
Есть предложения, как подобное можно упростить?
Hemul GM
12
type TObj = object procedure Init; virtual; end; TObj1 = object(TObj) procedure Init; override; end; procedure TObj1.Init; begin inherited; end; procedur...
Alexander 👋
29
У меня вопросик назрел. Почему, создав класс без наследования и реализации деструктора Destroy, деструктор не вызывался при free. Потом указал наследование от tobject и overri...
Сергей Бычков
9
Такой вопросец - есть функция function MySuperDuperConcat(const a: array of AnsiString): AnsiString; Как мне в её теле сделать вот так? Result:=Concat(a); А не грустный вариан...
notme
15
just use free version ?? pycharm has a free version
Fan / Ac
9
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
86
Привет, не могли бы подсказать почему "A tree falls in a forest" не отображается в journalctl? openlog ("exampleprog", LOG_CONS | LOG_PID | LOG_NDELAY, LOG_LOCAL1); syslog (LO...
•_• Asmanov 🎓
3
Карта сайта