From 8e91d7926d86c88fd1074ebd6e7ababe1b46007b Mon Sep 17 00:00:00 2001 From: ze97286 Date: Mon, 20 May 2024 13:12:08 +0100 Subject: [PATCH] fix: Handle properly asset decimals < market decimals when uncrossing the order book upon leaving auction --- CHANGELOG.md | 1 + core/matching/orderbook.go | 4 ++-- 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 9f1837179c3..145f5495417 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -25,6 +25,7 @@ - [11279](https://github.com/vegaprotocol/vega/issues/11279) - Handle properly the case of multiple transfers for the same game id. - [11293](https://github.com/vegaprotocol/vega/issues/11293) - Panic in data node with position estimate endpoint. - [11279](https://github.com/vegaprotocol/vega/issues/11279) - Handle properly the case of multiple transfers for the same game id. +- [11297](https://github.com/vegaprotocol/vega/issues/11297) - Handle properly asset decimals < market decimals when uncrossing the order book upon leaving auction. ## 0.76.1 diff --git a/core/matching/orderbook.go b/core/matching/orderbook.go index 660e9f37ce4..ede29b8a892 100644 --- a/core/matching/orderbook.go +++ b/core/matching/orderbook.go @@ -567,8 +567,8 @@ func (b *OrderBook) uncrossBookSide( } // get price factor, if price is 10,000, but market price is 100, this is 10,000/100 -> 100 // so we can get the market price simply by doing price / (order.Price/ order.OriginalPrice) - mPrice := num.UintZero().Div(uncrossOrders[0].Price, uncrossOrders[0].OriginalPrice) - mPrice.Div(price, mPrice) + // as the asset decimals may be < market decimals, the calculation must be done in decimals. + mPrice, _ := num.UintFromDecimal(price.ToDecimal().Div(uncrossOrders[0].Price.ToDecimal().Div(uncrossOrders[0].OriginalPrice.ToDecimal()))) // Uncross each one for _, order := range uncrossOrders { // since all of uncrossOrders will be traded away and at the same uncrossing price