X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=market.py;h=41c4c9c5652d6c24629aca26d21e58797a7eb6e5;hb=f0001495538945af15ae0c28a07e4de4cc18cbf1;hp=9550b7706aa7194a6e09ab174ea0420206fd7832;hpb=5321200c05b3b693581ec4238c74eb02e0b715d7;p=perso%2FImmae%2FProjets%2FCryptomonnaies%2FCryptoportfolio%2FTrader.git diff --git a/market.py b/market.py index 9550b77..41c4c9c 100644 --- a/market.py +++ b/market.py @@ -206,8 +206,9 @@ class Market: message="{} disappeared, recreating it".format(order)) new_order = order.trade.prepare_order( compute_value=order.trade.tick_actions_recreate(tick)) - new_order.run() - self.report.log_order(order, tick, new_order=new_order) + if new_order is not None: + new_order.run() + self.report.log_order(order, tick, new_order=new_order) self.report.log_stage("follow_orders_end") @@ -220,23 +221,20 @@ class Market: compute_value=compute_value, only=only, repartition=repartition, available_balance_only=available_balance_only) - values_in_base = self.balances.in_currency(base_currency, - compute_value=compute_value) if available_balance_only: - balance = self.balances.all.get(base_currency) - if balance is None: - total_base_value = portfolio.Amount(base_currency, 0) - else: - total_base_value = balance.exchange_free + balance.margin_available + repartition, total_base_value, values_in_base = self.balances.available_balances_for_repartition( + base_currency=base_currency, liquidity=liquidity, + repartition=repartition, compute_value=compute_value) else: + values_in_base = self.balances.in_currency(base_currency, + compute_value=compute_value) total_base_value = sum(values_in_base.values()) new_repartition = self.balances.dispatch_assets(total_base_value, liquidity=liquidity, repartition=repartition) if available_balance_only: for currency, amount in values_in_base.items(): - if currency != base_currency: - new_repartition.setdefault(currency, portfolio.Amount(base_currency, 0)) - new_repartition[currency] += amount + if currency != base_currency and currency not in new_repartition: + new_repartition[currency] = amount self.trades.compute_trades(values_in_base, new_repartition, only=only)