From 7db8003e05b396dd1132e4ed4ad198771641da4c Mon Sep 17 00:00:00 2001 From: Dev Bear Date: Wed, 21 Dec 2022 18:35:25 -0500 Subject: [PATCH 1/3] interface --- types/context.go | 4 ++-- types/events.go | 14 ++++++++++++++ 2 files changed, 16 insertions(+), 2 deletions(-) diff --git a/types/context.go b/types/context.go index 6483304fed85..8b174105df18 100644 --- a/types/context.go +++ b/types/context.go @@ -37,7 +37,7 @@ type Context struct { recheckTx bool // if recheckTx == true, then checkTx must also be true minGasPrice DecCoins consParams *tmproto.ConsensusParams - eventManager *EventManager + eventManager EventManagerI priority int64 // The tx priority, only relevant in CheckTx kvGasConfig storetypes.GasConfig transientKVGasConfig storetypes.GasConfig @@ -60,7 +60,7 @@ func (c Context) BlockGasMeter() GasMeter { return c.blockGas func (c Context) IsCheckTx() bool { return c.checkTx } func (c Context) IsReCheckTx() bool { return c.recheckTx } func (c Context) MinGasPrices() DecCoins { return c.minGasPrice } -func (c Context) EventManager() *EventManager { return c.eventManager } +func (c Context) EventManager() EventManagerI { return c.eventManager } func (c Context) Priority() int64 { return c.priority } func (c Context) KVGasConfig() storetypes.GasConfig { return c.kvGasConfig } func (c Context) TransientKVGasConfig() storetypes.GasConfig { return c.transientKVGasConfig } diff --git a/types/events.go b/types/events.go index 0d8fafc02c5e..d498fd953008 100644 --- a/types/events.go +++ b/types/events.go @@ -17,10 +17,24 @@ import ( "github.com/cosmos/cosmos-sdk/codec" ) +type EventManagerI interface { + Events() Events + ABCIEvents() []abci.Event + EmitTypedEvent(tev proto.Message) error + EmitTypedEvents(tevs ...proto.Message) error + + // Deprecated: Use EmitTypedEvent + EmitEvent(event Event) + // Deprecated: Use EmitTypedEvents + EmitEvents(events Events) +} + // ---------------------------------------------------------------------------- // Event Manager // ---------------------------------------------------------------------------- +var _ EventManagerI = (*EventManager)(nil) + // EventManager implements a simple wrapper around a slice of Event objects that // can be emitted from. type EventManager struct { From 9d16b4d69c994d067cc696a7de1f757653b57ae9 Mon Sep 17 00:00:00 2001 From: Dev Bear Date: Wed, 21 Dec 2022 23:31:48 -0500 Subject: [PATCH 2/3] fix comment --- types/events.go | 3 --- 1 file changed, 3 deletions(-) diff --git a/types/events.go b/types/events.go index d498fd953008..b433c8515679 100644 --- a/types/events.go +++ b/types/events.go @@ -22,10 +22,7 @@ type EventManagerI interface { ABCIEvents() []abci.Event EmitTypedEvent(tev proto.Message) error EmitTypedEvents(tevs ...proto.Message) error - - // Deprecated: Use EmitTypedEvent EmitEvent(event Event) - // Deprecated: Use EmitTypedEvents EmitEvents(events Events) } From c49f663b5c04abe7a4734e7aed6b093fa16fbcc3 Mon Sep 17 00:00:00 2001 From: Dev Bear Date: Wed, 21 Dec 2022 23:35:37 -0500 Subject: [PATCH 3/3] changelog --- CHANGELOG.md | 1 + 1 file changed, 1 insertion(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 1b30e097b786..98fd3df7d254 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -62,6 +62,7 @@ Ref: https://keepachangelog.com/en/1.0.0/ ### Improvements +* (context)[#14384](https://github.com/cosmos/cosmos-sdk/pull/14384) refactor(context): Pass EventManager to the context as an interface. * (types) [#14354](https://github.com/cosmos/cosmos-sdk/pull/14354) - improve performance on Context.KVStore and Context.TransientStore by 40% * (crypto/keyring) [#14151](https://github.com/cosmos/cosmos-sdk/pull/14151) Move keys presentation from `crypto/keyring` to `client/keys` * (types) [#14163](https://github.com/cosmos/cosmos-sdk/pull/14163) Refactor `(coins Coins) Validate()` to avoid unnecessary map.