Fix slot and proposer type, add initBlock proc

This commit is contained in:
mratsim 2018-09-04 18:09:28 +02:00
parent 0561bf70b7
commit 3d76e238e7
2 changed files with 42 additions and 10 deletions

View File

@ -28,7 +28,7 @@ method on_receive(self: Node, obj: BlockOrSig, reprocess = false) {.base.} =
########################################################### ###########################################################
proc broadcast(self: Node, x: Block) = proc broadcast(self: Node, x: Block) =
if self.sleepy and self.timestamp != Duration(): if self.sleepy and self.timestamp != DurationZero:
return return
self.network.broadcast(self, x) self.network.broadcast(self, x)
self.on_receive(x) self.on_receive(x)
@ -241,3 +241,12 @@ func get_sig_targets(self: Node, start_slot: int32): seq[MDigest[256]] =
doAssert self.blocks[x].slot <= start_slot - 1 - i doAssert self.blocks[x].slot <= start_slot - 1 - i
doAssert result.len == min(EPOCH_LENGTH, start_slot) doAssert result.len == min(EPOCH_LENGTH, start_slot)
proc tick(self: Node) =
self.timestamp += initDuration(milliseconds = 100)
self.log &"Tick: {self.timestamp}", lvl=1
# Make a block?
let slot = int32 seconds(self.timestamp div SLOT_SIZE)
if slot > self.last_made_block and (slot mod NOTARIES) == self.id:
self.broadcast(
initBlock(self.blocks[self.main_chain[^1]], slot, self.id)
)

View File

@ -11,13 +11,16 @@
# Note that implementation is not updated to the latest v2.1 yet # Note that implementation is not updated to the latest v2.1 yet
import import
tables, deques, strutils, hashes, times, # Stdlib # Stdlib
nimcrypto # Nimble packages tables, deques, strutils, hashes, times,
random,
# Nimble packages
nimcrypto
const const
NOTARIES* = 100 # Committee size in Casper v2.1 NOTARIES* = 100 # Committee size in Casper v2.1
SLOT_SIZE* = initDuration(seconds = 6) # Slot duration in Casper v2.1 SLOT_SIZE* = 6 # Slot duration in Casper v2.1
EPOCH_LENGTH* = 25 # Cycle length in Casper v2. EPOCH_LENGTH* = 25 # Cycle length in Casper v2.
# TODO, clear up if reference semantics are needed # TODO, clear up if reference semantics are needed
# for the tables. I.e. what's their maximum size. # for the tables. I.e. what's their maximum size.
@ -39,15 +42,35 @@ type
parent_hash*: MDigest[256] parent_hash*: MDigest[256]
hash*: MDigest[256] hash*: MDigest[256]
height*: int # slot in Casper v2.1 spec height*: int # slot in Casper v2.1 spec
proposer*: int64 proposer*: int32
slot*: int64 slot*: int32
########################################## ##########################################
func min_timestamp*(self: Block): Duration = func min_timestamp*(self: Block): Duration =
SLOT_SIZE * self.slot const slot_size = initDuration(seconds = SLOT_SIZE)
result = slot_size * self.slot
let Genesis* = Block() let Genesis* = Block()
proc initBlock*(parent: Block, slot, proposer: int32): Block =
new result
for val in result.contents.mitems:
val = rand(0.byte .. 7.byte)
if not parent.isNil:
result.parent_hash = parent.hash
result.height = parent.height + 1
var ctx: keccak256
ctx.init()
ctx.update(result.parent_hash.data)
ctx.update(result.contents)
ctx.finish(result.hash.data)
ctx.clear()
doAssert slot mod NOTARIES == proposer
result.proposer = proposer
result.slot = slot
########################################## ##########################################
func hash*(x: MDigest): Hash = func hash*(x: MDigest): Hash =
@ -108,7 +131,7 @@ type
justified*: TableRef[MDigest[256], bool] justified*: TableRef[MDigest[256], bool]
finalized*: TableRef[MDigest[256], bool] finalized*: TableRef[MDigest[256], bool]
timestamp*: Duration timestamp*: Duration
id*: int id*: int32
network*: NetworkSimulator network*: NetworkSimulator
used_parents*: TableRef[MDigest[256], Node] used_parents*: TableRef[MDigest[256], Node]
processed*: TableRef[BlockOrSigHash, BlockOrSig] processed*: TableRef[BlockOrSigHash, BlockOrSig]