96 lines
2.4 KiB
Rust
96 lines
2.4 KiB
Rust
#![allow(dead_code, unused_variables)]
|
|
|
|
use log::{debug, error, info, trace, warn};
|
|
use log4rs::{
|
|
append::{console::ConsoleAppender, file::FileAppender},
|
|
config::{Appender, Root},
|
|
encode::pattern::PatternEncoder,
|
|
Config,
|
|
};
|
|
use state::WMConfig;
|
|
|
|
mod backends;
|
|
mod clients;
|
|
//mod clients2;
|
|
mod state;
|
|
mod util;
|
|
mod xlib;
|
|
|
|
pub mod error {
|
|
use thiserror::Error;
|
|
|
|
#[derive(Debug, Error)]
|
|
pub enum Error {
|
|
#[error("placeholder error for Result<T> as Option<T>")]
|
|
NonError,
|
|
#[error("Unknown Event")]
|
|
UnknownEvent,
|
|
#[error("Unhandled VirtualKeyCode")]
|
|
UnhandledVirtualKeyCode,
|
|
#[error(transparent)]
|
|
IoError(#[from] std::io::Error),
|
|
#[error(transparent)]
|
|
FmtError(#[from] std::fmt::Error),
|
|
#[error(transparent)]
|
|
XlibError(#[from] crate::backends::xlib::XlibError),
|
|
}
|
|
}
|
|
|
|
fn init_logger() {
|
|
let encoder = Box::new(PatternEncoder::new(
|
|
"{d(%Y-%m-%d %H:%M:%S %Z)(utc)} │ {({M}::{f}:{L}):>25} │ {h({l:>5})} │ {m}{n}",
|
|
));
|
|
|
|
let stdout = ConsoleAppender::builder().encoder(encoder.clone()).build();
|
|
|
|
let home = dirs::home_dir().expect("Failed to get $HOME env var.");
|
|
|
|
let _logfile = FileAppender::builder()
|
|
.encoder(encoder)
|
|
.build(home.join(".local/portlights.log"))
|
|
.unwrap();
|
|
|
|
let config = Config::builder()
|
|
.appender(Appender::builder().build("stdout", Box::new(stdout)))
|
|
//.appender(Appender::builder().build("logfile", Box::new(logfile)))
|
|
.build(
|
|
Root::builder()
|
|
.appender("stdout")
|
|
//.appender("logfile")
|
|
.build(log::LevelFilter::Info),
|
|
)
|
|
.unwrap();
|
|
|
|
log4rs::init_config(config).unwrap();
|
|
}
|
|
|
|
fn main() {
|
|
init_logger();
|
|
|
|
log_prologue();
|
|
|
|
state::WindowManager::<backends::xlib::XLib>::new(WMConfig::default())
|
|
.run();
|
|
}
|
|
|
|
fn log_prologue() {
|
|
info!("========================================================================");
|
|
info!("Portlights Window Manager");
|
|
info!("Version: {}", env!("CARGO_PKG_VERSION"));
|
|
info!("Warning levels:");
|
|
info!("Info!");
|
|
warn!("Warning!");
|
|
debug!("Debug!");
|
|
error!("Error!");
|
|
trace!("Trace!");
|
|
info!("========================================================================");
|
|
}
|
|
|
|
#[test]
|
|
fn test_logger() {
|
|
init_logger();
|
|
// asdf
|
|
|
|
log_prologue();
|
|
}
|