From 8948353106cd11d1934be4b02c46cd6152ae84cf Mon Sep 17 00:00:00 2001 From: LordMZTE Date: Wed, 26 Aug 2020 13:15:01 +0200 Subject: [PATCH] add KeyState struct other small improvements --- src/logging/logger.rs | 59 +++++++++++++++++++++++++++++++++++++++++- src/logging/loggers.rs | 12 ++++----- src/main.rs | 15 ++++++----- 3 files changed, 72 insertions(+), 14 deletions(-) diff --git a/src/logging/logger.rs b/src/logging/logger.rs index 6588fa1..d43cd18 100644 --- a/src/logging/logger.rs +++ b/src/logging/logger.rs @@ -1,8 +1,10 @@ use winapi::um::winuser::KBDLLHOOKSTRUCT; + use crate::logging::loggers::{ConsoleLogger, FileLogger}; +use crate::scan_code_to_key_name; pub trait Logger: Sync { - fn log(&self, key: &KBDLLHOOKSTRUCT); + fn log(&self, key: &KeyState); } pub fn get_logger(name: &str) -> Box { @@ -11,3 +13,58 @@ pub fn get_logger(name: &str) -> Box { _ => Box::new(ConsoleLogger), } } + +impl dyn Logger { + pub fn default_format(key: &KeyState) -> String { + format!( + "{} >> {}{}{} >> {}\n", + key.kbdllstruct.vkCode, + if key.win_down { "w" } else { "" }, + if key.ctrl_down { "c" } else { "" }, + if key.shift_down { "s" } else { "" }, + scan_code_to_key_name(key.kbdllstruct.scanCode) + ) + } +} + +pub struct KeyState { + pub kbdllstruct: KBDLLHOOKSTRUCT, + + pub shift_down: bool, + pub ctrl_down: bool, + pub win_down: bool, +} + +impl KeyState { + pub fn new() -> Box { + Box::new(Self { + kbdllstruct: KBDLLHOOKSTRUCT { + vkCode: 0, + scanCode: 0, + flags: 0, + time: 0, + dwExtraInfo: 0, + }, + shift_down: false, + ctrl_down: false, + win_down: false, + }) + } + + /// key_down: if the event was a keydown event, this should be true. if it was keyup it should be false + pub fn update(&mut self, key: KBDLLHOOKSTRUCT, key_down: bool) { + self.kbdllstruct = key; + + match key.vkCode { + 160 | 161 => self.shift_down = key_down, + 162 | 163 => self.ctrl_down = key_down, + 91 => self.win_down = key_down, + _ => {} + } + } + + /// true if the key is an auxiliary key like shift, control or the windows key + pub fn is_aux_key(&self) -> bool { + matches!(self.kbdllstruct.vkCode, 160 | 161 | 162 | 163 | 91) + } +} diff --git a/src/logging/loggers.rs b/src/logging/loggers.rs index 7a85aa1..2afa0e5 100644 --- a/src/logging/loggers.rs +++ b/src/logging/loggers.rs @@ -1,6 +1,4 @@ -use crate::logging::logger::Logger; -use winapi::um::winuser::KBDLLHOOKSTRUCT; -use crate::scan_code_to_key_name; +use crate::logging::logger::{Logger, KeyState}; use std::fs::{File, OpenOptions}; use std::io::Write; use std::path::Path; @@ -8,8 +6,8 @@ use std::sync::Mutex; pub struct ConsoleLogger; impl Logger for ConsoleLogger { - fn log(&self, key: &KBDLLHOOKSTRUCT) { - println!("{} >> {}", key.vkCode, scan_code_to_key_name(key.scanCode)); + fn log(&self, key: &KeyState) { + println!("{}", Logger::default_format(key)) } } @@ -30,7 +28,7 @@ impl FileLogger { } impl Logger for FileLogger { - fn log(&self, key: &KBDLLHOOKSTRUCT) { - self.file.lock().unwrap().write_all(format!("{} >> {}\n", key.vkCode, scan_code_to_key_name(key.scanCode)).as_ref()).unwrap(); + fn log(&self, key: &KeyState) { + self.file.lock().unwrap().write_all(Logger::default_format(key).as_ref()).unwrap(); } } diff --git a/src/main.rs b/src/main.rs index 8148065..2472edc 100644 --- a/src/main.rs +++ b/src/main.rs @@ -3,15 +3,16 @@ extern crate lazy_static; use std::env::args; use std::ptr::null_mut; +use std::sync::Mutex; use winapi::um::winuser::{GetMessageW, PKBDLLHOOKSTRUCT, SetWindowsHookExA}; -use jenslog_rs::logging::logger::{get_logger, Logger}; +use jenslog_rs::logging::logger::{get_logger, Logger, KeyState}; lazy_static! { - pub static ref LOGGER: Box = get_logger(&args().nth(1).unwrap_or_default()); + static ref KEYSTATE: Mutex> = Mutex::new(KeyState::new()); + static ref LOGGER: Box = get_logger(&args().nth(1).unwrap_or_default()); } -//static mut LOGGER: Box = get_logger(args().nth(0).map(|k| k.as_str())); fn main() { unsafe { @@ -21,9 +22,11 @@ fn main() { } unsafe extern "system" fn hook_callback(_code: i32, w_param: usize, l_param: isize) -> isize { - //Check if keydown - if w_param != 256 { return 0; } + let mut state = KEYSTATE.lock().unwrap(); let key = *(l_param as PKBDLLHOOKSTRUCT); - LOGGER.log(&key); + state.update(key, w_param == 256); + //Check if keydown and not aux key + if w_param != 256 || state.is_aux_key() { return 0; } + LOGGER.log(&state); 0 }