This commit is contained in:
Rob Walker
2018-07-10 12:23:55 -07:00
parent c2dd009e0b
commit de44d7475e

View File

@ -329,7 +329,11 @@ impl Bank {
for entry in entries { for entry in entries {
entry_count += 1; entry_count += 1;
tail[*tail_index] = entry.clone(); if tail.len() > *tail_index {
tail[*tail_index] = entry.clone();
} else {
tail.push(entry.clone());
}
*tail_index += 1; *tail_index += 1;
*tail_index %= WINDOW_SIZE as usize; *tail_index %= WINDOW_SIZE as usize;
@ -425,11 +429,21 @@ impl Bank {
self.register_entry_id(&entry1.id); self.register_entry_id(&entry1.id);
let mut tail = Vec::with_capacity(WINDOW_SIZE as usize); let mut tail = Vec::with_capacity(WINDOW_SIZE as usize);
tail[0] = entry0; tail.push(entry0);
tail[1] = entry1; tail.push(entry1);
let mut tail_idx = 2; let mut tail_idx = 2;
let entry_count = 2 + self.process_blocks(entries, &mut tail, &mut tail_idx)?; let entry_count = 2 + self.process_blocks(entries, &mut tail, &mut tail_idx)?;
// check if we need to shift tail around
if tail.len() == WINDOW_SIZE as usize && tail_idx != 0 {
for i in 0..WINDOW_SIZE as usize {
tail.swap(i, tail_idx);
tail_idx += 1;
tail_idx %= WINDOW_SIZE as usize;
}
}
eprintln!(".. {}", duration_as_us(&now.elapsed())); eprintln!(".. {}", duration_as_us(&now.elapsed()));
Ok((entry_count, tail)) Ok((entry_count, tail))
@ -810,23 +824,24 @@ mod tests {
#[test] #[test]
fn test_process_ledger_around_window_size() { fn test_process_ledger_around_window_size() {
// benchmark
for _ in 0..10 { for _ in 0..10 {
let (ledger, _) = create_sample_ledger(WINDOW_SIZE as usize * 6); let (ledger, _) = create_sample_ledger(WINDOW_SIZE as usize * 6);
let bank = Bank::default(); let bank = Bank::default();
let (_, _) = bank.process_ledger(ledger).unwrap(); let (_, _) = bank.process_ledger(ledger).unwrap();
} }
// let window_size = WINDOW_SIZE as usize; let window_size = WINDOW_SIZE as usize;
// for entry_count in window_size - 1..window_size + 2 { for entry_count in window_size - 1..window_size + 2 {
// let (ledger, pubkey) = create_sample_ledger(entry_count); let (ledger, pubkey) = create_sample_ledger(entry_count);
// let bank = Bank::default(); let bank = Bank::default();
// let (ledger_height, tail) = bank.process_ledger(ledger).unwrap(); let (ledger_height, tail) = bank.process_ledger(ledger).unwrap();
// assert_eq!(bank.get_balance(&pubkey), 1); assert_eq!(bank.get_balance(&pubkey), 1);
// assert_eq!(ledger_height, entry_count as u64 + 2); assert_eq!(ledger_height, entry_count as u64 + 2);
// assert!(tail.len() <= window_size); assert!(tail.len() <= window_size);
// let last_entry = &tail[tail.len() - 1]; let last_entry = &tail[tail.len() - 1];
// assert_eq!(bank.last_id(), last_entry.id); assert_eq!(bank.last_id(), last_entry.id);
// } }
} }
// Write the given entries to a file and then return a file iterator to them. // Write the given entries to a file and then return a file iterator to them.