Fix reconnecting
This commit is contained in:
parent
cecc355be4
commit
594a31d983
|
@ -10,7 +10,7 @@ use std::time::Duration;
|
||||||
///
|
///
|
||||||
/// For a given GCode buffer size on the machine, we can assume
|
/// For a given GCode buffer size on the machine, we can assume
|
||||||
/// a maximum delay of `TIME_PER_MOVEMENT * BUFFER_COUNT`
|
/// a maximum delay of `TIME_PER_MOVEMENT * BUFFER_COUNT`
|
||||||
const TIME_PER_MOVEMENT: Duration = Duration::from_millis(20);
|
const TIME_PER_MOVEMENT: Duration = Duration::from_millis(50);
|
||||||
/// Movement speed of gantry when going full throttle in x/y-direction
|
/// Movement speed of gantry when going full throttle in x/y-direction
|
||||||
/// in units/min (mm/min)
|
/// in units/min (mm/min)
|
||||||
const FULL_SCALE_SPEED_XY: f64 = 1000.0;
|
const FULL_SCALE_SPEED_XY: f64 = 1000.0;
|
||||||
|
@ -51,6 +51,5 @@ pub async fn jog(gamepad: Arc<Gamepad>, mut printer: Printer) -> Never {
|
||||||
velocity: velocity.into(),
|
velocity: velocity.into(),
|
||||||
};
|
};
|
||||||
printer.send_gcode(Box::new(command)).await;
|
printer.send_gcode(Box::new(command)).await;
|
||||||
std::thread::sleep(TIME_PER_MOVEMENT);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
23
red/src/printer/gcode/m997.rs
Normal file
23
red/src/printer/gcode/m997.rs
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
use super::*;
|
||||||
|
|
||||||
|
/// Auto Home
|
||||||
|
#[derive(Debug)]
|
||||||
|
pub struct M997Command;
|
||||||
|
|
||||||
|
impl GcodeCommand for M997Command {
|
||||||
|
fn command(&self) -> String {
|
||||||
|
"M997".into()
|
||||||
|
}
|
||||||
|
|
||||||
|
fn parse_reply(&self, reply: &str) -> Result<GcodeReply> {
|
||||||
|
if !reply.is_empty() {
|
||||||
|
Err(GcodeReplyError {
|
||||||
|
sent_command: self.command(),
|
||||||
|
parsed_input: reply.to_string(),
|
||||||
|
problem: "Expected no reply".to_string(),
|
||||||
|
})
|
||||||
|
} else {
|
||||||
|
Ok(GcodeReply::NoReply)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -13,10 +13,12 @@ mod g0;
|
||||||
mod g28;
|
mod g28;
|
||||||
mod g91;
|
mod g91;
|
||||||
mod m114;
|
mod m114;
|
||||||
|
mod m997;
|
||||||
pub use g0::G0Command;
|
pub use g0::G0Command;
|
||||||
pub use g28::G28Command;
|
pub use g28::G28Command;
|
||||||
pub use g91::G91Command;
|
pub use g91::G91Command;
|
||||||
pub use m114::M114Command;
|
pub use m114::M114Command;
|
||||||
|
pub use m997::M997Command;
|
||||||
use std::fmt::Debug;
|
use std::fmt::Debug;
|
||||||
|
|
||||||
type Result<T> = std::result::Result<T, GcodeReplyError>;
|
type Result<T> = std::result::Result<T, GcodeReplyError>;
|
||||||
|
|
|
@ -3,14 +3,19 @@ pub mod gcode;
|
||||||
use bytes::BytesMut;
|
use bytes::BytesMut;
|
||||||
use futures::sink::SinkExt;
|
use futures::sink::SinkExt;
|
||||||
use futures::stream::StreamExt;
|
use futures::stream::StreamExt;
|
||||||
|
use futures::TryStreamExt;
|
||||||
|
use std::time::Duration;
|
||||||
use std::{fmt::Write, io, rc::Rc, str};
|
use std::{fmt::Write, io, rc::Rc, str};
|
||||||
use tokio;
|
use tokio;
|
||||||
use tokio::sync::mpsc::{channel, Receiver, Sender};
|
use tokio::sync::mpsc::{channel, Receiver, Sender};
|
||||||
|
use tokio::time::timeout;
|
||||||
use tokio_serial::SerialPortBuilderExt;
|
use tokio_serial::SerialPortBuilderExt;
|
||||||
use tokio_util::codec::{Decoder, Encoder};
|
use tokio_util::codec::{Decoder, Encoder};
|
||||||
|
|
||||||
pub use gcode::{GcodeCommand, GcodeReply};
|
pub use gcode::{GcodeCommand, GcodeReply};
|
||||||
|
|
||||||
|
use crate::printer::gcode::{G91Command, M997Command};
|
||||||
|
|
||||||
use self::gcode::GcodeReplyError;
|
use self::gcode::GcodeReplyError;
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
|
@ -63,10 +68,31 @@ impl Printer {
|
||||||
|
|
||||||
// The printer will send some info after connecting. We need to wait for this
|
// The printer will send some info after connecting. We need to wait for this
|
||||||
// to be received as it will otherwise stop responding for some reason:
|
// to be received as it will otherwise stop responding for some reason:
|
||||||
while let Some(stuff) = serial_rx.next().await {
|
loop {
|
||||||
if stuff.map(|s| s.contains("Loaded")).unwrap_or(false) {
|
if let Ok(message) = timeout(Duration::from_secs(10), serial_rx.next()).await {
|
||||||
|
match message {
|
||||||
|
Some(Ok(reply)) => {
|
||||||
|
println!("got stuff: {:?}", reply);
|
||||||
|
if reply.contains("Loaded") {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
if reply.contains("ok") {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Some(Err(e)) => {
|
||||||
|
println!("Error reading from serial port: {:?}", e);
|
||||||
|
}
|
||||||
|
None => (),
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// TODO: Check if port is good by sending some harmless gcode
|
||||||
|
println!(
|
||||||
|
"Reading from serial port timed out. Printer might already be initialized."
|
||||||
|
);
|
||||||
|
println!("Sending G91 command");
|
||||||
|
serial_tx.send(G91Command.command() + "\n").await;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
while let Some(command) = printer_in_rx.recv().await {
|
while let Some(command) = printer_in_rx.recv().await {
|
||||||
|
|
Loading…
Reference in a new issue