From 07cc547881549db3bdacd2588565da3aaf7b7e6d Mon Sep 17 00:00:00 2001 From: emidev98 Date: Tue, 23 May 2023 10:32:39 +0300 Subject: [PATCH 1/3] feat: allow setting the base denom --- types/denom.go | 11 +++++++++++ types/denom_internal_test.go | 16 ++++++++++++++++ 2 files changed, 27 insertions(+) diff --git a/types/denom.go b/types/denom.go index 0b9389286bea..c87a150f5988 100644 --- a/types/denom.go +++ b/types/denom.go @@ -47,6 +47,17 @@ func GetDenomUnit(denom string) (Dec, bool) { return unit, true } +// SetBaseDenom allow overwritting the base denom +// if the denom has registered before, otherwise return error +func SetBaseDenom(denom string) error { + _, ok := denomUnits[denom] + if !ok { + return fmt.Errorf("denom %s not registered", denom) + } + baseDenom = denom + return nil +} + // GetBaseDenom returns the denom of smallest unit registered func GetBaseDenom() (string, error) { if baseDenom == "" { diff --git a/types/denom_internal_test.go b/types/denom_internal_test.go index 67227bdd4d5e..bb76d80fb9a2 100644 --- a/types/denom_internal_test.go +++ b/types/denom_internal_test.go @@ -36,6 +36,13 @@ func (s *internalDenomTestSuite) TestRegisterDenom() { s.Require().False(ok) s.Require().Equal(math.LegacyZeroDec(), res) + err := SetBaseDenom(atom) + s.Require().NoError(err) + + res, ok = GetDenomUnit(atom) + s.Require().True(ok) + s.Require().Equal(atomUnit, res) + // reset registration baseDenom = "" denomUnits = map[string]Dec{} @@ -192,3 +199,12 @@ func (s *internalDenomTestSuite) TestDecOperationOrder() { baseDenom = "" denomUnits = map[string]Dec{} } + +func (s *internalDenomTestSuite) TestSetBaseDenomError() { + err := SetBaseDenom(atom) + s.Require().Error(err) + + // reset registration + baseDenom = "" + denomUnits = map[string]Dec{} +} From 8c219aff717ec0618bec1deef9b3ed96e9403aa0 Mon Sep 17 00:00:00 2001 From: emidev98 Date: Tue, 23 May 2023 10:39:48 +0300 Subject: [PATCH 2/3] chore: update changelog --- CHANGELOG.md | 1 + 1 file changed, 1 insertion(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 7463de3e6f7e..46b8a4f742b7 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -68,6 +68,7 @@ Ref: https://keepachangelog.com/en/1.0.0/ * (tx) [#15992](https://github.com/cosmos/cosmos-sdk/pull/15992) Add `WithExtensionOptions` in tx Factory to allow `SetExtensionOptions` with given extension options. * (types/simulation) [#16074](https://github.com/cosmos/cosmos-sdk/pull/16074) Add generic SimulationStoreDecoder for modules using collections. * (cli) [#16209](https://github.com/cosmos/cosmos-sdk/pull/16209) Make `StartCmd` more customizable. +* (types) [#16257](https://github.com/cosmos/cosmos-sdk/pull/16257) Allow setting the base denom ### Improvements From fff3b0af9c78639a5311020bf4a3b6a09b0805f6 Mon Sep 17 00:00:00 2001 From: emidev98 <49301655+emidev98@users.noreply.github.com> Date: Tue, 23 May 2023 16:29:22 +0200 Subject: [PATCH 3/3] Update CHANGELOG.md Co-authored-by: Aleksandr Bezobchuk --- CHANGELOG.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 46b8a4f742b7..ab6df2173f53 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -68,7 +68,7 @@ Ref: https://keepachangelog.com/en/1.0.0/ * (tx) [#15992](https://github.com/cosmos/cosmos-sdk/pull/15992) Add `WithExtensionOptions` in tx Factory to allow `SetExtensionOptions` with given extension options. * (types/simulation) [#16074](https://github.com/cosmos/cosmos-sdk/pull/16074) Add generic SimulationStoreDecoder for modules using collections. * (cli) [#16209](https://github.com/cosmos/cosmos-sdk/pull/16209) Make `StartCmd` more customizable. -* (types) [#16257](https://github.com/cosmos/cosmos-sdk/pull/16257) Allow setting the base denom +* (types) [#16257](https://github.com/cosmos/cosmos-sdk/pull/16257) Allow setting the base denom in the denom registry. ### Improvements