diff --git a/CHANGES.md b/CHANGES.md
index 73d6c092e6d..775a969f872 100644
--- a/CHANGES.md
+++ b/CHANGES.md
@@ -31,6 +31,9 @@ To be released.
### Added APIs
+ - Added `DetermineNextBlockStateRootHash()` method to `BlockChain`.
+ [[#3977], [#3978]]
+
### Behavioral changes
### Bug fixes
@@ -41,6 +44,8 @@ To be released.
[#3912]: https://github.com/planetarium/libplanet/pull/3912
[#3974]: https://github.com/planetarium/libplanet/pull/3974
+[#3977]: https://github.com/planetarium/libplanet/issue/3977
+[#3978]: https://github.com/planetarium/libplanet/pull/3978
Version 5.3.1
diff --git a/src/Libplanet/Blockchain/BlockChain.cs b/src/Libplanet/Blockchain/BlockChain.cs
index 856403dd71e..5326ccfca17 100644
--- a/src/Libplanet/Blockchain/BlockChain.cs
+++ b/src/Libplanet/Blockchain/BlockChain.cs
@@ -33,7 +33,7 @@ namespace Libplanet.Blockchain
///
/// In order to watch its state changes, implement interface
/// and pass it to the
- ///
+ ///
/// constructor.
///
///
@@ -90,6 +90,9 @@ public partial class BlockChain : IBlockChainStates
/// by default or if it is . Note that action renderers receive
/// events made by unsuccessful transactions as well.
/// to store states.
+ ///
+ /// Whether to determine the next block's state root hash when the chain is instantiated.
+ ///
/// Thrown when does not
/// have canonical chain id set, i.e. is
/// .
@@ -106,7 +109,8 @@ public BlockChain(
Block genesisBlock,
IBlockChainStates blockChainStates,
IActionEvaluator actionEvaluator,
- IEnumerable renderers = null)
+ IEnumerable renderers = null,
+ bool determineNextBlockStateRootHash = true)
#pragma warning disable SA1118 // The parameter spans multiple lines
: this(
policy,
@@ -120,7 +124,8 @@ public BlockChain(
genesisBlock,
blockChainStates,
actionEvaluator,
- renderers)
+ renderers,
+ determineNextBlockStateRootHash)
{
}
@@ -133,7 +138,8 @@ private BlockChain(
Block genesisBlock,
IBlockChainStates blockChainStates,
IActionEvaluator actionEvaluator,
- IEnumerable renderers)
+ IEnumerable renderers,
+ bool determineNextBlockStateRootHash)
{
if (store is null)
{
@@ -190,7 +196,7 @@ private BlockChain(
{
_nextStateRootHash = Tip.StateRootHash;
}
- else
+ else if (determineNextBlockStateRootHash)
{
_nextStateRootHash =
DetermineNextBlockStateRootHash(Tip, out var actionEvaluations);
@@ -224,7 +230,7 @@ private BlockChain(
///
/// Since this value is immutable, renderers cannot be registered after once a object is instantiated; use renderers option of
- ///
+ ///
/// constructor instead.
///
#pragma warning restore MEN002
@@ -441,7 +447,8 @@ public static BlockChain Create(
genesisBlock,
blockChainStates,
actionEvaluator,
- renderers);
+ renderers,
+ true);
}
///