mirror of
https://gitlab.com/pulsechaincom/lighthouse-pulse.git
synced 2025-01-01 00:41:20 +00:00
Tidy BlockGraph, use parking_lot, add doc comments
This commit is contained in:
parent
d4757f2e09
commit
1e6f85a5eb
@ -1,12 +1,22 @@
|
|||||||
|
use parking_lot::{RwLock, RwLockReadGuard};
|
||||||
use std::collections::HashSet;
|
use std::collections::HashSet;
|
||||||
use std::sync::{RwLock, RwLockReadGuard};
|
|
||||||
use types::Hash256;
|
use types::Hash256;
|
||||||
|
|
||||||
|
/// Maintains a view of the block DAG, also known as the "blockchain" (except, it tracks multiple
|
||||||
|
/// chains eminating from a single root instead of just the head of some canonical chain).
|
||||||
|
///
|
||||||
|
/// The BlockGraph does not store the blocks, instead it tracks the block hashes of blocks at the
|
||||||
|
/// tip of the DAG. It is out of the scope of the object to retrieve blocks.
|
||||||
|
///
|
||||||
|
/// Presently, the DAG root (genesis block) is not tracked.
|
||||||
|
///
|
||||||
|
/// The BlogGraph is thread-safe due to internal RwLocks.
|
||||||
pub struct BlockGraph {
|
pub struct BlockGraph {
|
||||||
pub leaves: RwLock<HashSet<Hash256>>,
|
pub leaves: RwLock<HashSet<Hash256>>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl BlockGraph {
|
impl BlockGraph {
|
||||||
|
/// Create a new block graph without any leaves.
|
||||||
pub fn new() -> Self {
|
pub fn new() -> Self {
|
||||||
Self {
|
Self {
|
||||||
leaves: RwLock::new(HashSet::new()),
|
leaves: RwLock::new(HashSet::new()),
|
||||||
@ -15,10 +25,7 @@ impl BlockGraph {
|
|||||||
/// Add a new leaf to the block hash graph. Returns `true` if the leaf was built upon another
|
/// Add a new leaf to the block hash graph. Returns `true` if the leaf was built upon another
|
||||||
/// leaf.
|
/// leaf.
|
||||||
pub fn add_leaf(&self, parent: &Hash256, leaf: Hash256) -> bool {
|
pub fn add_leaf(&self, parent: &Hash256, leaf: Hash256) -> bool {
|
||||||
let mut leaves = self
|
let mut leaves = self.leaves.write();
|
||||||
.leaves
|
|
||||||
.write()
|
|
||||||
.expect("CRITICAL: BlockGraph poisioned.");
|
|
||||||
|
|
||||||
if leaves.contains(parent) {
|
if leaves.contains(parent) {
|
||||||
leaves.remove(parent);
|
leaves.remove(parent);
|
||||||
@ -30,7 +37,8 @@ impl BlockGraph {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Returns a read-guarded HashSet of all leaf blocks.
|
||||||
pub fn leaves(&self) -> RwLockReadGuard<HashSet<Hash256>> {
|
pub fn leaves(&self) -> RwLockReadGuard<HashSet<Hash256>> {
|
||||||
self.leaves.read().expect("CRITICAL: BlockGraph poisioned.")
|
self.leaves.read()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user