feat(core): improve notification handling

This commit is contained in:
Federico Terzi 2021-07-24 10:08:37 +02:00
parent e9d90929a6
commit adc13c707d
4 changed files with 30 additions and 7 deletions

View File

@ -110,6 +110,7 @@ fn daemon_main(args: CliModuleArgs) -> i32 {
&paths_overrides, &paths_overrides,
exit_notify.clone(), exit_notify.clone(),
&mut worker_run_count, &mut worker_run_count,
false,
); );
ipc::initialize_and_spawn(&paths.runtime, exit_notify.clone()) ipc::initialize_and_spawn(&paths.runtime, exit_notify.clone())
@ -159,7 +160,7 @@ fn daemon_main(args: CliModuleArgs) -> i32 {
} }
if !has_timed_out { if !has_timed_out {
spawn_worker(&paths, &paths_overrides, exit_notify.clone(), &mut worker_run_count); spawn_worker(&paths, &paths_overrides, exit_notify.clone(), &mut worker_run_count, false);
} else { } else {
error!("could not restart worker, as the exit process has timed out"); error!("could not restart worker, as the exit process has timed out");
} }
@ -174,7 +175,7 @@ fn daemon_main(args: CliModuleArgs) -> i32 {
} }
WORKER_RESTART => { WORKER_RESTART => {
info!("worker requested a restart, spawning a new one..."); info!("worker requested a restart, spawning a new one...");
spawn_worker(&paths, &paths_overrides, exit_notify.clone(), &mut worker_run_count); spawn_worker(&paths, &paths_overrides, exit_notify.clone(), &mut worker_run_count, true);
} }
_ => { _ => {
error!("received unexpected exit code from worker {}, exiting", code); error!("received unexpected exit code from worker {}, exiting", code);
@ -236,6 +237,7 @@ fn spawn_worker(
paths_overrides: &PathsOverrides, paths_overrides: &PathsOverrides,
exit_notify: Sender<i32>, exit_notify: Sender<i32>,
worker_run_count: &mut i32, worker_run_count: &mut i32,
manual_start: bool,
) { ) {
info!("spawning the worker process..."); info!("spawning the worker process...");
@ -265,12 +267,18 @@ fn spawn_worker(
}; };
let mut command = Command::new(&espanso_exe_path.to_string_lossy().to_string()); let mut command = Command::new(&espanso_exe_path.to_string_lossy().to_string());
command.args(&[
let string_worker_run_count = format!("{}", worker_run_count);
let mut args = vec![
"worker", "worker",
"--monitor-daemon", "--monitor-daemon",
"--run-count", "--run-count",
&format!("{}", worker_run_count), &string_worker_run_count
]); ];
if manual_start {
args.push("--manual");
}
command.args(&args);
command.with_paths_overrides(paths_overrides); command.with_paths_overrides(paths_overrides);
let mut child = command.spawn().expect("unable to spawn worker process"); let mut child = command.spawn().expect("unable to spawn worker process");

View File

@ -73,6 +73,7 @@ pub fn initialize_and_spawn(
secure_input_receiver: Receiver<SecureInputEvent>, secure_input_receiver: Receiver<SecureInputEvent>,
use_evdev_backend: bool, use_evdev_backend: bool,
run_count: i32, run_count: i32,
has_been_started_manually: bool,
) -> Result<JoinHandle<ExitMode>> { ) -> Result<JoinHandle<ExitMode>> {
let handle = std::thread::Builder::new() let handle = std::thread::Builder::new()
.name("engine thread".to_string()) .name("engine thread".to_string())
@ -215,8 +216,13 @@ pub fn initialize_and_spawn(
// TODO: check config // TODO: check config
match run_count { match run_count {
0 => ui_remote.show_notification("Espanso is running!"), 0 => ui_remote.show_notification("Espanso is running!"),
1 => ui_remote.show_notification("Configuration reloaded! Espanso automatically loads new changes as soon as you save them."), n => {
_ => {}, if has_been_started_manually {
ui_remote.show_notification("Configuration reloaded!");
} else if n == 1 {
ui_remote.show_notification("Configuration reloaded! Espanso automatically loads new changes as soon as you save them.");
}
},
} }
let mut engine = crate::engine::Engine::new(&funnel, &mut processor, &dispatcher); let mut engine = crate::engine::Engine::new(&funnel, &mut processor, &dispatcher);

View File

@ -67,6 +67,8 @@ fn worker_main(args: CliModuleArgs) -> i32 {
.unwrap_or(0); .unwrap_or(0);
debug!("starting with run-count = {:?}", cli_args); debug!("starting with run-count = {:?}", cli_args);
let has_been_started_manually = cli_args.is_present("manual");
// Avoid running multiple worker instances // Avoid running multiple worker instances
let lock_file = acquire_worker_lock(&paths.runtime); let lock_file = acquire_worker_lock(&paths.runtime);
if lock_file.is_none() { if lock_file.is_none() {
@ -129,6 +131,7 @@ fn worker_main(args: CliModuleArgs) -> i32 {
engine_secure_input_receiver, engine_secure_input_receiver,
use_evdev_backend, use_evdev_backend,
run_count, run_count,
has_been_started_manually,
) )
.expect("unable to initialize engine"); .expect("unable to initialize engine");

View File

@ -345,6 +345,12 @@ fn main() {
.required(false) .required(false)
.takes_value(true), .takes_value(true),
) )
.arg(
Arg::with_name("manual")
.long("manual")
.required(false)
.takes_value(false),
)
.arg( .arg(
Arg::with_name("monitor-daemon") Arg::with_name("monitor-daemon")
.long("monitor-daemon") .long("monitor-daemon")