Moved the state out to a different file
This commit is contained in:
parent
a888ec9a8a
commit
ceb26b40b1
21
src/main.rs
21
src/main.rs
@ -4,28 +4,21 @@
|
||||
extern crate rocket;
|
||||
extern crate serde;
|
||||
|
||||
mod simulation;
|
||||
|
||||
use std::sync::{Arc, Mutex};
|
||||
use std::thread;
|
||||
use std::time::Duration;
|
||||
|
||||
use rocket::State;
|
||||
use rocket::State as RocketState;
|
||||
use rocket_contrib::templates::Template;
|
||||
use serde::Serialize;
|
||||
|
||||
use simulation::{Object, Simulation};
|
||||
mod simulation;
|
||||
mod state;
|
||||
|
||||
#[derive(Clone, Serialize)]
|
||||
struct SimState {
|
||||
pub iteration: u64,
|
||||
pub objects: Vec<Object>
|
||||
}
|
||||
|
||||
type WrappedState = Arc<Mutex<SimState>>;
|
||||
use simulation::Simulation;
|
||||
use state::{State, WrappedState};
|
||||
|
||||
#[get("/")]
|
||||
fn index(sim: State<WrappedState>) -> Template {
|
||||
fn index(sim: RocketState<WrappedState>) -> Template {
|
||||
let state = sim.lock().unwrap();
|
||||
|
||||
|
||||
@ -49,7 +42,7 @@ fn simulation(s: WrappedState) {
|
||||
}
|
||||
|
||||
fn main() {
|
||||
let state = Arc::new(Mutex::new(SimState {
|
||||
let state = Arc::new(Mutex::new(State {
|
||||
iteration: 0, objects: vec![]
|
||||
}));
|
||||
|
||||
|
@ -1,6 +1,7 @@
|
||||
use legion::prelude::*;
|
||||
use rand::prelude::*;
|
||||
use serde::Serialize;
|
||||
|
||||
use crate::state::Object;
|
||||
|
||||
#[derive(Clone, Debug, PartialEq)]
|
||||
struct Name {
|
||||
@ -23,13 +24,6 @@ pub struct Simulation {
|
||||
world: World
|
||||
}
|
||||
|
||||
#[derive(Clone, Serialize)]
|
||||
pub struct Object {
|
||||
pub name: String,
|
||||
pub x: f64,
|
||||
pub y: f64,
|
||||
}
|
||||
|
||||
impl Simulation {
|
||||
pub fn new() -> Self {
|
||||
let universe = Universe::new();
|
||||
|
18
src/state.rs
Normal file
18
src/state.rs
Normal file
@ -0,0 +1,18 @@
|
||||
use std::sync::{Arc, Mutex};
|
||||
|
||||
use serde::Serialize;
|
||||
|
||||
#[derive(Clone, Serialize)]
|
||||
pub struct Object {
|
||||
pub name: String,
|
||||
pub x: f64,
|
||||
pub y: f64,
|
||||
}
|
||||
|
||||
#[derive(Clone, Serialize)]
|
||||
pub struct State {
|
||||
pub iteration: u64,
|
||||
pub objects: Vec<Object>
|
||||
}
|
||||
|
||||
pub type WrappedState = Arc<Mutex<State>>;
|
Loading…
x
Reference in New Issue
Block a user