remove unused imports

This commit is contained in:
リキ萌 2024-08-24 12:53:52 +02:00
parent eb25d0b1cf
commit 9cb24a0b1e
8 changed files with 19 additions and 120 deletions

View file

@ -1,6 +1,6 @@
use alloc::vec::Vec;
use tiny_skia::{
BlendMode, Color, FillRule, LineCap, Paint, Path, PathBuilder, Pixmap, Rect, Shader,
BlendMode, Color, FillRule, LineCap, Paint, Path, PathBuilder, Pixmap, Shader,
Stroke as SStroke, Transform,
};

View file

@ -19,10 +19,9 @@ use schema::{
use serde::{Deserialize, Serialize};
use tokio::{
select,
sync::{self, mpsc, oneshot},
time::Instant,
sync::{mpsc, oneshot},
};
use tracing::{error, info, instrument};
use tracing::{error, instrument};
use crate::{
haku::{Haku, Limits},
@ -254,8 +253,7 @@ impl SessionLoop {
.name(String::from("haku render thread"))
.spawn({
let wall = Arc::clone(&wall);
let chunk_images = Arc::clone(&chunk_images);
move || Self::render_thread(wall, chunk_images, limits, render_commands_rx)
move || Self::render_thread(wall, limits, render_commands_rx)
})
.context("could not spawn render thread")?;
@ -415,12 +413,7 @@ impl SessionLoop {
Ok(())
}
fn render_thread(
wall: Arc<Wall>,
chunk_images: Arc<ChunkImages>,
limits: Limits,
mut commands: mpsc::Receiver<RenderCommand>,
) {
fn render_thread(wall: Arc<Wall>, limits: Limits, mut commands: mpsc::Receiver<RenderCommand>) {
let mut haku = Haku::new(limits);
let mut brush_ok = false;
@ -436,7 +429,7 @@ impl SessionLoop {
for point in points {
// Ignore the result. It's better if we render _something_ rather
// than nothing.
_ = draw_to_chunks(&wall, &chunk_images, &haku, value, point);
_ = draw_to_chunks(&wall, &haku, value, point);
}
haku.reset_vm();
}
@ -467,14 +460,8 @@ fn chunks_to_modify(wall: &Wall, points: &[Vec2]) -> HashSet<ChunkPosition> {
chunks
}
#[instrument(skip(wall, chunk_images, haku, value))]
fn draw_to_chunks(
wall: &Wall,
chunk_images: &ChunkImages,
haku: &Haku,
value: Value,
center: Vec2,
) -> eyre::Result<()> {
#[instrument(skip(wall, haku, value))]
fn draw_to_chunks(wall: &Wall, haku: &Haku, value: Value, center: Vec2) -> eyre::Result<()> {
let settings = wall.settings();
let chunk_size = settings.chunk_size as f32;
@ -497,16 +484,5 @@ fn draw_to_chunks(
}
}
// NOTE: Maybe sending in an iterator would be more efficient?
// If there were many chunks modified, (which there probably weren't,) this could allocate
// a lot of memory.
chunk_images.mark_modified_blocking(
(top_chunk..bottom_chunk)
.flat_map(|chunk_y| {
(left_chunk..right_chunk).map(move |chunk_x| ChunkPosition::new(chunk_x, chunk_y))
})
.collect(),
);
Ok(())
}

View file

@ -1,7 +1,7 @@
use std::path::PathBuf;
use argon2::{
password_hash::{PasswordHasher, Salt, SaltString},
password_hash::{PasswordHasher, SaltString},
Argon2, PasswordHash, PasswordVerifier,
};
use base64::Engine;

View file

@ -13,10 +13,8 @@ use eyre::Context;
use tokio::{fs, net::TcpListener};
use tower_http::services::{ServeDir, ServeFile};
use tracing::{info, info_span};
use tracing_subscriber::fmt::format::FmtSpan;
mod api;
mod binary;
mod config;
mod haku;
mod id;

View file

@ -1,14 +1,13 @@
use std::{backtrace::Backtrace, collections::HashSet, sync::Arc, time::Duration};
use std::{collections::HashSet, sync::Arc, time::Duration};
use dashmap::DashSet;
use serde::{Deserialize, Serialize};
use tokio::{
sync::mpsc,
time::{interval, MissedTickBehavior},
};
use tracing::{info, instrument};
use tracing::instrument;
use super::{chunk_images::ChunkImages, ChunkPosition, Database, Wall};
use super::{chunk_images::ChunkImages, ChunkPosition};
#[derive(Debug, Clone, Deserialize, Serialize)]
pub struct Settings {

View file

@ -26,10 +26,6 @@ enum Command {
chunks: Vec<ChunkPosition>,
reply: oneshot::Sender<eyre::Result<()>>,
},
MarkModified {
chunks: Vec<ChunkPosition>,
},
}
impl ChunkImages {
@ -69,12 +65,6 @@ impl ChunkImages {
rx.await.context("failed to load chunks")?
}
pub fn mark_modified_blocking(&self, chunks: Vec<ChunkPosition>) {
_ = self
.commands_tx
.blocking_send(Command::MarkModified { chunks });
}
pub fn chunk_exists(&self, position: ChunkPosition) -> bool {
self.wall.has_chunk(position) || self.async_loop.chunks_in_db.contains(&position)
}
@ -221,17 +211,12 @@ impl ChunkImageLoop {
while let Some(command) = commands_rx.recv().await {
match command {
Command::Encode { chunks, reply } => {
// TODO: This should have a caching layer.
tokio::spawn(Arc::clone(&self).encode(chunks, reply));
}
Command::Load { chunks, reply } => {
tokio::spawn(Arc::clone(&self).load(chunks, reply));
}
Command::MarkModified { chunks } => {
// TODO: This should invalidate data from the caching layer.
}
}
}
}

View file

@ -1,5 +1,3 @@
use std::iter::Take;
use super::ChunkPosition;
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
@ -19,26 +17,6 @@ impl ChunkIterator {
bottom_right,
}
}
pub fn take_next(&mut self, n: i32) -> Take<Self> {
assert!(n > 0);
let take = (*self).take(n as usize);
let x = self.cursor.x - self.left;
let width = self.bottom_right.x - self.left;
if width != 0 {
self.cursor.x = self.left + (x + n) % width;
self.cursor.y += n / width;
} else {
// In a width = 0 configuration, we iterate vertically.
// This is probably not the right thing to do, but we're just doing this to guard
// against malicious clients.
self.cursor.y += n;
}
take
}
}
impl Iterator for ChunkIterator {

View file

@ -1,17 +1,10 @@
use std::{
convert::identity,
path::{Path, PathBuf},
sync::Arc,
};
use std::{convert::identity, path::PathBuf, sync::Arc};
use chrono::Utc;
use eyre::Context;
use rusqlite::Connection;
use tokio::sync::{mpsc, oneshot};
use tracing::{error, info, instrument};
use crate::login::UserId;
use super::{ChunkPosition, WallId};
pub struct Settings {
@ -32,18 +25,12 @@ pub struct ChunkDataPair {
}
enum Command {
SetWallInfo {
created_by: UserId,
title: String,
reply: oneshot::Sender<eyre::Result<()>>,
},
WriteChunks {
Write {
chunks: Vec<ChunkDataPair>,
reply: oneshot::Sender<eyre::Result<()>>,
},
ReadChunks {
Read {
chunks: Vec<ChunkPosition>,
reply: oneshot::Sender<Vec<ChunkDataPair>>,
},
@ -62,7 +49,7 @@ impl Database {
pub async fn write_chunks(&self, chunks: Vec<ChunkDataPair>) -> eyre::Result<()> {
let (tx, rx) = oneshot::channel();
self.command_tx
.send(Command::WriteChunks { chunks, reply: tx })
.send(Command::Write { chunks, reply: tx })
.await
.context("database is offline")?;
rx.await.context("database returned an error")?
@ -74,7 +61,7 @@ impl Database {
) -> eyre::Result<Vec<ChunkDataPair>> {
let (tx, rx) = oneshot::channel();
self.command_tx
.send(Command::ReadChunks { chunks, reply: tx })
.send(Command::Read { chunks, reply: tx })
.await
.context("database is offline")?;
rx.await.context("database did not return anything")
@ -207,17 +194,6 @@ pub fn start(settings: Settings) -> eyre::Result<Database> {
std::thread::Builder::new()
.name(format!("database thread {}", settings.wall_id))
.spawn(move || {
let mut s_set_wall_info = db
.prepare(
r#"
INSERT OR REPLACE
INTO t_wall_info
(created_by, title)
VALUES (?, ?);
"#,
)
.unwrap();
let mut s_write_chunk = db
.prepare(
r#"
@ -250,20 +226,7 @@ pub fn start(settings: Settings) -> eyre::Result<Database> {
while let Some(command) = command_rx.blocking_recv() {
match command {
Command::SetWallInfo {
created_by,
title,
reply,
} => {
_ = reply.send(
s_set_wall_info
.execute((created_by.0, title))
.map(|_| ())
.context("failed to set wall info"),
);
}
Command::WriteChunks { chunks, reply } => {
Command::Write { chunks, reply } => {
let mut result = Ok(());
for ChunkDataPair { position, data } in chunks {
if let Err(error) =
@ -279,7 +242,7 @@ pub fn start(settings: Settings) -> eyre::Result<Database> {
));
}
Command::ReadChunks { chunks, reply } => {
Command::Read { chunks, reply } => {
let result = chunks
.into_iter()
.flat_map(|position| {