2019-05-19 03:41:30 +00:00
|
|
|
extern crate clap;
|
2019-09-06 00:28:50 +00:00
|
|
|
extern crate glob;
|
|
|
|
use clap::{App, Arg};
|
|
|
|
use glob::glob;
|
2019-05-18 20:27:15 +00:00
|
|
|
use std::fs;
|
2019-09-06 00:28:50 +00:00
|
|
|
use std::process::Command;
|
2019-05-18 20:27:15 +00:00
|
|
|
use std::thread;
|
|
|
|
use std::time::Duration;
|
|
|
|
|
2019-09-06 00:28:26 +00:00
|
|
|
enum BackendMode {
|
|
|
|
Sway,
|
|
|
|
Xorg,
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() -> Result<(), String> {
|
2019-05-18 20:27:15 +00:00
|
|
|
let mut old_state = "normal";
|
|
|
|
let mut new_state: &str;
|
|
|
|
let mut path_x: String = "".to_string();
|
|
|
|
let mut path_y: String = "".to_string();
|
2019-09-06 00:28:50 +00:00
|
|
|
let mut matrix: [&str; 9];
|
2019-05-19 03:41:30 +00:00
|
|
|
let mut x_state: &str;
|
|
|
|
|
2019-09-06 00:28:26 +00:00
|
|
|
let mode = if String::from_utf8(Command::new("pidof").arg("sway").output().unwrap().stdout)
|
|
|
|
.unwrap()
|
|
|
|
.len()
|
|
|
|
>= 1
|
|
|
|
{
|
|
|
|
BackendMode::Sway
|
|
|
|
} else if String::from_utf8(Command::new("pidof").arg("Xorg").output().unwrap().stdout)
|
|
|
|
.unwrap()
|
|
|
|
.len()
|
|
|
|
>= 1
|
|
|
|
{
|
|
|
|
BackendMode::Xorg
|
|
|
|
} else {
|
|
|
|
return Err("Unable to find Sway or Xorg procceses".to_owned());
|
|
|
|
};
|
2019-05-19 03:41:30 +00:00
|
|
|
|
|
|
|
let matches = App::new("rot8")
|
2019-09-06 00:28:50 +00:00
|
|
|
.version("0.1.1")
|
|
|
|
.arg(
|
|
|
|
Arg::with_name("sleep")
|
|
|
|
.default_value("500")
|
|
|
|
.long("sleep")
|
|
|
|
.value_name("SLEEP")
|
|
|
|
.help("Set sleep millis")
|
|
|
|
.takes_value(true),
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
Arg::with_name("display")
|
|
|
|
.default_value("eDP-1")
|
|
|
|
.long("display")
|
|
|
|
.value_name("DISPLAY")
|
|
|
|
.help("Set Display Device")
|
|
|
|
.takes_value(true),
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
Arg::with_name("touchscreen")
|
|
|
|
.default_value("ELAN0732:00 04F3:22E1")
|
|
|
|
.long("touchscreen")
|
|
|
|
.value_name("TOUCHSCREEN")
|
|
|
|
.help("Set Touchscreen Device (X11)")
|
|
|
|
.takes_value(true),
|
|
|
|
)
|
|
|
|
.get_matches();
|
2019-08-16 23:47:36 +00:00
|
|
|
let sleep = matches.value_of("sleep").unwrap_or("default.conf");
|
2019-05-19 03:41:30 +00:00
|
|
|
let display = matches.value_of("display").unwrap_or("default.conf");
|
2019-09-06 00:28:50 +00:00
|
|
|
let touchscreen = matches.value_of("touchscreen").unwrap_or("default.conf");
|
2019-05-19 03:41:30 +00:00
|
|
|
|
2019-09-06 00:28:50 +00:00
|
|
|
for entry in glob("/sys/bus/iio/devices/iio:device*/in_accel_*_raw").unwrap() {
|
|
|
|
match entry {
|
2019-05-18 20:27:15 +00:00
|
|
|
Ok(path) => {
|
2019-09-06 00:28:50 +00:00
|
|
|
if path.to_str().unwrap().contains("x_raw") {
|
2019-05-18 20:27:15 +00:00
|
|
|
path_x = path.to_str().unwrap().to_owned();
|
2019-09-06 00:28:50 +00:00
|
|
|
} else if path.to_str().unwrap().contains("y_raw") {
|
2019-05-18 20:27:15 +00:00
|
|
|
path_y = path.to_str().unwrap().to_owned();
|
2019-09-06 00:28:50 +00:00
|
|
|
} else if path.to_str().unwrap().contains("z_raw") {
|
2019-05-18 20:27:15 +00:00
|
|
|
continue;
|
|
|
|
} else {
|
|
|
|
println!("{:?}", path);
|
|
|
|
panic!();
|
|
|
|
}
|
2019-09-06 00:28:50 +00:00
|
|
|
}
|
|
|
|
Err(e) => println!("{:?}", e),
|
2019-05-18 20:27:15 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
loop {
|
|
|
|
let x_raw = fs::read_to_string(path_x.as_str()).unwrap();
|
|
|
|
let y_raw = fs::read_to_string(path_y.as_str()).unwrap();
|
|
|
|
let x = x_raw.trim_end_matches('\n').parse::<i32>().unwrap_or(0);
|
|
|
|
let y = y_raw.trim_end_matches('\n').parse::<i32>().unwrap_or(0);
|
2019-05-19 03:41:30 +00:00
|
|
|
|
2019-05-18 20:27:15 +00:00
|
|
|
if x < -500000 {
|
|
|
|
if y > 500000 {
|
|
|
|
new_state = "180";
|
2019-05-19 03:41:30 +00:00
|
|
|
x_state = "normal";
|
|
|
|
matrix = ["-1", "0", "1", "0", "-1", "1", "0", "0", "1"];
|
2019-09-06 00:28:50 +00:00
|
|
|
} else {
|
|
|
|
new_state = "90";
|
|
|
|
x_state = "left";
|
|
|
|
matrix = ["0", "-1", "1", "1", "0", "0", "0", "0", "1"];
|
2019-05-18 20:27:15 +00:00
|
|
|
}
|
|
|
|
} else if x > 500000 {
|
|
|
|
if y > 500000 {
|
|
|
|
new_state = "180";
|
2019-05-19 03:41:30 +00:00
|
|
|
x_state = "inverted";
|
|
|
|
matrix = ["-1", "0", "1", "0", "-1", "1", "0", "0", "1"];
|
2019-09-06 00:28:50 +00:00
|
|
|
} else {
|
2019-05-18 20:27:15 +00:00
|
|
|
new_state = "270";
|
2019-05-19 03:41:30 +00:00
|
|
|
x_state = "right";
|
|
|
|
matrix = ["0", "1", "0", "-1", "0", "1", "0", "0", "1"];
|
2019-05-18 20:27:15 +00:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if y > 500000 {
|
|
|
|
new_state = "180";
|
2019-05-19 03:41:30 +00:00
|
|
|
x_state = "inverted";
|
|
|
|
matrix = ["-1", "0", "1", "0", "-1", "1", "0", "0", "1"];
|
2019-09-06 00:28:50 +00:00
|
|
|
} else {
|
2019-05-18 20:27:15 +00:00
|
|
|
new_state = "normal";
|
2019-05-19 03:41:30 +00:00
|
|
|
x_state = "normal";
|
|
|
|
matrix = ["1", "0", "0", "0", "1", "0", "0", "0", "1"];
|
2019-05-18 20:27:15 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if new_state != old_state {
|
2019-09-06 00:28:26 +00:00
|
|
|
match mode {
|
|
|
|
BackendMode::Sway => {
|
|
|
|
Command::new("swaymsg")
|
|
|
|
.arg("output")
|
|
|
|
.arg(display)
|
|
|
|
.arg("transform")
|
|
|
|
.arg(new_state)
|
|
|
|
.spawn()
|
|
|
|
.expect("rotate command failed to start");
|
|
|
|
}
|
|
|
|
BackendMode::Xorg => {
|
|
|
|
Command::new("xrandr")
|
|
|
|
.arg("-o")
|
|
|
|
.arg(x_state)
|
|
|
|
.spawn()
|
|
|
|
.expect("rotate command failed to start");
|
2019-05-19 03:41:30 +00:00
|
|
|
|
2019-09-06 00:28:26 +00:00
|
|
|
Command::new("xinput")
|
|
|
|
.arg("set-prop")
|
|
|
|
.arg(touchscreen)
|
|
|
|
.arg("Coordinate")
|
|
|
|
.arg("Transformation")
|
|
|
|
.arg("Matrix")
|
|
|
|
.args(&matrix)
|
|
|
|
.spawn()
|
|
|
|
.expect("rotate command failed to start");
|
|
|
|
}
|
2019-05-19 03:41:30 +00:00
|
|
|
}
|
2019-09-06 00:28:26 +00:00
|
|
|
old_state = new_state;
|
2019-05-19 03:41:30 +00:00
|
|
|
}
|
2019-08-17 00:07:30 +00:00
|
|
|
thread::sleep(Duration::from_millis(sleep.parse::<u64>().unwrap_or(0)));
|
2019-05-19 03:41:30 +00:00
|
|
|
}
|
2019-05-18 20:27:15 +00:00
|
|
|
}
|