aboutsummaryrefslogtreecommitdiffstats
path: root/core/interfaces.go
diff options
context:
space:
mode:
authorWei-Ning Huang <w@dexon.org>2018-09-20 16:08:08 +0800
committerGitHub <noreply@github.com>2018-09-20 16:08:08 +0800
commita4b6b9e6a28a4d8fc49ee76c191454a819265713 (patch)
tree716e5724b182b8dccb01a49faec4c163f1fafdb0 /core/interfaces.go
parent2f1e71d9d298d1f6ade8d17a1db7a657b0223872 (diff)
downloadtangerine-consensus-a4b6b9e6a28a4d8fc49ee76c191454a819265713.tar
tangerine-consensus-a4b6b9e6a28a4d8fc49ee76c191454a819265713.tar.gz
tangerine-consensus-a4b6b9e6a28a4d8fc49ee76c191454a819265713.tar.bz2
tangerine-consensus-a4b6b9e6a28a4d8fc49ee76c191454a819265713.tar.lz
tangerine-consensus-a4b6b9e6a28a4d8fc49ee76c191454a819265713.tar.xz
tangerine-consensus-a4b6b9e6a28a4d8fc49ee76c191454a819265713.tar.zst
tangerine-consensus-a4b6b9e6a28a4d8fc49ee76c191454a819265713.zip
core: refactor witness data processing flow (#124)
Since witness data need to include data from application after it processed a block (e.g. stateRoot). We should make the process of witness data asynchronous. An interface `BlockProcessedChan()` is added to the application interface to return a channel for notifying the consensus core when a block is processed. The notification object includes a byte slice (witenss data) which will be include in the final witness data object.
Diffstat (limited to 'core/interfaces.go')
-rw-r--r--core/interfaces.go4
1 files changed, 4 insertions, 0 deletions
diff --git a/core/interfaces.go b/core/interfaces.go
index 4f67e1e..8ecfb3c 100644
--- a/core/interfaces.go
+++ b/core/interfaces.go
@@ -46,6 +46,10 @@ type Application interface {
// DeliverBlock is called when a block is add to the compaction chain.
DeliverBlock(blockHash common.Hash, timestamp time.Time)
+ // BlockProcessedChan returns a channel to receive the block hashes that have
+ // finished processing by the application.
+ BlockProcessedChan() <-chan types.WitnessResult
+
// WitnessAckDeliver is called when a witness ack is created.
WitnessAckDeliver(witnessAck *types.WitnessAck)
}