this kinda works
Some checks failed
CI / Rust checks (push) Failing after 1m17s
Security / Audit (push) Failing after 7m24s

This commit is contained in:
2024-10-20 19:44:04 +02:00
parent c50bb6c344
commit 54f84ed7af
7 changed files with 387 additions and 22 deletions

12
testapp/Cargo.toml Normal file
View File

@@ -0,0 +1,12 @@
[package]
name = "testapp"
version = "0.1.0"
edition = "2021"
[dependencies]
anyhow = "1.0.90"
ctrlc = "3.4.5"
# simconnect-rs = { path = "../simconnect-rs" }
simconnect-sdk = { path = "../simconnect-sdk", features = ["derive"] }
tracing = "0.1.40"
tracing-subscriber = "0.3.18"

28
testapp/src/ctrl_c.rs Normal file
View File

@@ -0,0 +1,28 @@
use std::sync::{
atomic::{AtomicU8, Ordering},
Arc,
};
pub struct CtrlC {
counter: Arc<AtomicU8>,
}
impl CtrlC {
pub fn new() -> Self {
let counter: Arc<AtomicU8> = Default::default();
let c = counter.clone();
ctrlc::set_handler(move || {
c.fetch_add(1, Ordering::SeqCst);
if c.load(Ordering::SeqCst) >= 3 {
std::process::exit(1);
}
})
.unwrap();
Self { counter }
}
pub fn count(&self) -> u8 {
self.counter.load(Ordering::SeqCst)
}
}

159
testapp/src/main.rs Normal file
View File

@@ -0,0 +1,159 @@
mod ctrl_c;
use std::{
borrow::Cow,
ffi::{CStr, CString},
thread::sleep,
time::Duration,
};
use ctrl_c::CtrlC;
// use simconnect_rs::SimConnect;
use simconnect_sdk::{Notification, SimConnect, SimConnectObject, SystemEventRequest};
#[derive(Debug, Clone, SimConnectObject)]
#[simconnect(period = "second")]
struct AtcID {
#[simconnect(name = "ATC ID")]
value: String,
}
// #[derive(Debug, Clone, SimConnectObject)]
// #[simconnect(period = "second")]
// #[allow(dead_code)]
// struct AirplaneData {
// #[simconnect(name = "TITLE")]
// title: String,
// #[simconnect(name = "ATC ID")]
// atc_id: String,
// #[simconnect(name = "CATEGORY")]
// category: String,
// #[simconnect(name = "PLANE LATITUDE", unit = "degrees")]
// lat: f64,
// #[simconnect(name = "PLANE LONGITUDE", unit = "degrees")]
// lon: f64,
// #[simconnect(name = "PLANE ALTITUDE", unit = "feet")]
// alt: f64,
// #[simconnect(name = "SIM ON GROUND")]
// sim_on_ground: bool,
// }
#[derive(Debug, Clone, SimConnectObject)]
#[simconnect(period = "second")]
struct Fuel {
#[simconnect(name = "FUEL TANK CENTER QUANTITY", unit = "gallons")]
ft1: f64,
#[simconnect(name = "FUEL TANK LEFT MAIN QUANTITY", unit = "gallons")]
wt1: f64,
#[simconnect(name = "FUEL TANK RIGHT MAIN QUANTITY", unit = "gallons")]
wt2: f64,
#[simconnect(name = "FUEL TANK EXTERNAL1 QUANTITY", unit = "gallons")]
et1: f64,
#[simconnect(name = "FUEL TANK EXTERNAL2 QUANTITY", unit = "gallons")]
et2: f64,
#[simconnect(name = "FUEL TANK CENTER3 QUANTITY", unit = "gallons")]
et3: f64,
#[simconnect(name = "FUEL TANK CENTER2 QUANTITY", unit = "gallons")]
ft2: f64,
}
fn main() -> Result<(), anyhow::Error> {
use tracing::Level;
use tracing_subscriber::layer::SubscriberExt;
use tracing_subscriber::util::SubscriberInitExt;
use tracing_subscriber::Layer;
let fmt = tracing_subscriber::fmt::layer().with_filter(tracing_subscriber::filter::filter_fn(
|metadata| metadata.level() < &Level::TRACE,
));
tracing_subscriber::registry().with(fmt).init();
let Ok(mut simconnect) = SimConnect::new("Avii's Virtual Airline Manager") else {
panic!("Game not running, gotta wait for it here");
};
// .subscribe(SomeEvent);
let mut id = 0;
let ctrl_c = CtrlC::new();
loop {
if let Ok(Some(event)) = simconnect.get_next_dispatch() {
match event {
Notification::Open => {
simconnect.subscribe_to_system_event(SystemEventRequest::FlightLoaded)?;
id = simconnect.register_object::<AtcID>()?;
simconnect.register_object::<Fuel>()?;
let cs = CString::new("FAST")?;
let mut buffer = [0i8; 256];
for (i, b) in cs.to_bytes_with_nul().iter().enumerate() {
buffer[i] = *b as i8;
}
simconnect
.set_data_on_sim_object_with_id(id, &mut AtcIDCPacked { value: buffer })?;
tracing::info!("ATC_ID set");
simconnect.set_data_on_sim_object(&mut Fuel {
ft1: 0.0,
wt1: 20.0,
wt2: 20.0,
et1: 0.0,
et2: 0.0,
et3: 0.0,
ft2: 0.0,
})?;
tracing::info!("FUEL set");
}
Notification::Object(object) => {
// if let Ok(fuel) = Fuel::try_from(&object) {
// // dbg!(fuel);
// continue;
// }
}
Notification::SystemEvent(system_event) => {
if let simconnect_sdk::SystemEvent::FlightLoaded { .. } = system_event {
let cs = CString::new("RAWR")?;
let mut buffer = [0i8; 256];
for (i, b) in cs.to_bytes_with_nul().iter().enumerate() {
buffer[i] = *b as i8;
}
simconnect.set_data_on_sim_object_with_id(
id,
&mut AtcIDCPacked { value: buffer },
)?;
tracing::info!("ATC_ID set");
simconnect.set_data_on_sim_object(&mut Fuel {
ft1: 0.0,
wt1: 20.0,
wt2: 20.0,
et1: 0.0,
et2: 0.0,
et3: 0.0,
ft2: 0.0,
})?;
tracing::info!("FUEL set");
}
}
Notification::Quit => panic!("Sim Quit"),
_ => todo!(),
}
}
sleep(Duration::from_millis(1000));
if ctrl_c.count() > 0 {
break;
}
}
drop(simconnect);
Ok(())
}