From a4c2ba9077dffb1c9ed6f6ca588694a1154a89d9 Mon Sep 17 00:00:00 2001 From: Juergen Stuber Date: Mon, 4 Nov 2024 18:47:02 +0100 Subject: [PATCH] Save the state between runs --- src/bin/primes/main.rs | 27 +++++++++++++++++++++++---- 1 file changed, 23 insertions(+), 4 deletions(-) diff --git a/src/bin/primes/main.rs b/src/bin/primes/main.rs index 4e6054b..26f1b79 100644 --- a/src/bin/primes/main.rs +++ b/src/bin/primes/main.rs @@ -1,4 +1,5 @@ use std::env::args; +use std::fs; use std::io::stdout; use std::io::Write; use std::thread::sleep; @@ -11,6 +12,9 @@ use lowdim::Array2d; use lowdim::BBox2d; use lowdim::Point2d; +type Error = Box; +type Result = std::result::Result; + const COLORS: usize = 4; #[derive(Clone, Copy, Debug, PartialEq, Eq)] @@ -38,7 +42,7 @@ impl Frame { } } -fn send(w: &mut T, frame: &Frame) -> std::io::Result<()> { +fn send(w: &mut T, frame: &Frame) -> Result<()> { for y in frame.bbox().y_range().rev() { for x in frame.bbox().x_range() { let pixel = frame.pixels[p2d(x, y)]; @@ -50,7 +54,7 @@ fn send(w: &mut T, frame: &Frame) -> std::io::Result<()> { w.write_all(rgbw)?; } } - w.flush() + Ok(w.flush()?) } fn encode_digit(d: u32) -> (i64, bool) { @@ -138,7 +142,18 @@ fn render(frame: &mut Frame, pos: &mut Point2d, n: usize) { const DEFAULT_ARG: u64 = 4; -fn main() -> std::io::Result<()> { +const STATE_FILENAME: &str = ".primes.state"; + +fn write_state(p: usize) { + let _ = fs::write(STATE_FILENAME, p.to_string()); +} + +fn read_state() -> Result { + let s = fs::read_to_string(STATE_FILENAME)?; + Ok(s.parse::()?) +} + +fn main() -> Result<()> { let args = args().collect::>(); eprintln!("executing {}", args[0]); @@ -151,6 +166,10 @@ fn main() -> std::io::Result<()> { }; eprintln!("screen size {}x{}, arg {}", x_size, y_size, arg); + let last_prime = read_state().unwrap_or(1); + eprintln!("starting after {}", last_prime); + let mut primes_iter = primal::Primes::all().skip_while(|&p| p < last_prime); + let bbox = bb2d(0..x_size as i64, 0..y_size as i64); let mut frame = Frame::new(bbox); @@ -162,7 +181,6 @@ fn main() -> std::io::Result<()> { let y_mid = (bbox.y_min() + bbox.y_max()) / 2; let mut start_pos = p2d(bbox.x_end(), y_mid - 6); - let mut primes_iter = primal::Primes::all(); let mut visible_primes = Vec::new(); let space = v2d(2, 0); @@ -193,6 +211,7 @@ fn main() -> std::io::Result<()> { // Fill up the visible primes when necessary. while pos.x() < frame.bbox().x_end() + STROKE_MID { let p = primes_iter.next().unwrap(); + write_state(p); eprintln!("{}", p); // Keep the prime for displaying it the next time.