mirror of
https://github.com/haveno-dex/haveno.git
synced 2025-01-20 17:54:39 +00:00
fix null price feed listener
Some checks are pending
Some checks are pending
This commit is contained in:
parent
856faafd1c
commit
c01d63490f
1 changed files with 20 additions and 15 deletions
|
@ -33,7 +33,6 @@ import haveno.core.monetary.Price;
|
||||||
import haveno.core.monetary.TraditionalMoney;
|
import haveno.core.monetary.TraditionalMoney;
|
||||||
import haveno.core.provider.PriceHttpClient;
|
import haveno.core.provider.PriceHttpClient;
|
||||||
import haveno.core.provider.ProvidersRepository;
|
import haveno.core.provider.ProvidersRepository;
|
||||||
import haveno.core.trade.HavenoUtils;
|
|
||||||
import haveno.core.trade.statistics.TradeStatistics3;
|
import haveno.core.trade.statistics.TradeStatistics3;
|
||||||
import haveno.core.user.Preferences;
|
import haveno.core.user.Preferences;
|
||||||
import haveno.network.http.HttpClient;
|
import haveno.network.http.HttpClient;
|
||||||
|
@ -144,15 +143,17 @@ public class PriceFeedService {
|
||||||
public void awaitExternalPrices() {
|
public void awaitExternalPrices() {
|
||||||
CountDownLatch latch = new CountDownLatch(1);
|
CountDownLatch latch = new CountDownLatch(1);
|
||||||
ChangeListener<? super Number> listener = (observable, oldValue, newValue) -> {
|
ChangeListener<? super Number> listener = (observable, oldValue, newValue) -> {
|
||||||
if (hasExternalPrices() && latch.getCount() != 0) latch.countDown();
|
if (hasExternalPrices()) UserThread.execute(() -> latch.countDown());
|
||||||
};
|
};
|
||||||
updateCounter.addListener(listener);
|
UserThread.execute(() -> updateCounter.addListener(listener));
|
||||||
if (hasExternalPrices()) {
|
if (hasExternalPrices()) UserThread.execute(() -> latch.countDown());
|
||||||
updateCounter.removeListener(listener);
|
try {
|
||||||
return;
|
latch.await();
|
||||||
|
} catch (InterruptedException e) {
|
||||||
|
throw new RuntimeException(e);
|
||||||
|
} finally {
|
||||||
|
UserThread.execute(() -> updateCounter.removeListener(listener));
|
||||||
}
|
}
|
||||||
HavenoUtils.awaitLatch(latch);
|
|
||||||
updateCounter.removeListener(listener);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean hasExternalPrices() {
|
public boolean hasExternalPrices() {
|
||||||
|
@ -377,17 +378,21 @@ public class PriceFeedService {
|
||||||
*/
|
*/
|
||||||
public synchronized Map<String, MarketPrice> requestAllPrices() throws ExecutionException, InterruptedException, TimeoutException, CancellationException {
|
public synchronized Map<String, MarketPrice> requestAllPrices() throws ExecutionException, InterruptedException, TimeoutException, CancellationException {
|
||||||
CountDownLatch latch = new CountDownLatch(1);
|
CountDownLatch latch = new CountDownLatch(1);
|
||||||
ChangeListener<? super Number> listener = (observable, oldValue, newValue) -> { if (latch.getCount() != 0) latch.countDown(); };
|
ChangeListener<? super Number> listener = (observable, oldValue, newValue) -> latch.countDown();
|
||||||
updateCounter.addListener(listener);
|
UserThread.execute(() -> updateCounter.addListener(listener));
|
||||||
requestAllPricesError = null;
|
requestAllPricesError = null;
|
||||||
requestPrices();
|
requestPrices();
|
||||||
UserThread.runAfter(() -> {
|
UserThread.runAfter(() -> {
|
||||||
if (latch.getCount() == 0) return;
|
if (latch.getCount() > 0) requestAllPricesError = "Timeout fetching market prices within 20 seconds";
|
||||||
requestAllPricesError = "Timeout fetching market prices within 20 seconds";
|
UserThread.execute(() -> latch.countDown());
|
||||||
latch.countDown();
|
|
||||||
}, 20);
|
}, 20);
|
||||||
HavenoUtils.awaitLatch(latch);
|
try {
|
||||||
updateCounter.removeListener(listener);
|
latch.await();
|
||||||
|
} catch (InterruptedException e) {
|
||||||
|
throw new RuntimeException(e);
|
||||||
|
} finally {
|
||||||
|
UserThread.execute(() -> updateCounter.removeListener(listener));
|
||||||
|
}
|
||||||
if (requestAllPricesError != null) throw new RuntimeException(requestAllPricesError);
|
if (requestAllPricesError != null) throw new RuntimeException(requestAllPricesError);
|
||||||
return cache;
|
return cache;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue