# HG changeset patch # User Emmanuel Gil Peyrot # Date 1604240637 -3600 # Node ID d1972fc49a5bd8c677e93f0a8096bbcf315dbcd5 # Parent 51a6c86d314161a8b7173c133db3d856adf5cf08 Reorganise the code a bit. diff --git a/src/main.rs b/src/main.rs --- a/src/main.rs +++ b/src/main.rs @@ -15,8 +15,8 @@ // along with this program. If not, see . use gio::prelude::*; +use glib::clone; use gtk::prelude::*; -use glib::clone; use std::env::args; use std::fs::{File, OpenOptions}; @@ -216,7 +216,26 @@ struct State { pressed: bool, } -fn build_ui(application: >k::Application) { +impl State { + fn new() -> std::io::Result>> { + let dev = create_uinput_device()?; + println!( + "New device at {:?} ({:?})", + dev.evdev_path()?, + dev.sys_path()? + ); + + Ok(Arc::new(Mutex::new(State { + dev, + width: WIDTH as f64, + height: HEIGHT as f64, + selected_tool: Key::ButtonToolPen, + pressed: false, + }))) + } +} + +fn build_main_menu(application: >k::Application) { let quit = gio::SimpleAction::new("quit", None); application.set_accels_for_action("app.quit", &["q"]); application.add_action(&quit); @@ -233,7 +252,9 @@ fn build_ui(application: >k::Applicati about.set_license_type(gtk::License::Agpl30); about.set_copyright(Some("© 2020 Emmanuel Gil Peyrot ")); about.run(); - unsafe { about.destroy(); } + unsafe { + about.destroy(); + } }); let menu = gio::Menu::new(); @@ -248,9 +269,13 @@ fn build_ui(application: >k::Applicati menu.append_submenu(Some("_Help"), &help); } application.set_menubar(Some(&menu)); +} - let dev = match create_uinput_device() { - Ok(dev) => dev, +fn build_ui(application: >k::Application) { + build_main_menu(application); + + let state = match State::new() { + Ok(state) => state, Err(err) => { match err.kind() { ErrorKind::NotFound => { @@ -263,25 +288,11 @@ fn build_ui(application: >k::Applicati } _ => eprintln!("Couldn’t open /dev/uinput for writing: {}", err), } - return; + std::process::exit(1); } }; - println!( - "New device at {:?} ({:?})", - dev.evdev_path().unwrap(), - dev.sys_path().unwrap() - ); - - let state = Arc::new(Mutex::new(State { - dev, - width: WIDTH as f64, - height: HEIGHT as f64, - selected_tool: Key::ButtonToolPen, - pressed: false, - })); let window = gtk::ApplicationWindow::new(application); - window.set_title("tablet-emu"); window.set_position(gtk::WindowPosition::Center);