pub struct CachedBlockStore<S: BlockStore> { /* private fields */ }Expand description
Write-back LRU block cache.
Wraps an arbitrary BlockStore and serves reads from an in-memory LRU
cache. Writes are marked dirty and batched to the inner store on
sync(). If the cache is full and a dirty entry must
be evicted, it is written-back to the inner store immediately.
Implementations§
Source§impl<S: BlockStore> CachedBlockStore<S>
impl<S: BlockStore> CachedBlockStore<S>
Sourcepub fn new(inner: S, capacity: usize) -> Self
pub fn new(inner: S, capacity: usize) -> Self
Create a new cache of capacity blocks in front of inner.
capacity is clamped to a minimum of 16.
Examples found in repository?
examples/network_mount.rs (line 99)
22fn main() {
23 let args: Vec<String> = std::env::args().collect();
24
25 let mut addr = "127.0.0.1:9100";
26 let mut server_name = "localhost";
27 let mut cert = "certs/client.pem";
28 let mut key = "certs/client-key.pem";
29 let mut ca = "certs/ca.pem";
30 let mut master_key_hex = "";
31 let mut init = false;
32
33 let mut i = 1;
34 while i < args.len() {
35 match args[i].as_str() {
36 "--addr" => {
37 addr = &args[i + 1];
38 i += 2;
39 }
40 "--server-name" => {
41 server_name = &args[i + 1];
42 i += 2;
43 }
44 "--cert" => {
45 cert = &args[i + 1];
46 i += 2;
47 }
48 "--key" => {
49 key = &args[i + 1];
50 i += 2;
51 }
52 "--ca" => {
53 ca = &args[i + 1];
54 i += 2;
55 }
56 "--master-key" => {
57 master_key_hex = &args[i + 1];
58 i += 2;
59 }
60 "--init" => {
61 init = true;
62 i += 1;
63 }
64 other => {
65 eprintln!("unknown argument: {other}");
66 std::process::exit(1);
67 }
68 }
69 }
70
71 if master_key_hex.is_empty() || master_key_hex.len() != 64 {
72 eprintln!("--master-key must be a 64-character hex string (32 bytes)");
73 std::process::exit(1);
74 }
75
76 let master_key: Vec<u8> = (0..32)
77 .map(|i| u8::from_str_radix(&master_key_hex[i * 2..i * 2 + 2], 16).unwrap())
78 .collect();
79
80 // ── Connect ─────────────────────────────────────────────
81 println!("Connecting to {addr} (SNI: {server_name})...");
82 let net = NetworkBlockStore::connect(
83 addr,
84 server_name,
85 Path::new(cert),
86 Path::new(key),
87 Path::new(ca),
88 )
89 .expect("failed to connect to server");
90
91 println!(
92 "Connected: {} blocks × {} bytes ({} MiB)",
93 net.total_blocks(),
94 net.block_size(),
95 net.total_blocks() as usize * net.block_size() / (1024 * 1024)
96 );
97
98 // ── Wrap with cache ─────────────────────────────────────
99 let store = Arc::new(CachedBlockStore::new(net, 1024));
100 let crypto = Arc::new(ChaChaEngine::new(&master_key).expect("invalid master key"));
101 let mut fs = FilesystemCore::new(store.clone(), crypto);
102
103 // ── Mount or init ───────────────────────────────────────
104 if init {
105 println!("Initializing new filesystem...");
106 fs.init_filesystem().expect("init_filesystem failed");
107 } else {
108 println!("Mounting existing filesystem...");
109 fs.open().expect("open failed");
110 }
111
112 // ── Demo operations ─────────────────────────────────────
113 println!("\nCreating file 'hello.txt'...");
114 match fs.create_file("hello.txt") {
115 Ok(()) => {}
116 Err(e) => println!(" (skipped: {e})"),
117 }
118
119 fs.write_file("hello.txt", 0, b"Hello from the network!")
120 .expect("write failed");
121
122 let data = fs.read_file("hello.txt", 0, 4096).expect("read failed");
123 println!("Read back: {:?}", String::from_utf8_lossy(&data));
124
125 println!("\nListing root directory:");
126 for entry in fs.list_directory().expect("list failed") {
127 println!(
128 " {:?} {:>10} bytes {}",
129 entry.kind, entry.size, entry.name
130 );
131 }
132
133 // ── Sync ────────────────────────────────────────────────
134 fs.sync().expect("sync failed");
135 println!("\nAll data synced to server.");
136}Trait Implementations§
Source§impl<S: BlockStore> BlockStore for CachedBlockStore<S>
impl<S: BlockStore> BlockStore for CachedBlockStore<S>
Source§fn block_size(&self) -> usize
fn block_size(&self) -> usize
Block size in bytes.
Source§fn total_blocks(&self) -> u64
fn total_blocks(&self) -> u64
Total number of blocks in the store.
Source§fn read_block(&self, block_id: u64) -> FsResult<Vec<u8>>
fn read_block(&self, block_id: u64) -> FsResult<Vec<u8>>
Read a full block. Returns exactly
block_size() bytes.Source§fn write_block(&self, block_id: u64, data: &[u8]) -> FsResult<()>
fn write_block(&self, block_id: u64, data: &[u8]) -> FsResult<()>
Write a full block.
data must be exactly block_size() bytes.Auto Trait Implementations§
impl<S> !Freeze for CachedBlockStore<S>
impl<S> RefUnwindSafe for CachedBlockStore<S>where
S: RefUnwindSafe,
impl<S> Send for CachedBlockStore<S>
impl<S> Sync for CachedBlockStore<S>
impl<S> Unpin for CachedBlockStore<S>where
S: Unpin,
impl<S> UnsafeUnpin for CachedBlockStore<S>where
S: UnsafeUnpin,
impl<S> UnwindSafe for CachedBlockStore<S>where
S: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more