network: fix requestTx()
2 bugs were here: 1. If amount of tx is small, no messages were sent. 2. Correctly cut byte slice if last message is small.
This commit is contained in:
parent
074ba5f394
commit
bd81b19a7a
1 changed files with 5 additions and 2 deletions
|
@ -839,12 +839,15 @@ func (s *Server) requestTx(hashes ...util.Uint256) {
|
|||
return
|
||||
}
|
||||
|
||||
for i := 0; i < len(hashes)/payload.MaxHashesCount; i++ {
|
||||
for i := 0; i <= len(hashes)/payload.MaxHashesCount; i++ {
|
||||
start := i * payload.MaxHashesCount
|
||||
stop := (i + 1) * payload.MaxHashesCount
|
||||
if stop < len(hashes) {
|
||||
if stop > len(hashes) {
|
||||
stop = len(hashes)
|
||||
}
|
||||
if start == stop {
|
||||
break
|
||||
}
|
||||
msg := NewMessage(CMDGetData, payload.NewInventory(payload.TXType, hashes[start:stop]))
|
||||
// It's high priority because it directly affects consensus process,
|
||||
// even though it's getdata.
|
||||
|
|
Loading…
Reference in a new issue