summaryrefslogtreecommitdiff
path: root/src/modules/mining.rs
diff options
context:
space:
mode:
authortom barrett <spalf0@gmail.com>2018-06-26 04:49:31 -0500
committertom barrett <spalf0@gmail.com>2018-06-26 04:49:31 -0500
commit25d556ad995a83c0c783f0bf9ca555b17cb0bfb0 (patch)
treedd18a8c287e3a397ee3ab8281643ee4a48ce9125 /src/modules/mining.rs
parent2d01ede909281e8c412924ba524b7406c2d760ee (diff)
-moved to enum states for mining and refinery, added mining module knowing if astroid has no minerals
Diffstat (limited to 'src/modules/mining.rs')
-rw-r--r--src/modules/mining.rs57
1 files changed, 33 insertions, 24 deletions
diff --git a/src/modules/mining.rs b/src/modules/mining.rs
index 7f11f05..4a1a37f 100644
--- a/src/modules/mining.rs
+++ b/src/modules/mining.rs
@@ -1,55 +1,64 @@
use std::time::SystemTime;
+#[derive(Serialize, Deserialize, Debug, Clone, PartialEq)]
+pub enum MiningStatus {
+ None,
+ Mining,
+ Mined,
+}
+
#[derive(Serialize, Deserialize, Debug, Clone)]
pub struct Mining {
pub range : f64,
- pub status : bool,
+ pub status : MiningStatus,
time : u64,
start : Option<SystemTime>,
- pub ready : bool,
}
-
impl Mining {
pub fn new() -> Mining {
Mining {
range : 10.0,
- status : false,
+ status : MiningStatus::None,
time : 5,
start : None,
- ready : false,
}
}
- pub fn toggle(&mut self) {
- self.status = !self.status;
- self.start = match self.status {
- true => Some(SystemTime::now()),
- false => None,
- };
- }
-
- pub fn off(&mut self) {
- self.status = false;
- }
-
- pub fn take(&mut self) {
- self.ready = false;
- }
-
pub fn process(&mut self) {
match self.start.clone() {
Some(timer) => {
if timer.elapsed().unwrap().as_secs() > self.time {
+ self.status = MiningStatus::Mined;
self.start = Some(SystemTime::now());
- self.ready = true;
}
}
_ => (),
}
- if !self.status {
+ if self.status == MiningStatus::None {
self.start = None;
- self.ready = false;
}
}
+
+ pub fn toggle(&mut self) {
+ self.status = match self.status {
+ MiningStatus::None => {
+ self.start = Some(SystemTime::now());
+ MiningStatus::Mining
+ }
+ _ => {
+ self.start = None;
+ MiningStatus::None
+ }
+ };
+ }
+
+ pub fn off(&mut self) {
+ self.status = MiningStatus::None;
+ }
+
+ pub fn take(&mut self) {
+ self.status = MiningStatus::Mining;
+ }
+
}