cli: add command to restart the compositor in place
This commit is contained in:
parent
fd1e260877
commit
2edfb29f2b
8 changed files with 186 additions and 3 deletions
|
|
@ -12,6 +12,7 @@ use {
|
|||
jay_output::JayOutput,
|
||||
jay_pointer::JayPointer,
|
||||
jay_randr::JayRandr,
|
||||
jay_reexec::JayReexec,
|
||||
jay_render_ctx::JayRenderCtx,
|
||||
jay_screencast::JayScreencast,
|
||||
jay_screenshot::JayScreenshot,
|
||||
|
|
@ -73,7 +74,7 @@ impl Global for JayCompositorGlobal {
|
|||
}
|
||||
|
||||
fn version(&self) -> u32 {
|
||||
16
|
||||
17
|
||||
}
|
||||
|
||||
fn required_caps(&self) -> ClientCaps {
|
||||
|
|
@ -456,6 +457,19 @@ impl JayCompositorRequestHandler for JayCompositor {
|
|||
self.client.add_client_obj(&obj)?;
|
||||
Ok(())
|
||||
}
|
||||
|
||||
fn reexec(&self, req: Reexec, _slf: &Rc<Self>) -> Result<(), Self::Error> {
|
||||
let obj = Rc::new(JayReexec {
|
||||
id: req.id,
|
||||
client: self.client.clone(),
|
||||
tracker: Default::default(),
|
||||
version: self.version,
|
||||
args: Default::default(),
|
||||
});
|
||||
track!(self.client, obj);
|
||||
self.client.add_client_obj(&obj)?;
|
||||
Ok(())
|
||||
}
|
||||
}
|
||||
|
||||
object_base! {
|
||||
|
|
|
|||
67
src/ifs/jay_reexec.rs
Normal file
67
src/ifs/jay_reexec.rs
Normal file
|
|
@ -0,0 +1,67 @@
|
|||
use {
|
||||
crate::{
|
||||
client::{Client, ClientError},
|
||||
leaks::Tracker,
|
||||
object::{Object, Version},
|
||||
utils::oserror::OsError,
|
||||
wire::{JayReexecId, jay_reexec::*},
|
||||
},
|
||||
std::{cell::RefCell, rc::Rc},
|
||||
thiserror::Error,
|
||||
uapi::UstrPtr,
|
||||
};
|
||||
|
||||
pub struct JayReexec {
|
||||
pub id: JayReexecId,
|
||||
pub client: Rc<Client>,
|
||||
pub tracker: Tracker<Self>,
|
||||
pub version: Version,
|
||||
pub args: RefCell<Vec<String>>,
|
||||
}
|
||||
|
||||
impl JayReexec {
|
||||
fn send_failed(&self, msg: &str) {
|
||||
self.client.event(Failed {
|
||||
self_id: self.id,
|
||||
msg,
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
impl JayReexecRequestHandler for JayReexec {
|
||||
type Error = JayReexecError;
|
||||
|
||||
fn arg(&self, req: Arg<'_>, _slf: &Rc<Self>) -> Result<(), Self::Error> {
|
||||
self.args.borrow_mut().push(req.arg.to_owned());
|
||||
Ok(())
|
||||
}
|
||||
|
||||
fn exec(&self, req: Exec<'_>, _slf: &Rc<Self>) -> Result<(), Self::Error> {
|
||||
let args = self.args.borrow();
|
||||
let mut args2 = UstrPtr::new();
|
||||
args2.push(req.path);
|
||||
for arg in &*args {
|
||||
args2.push(&**arg);
|
||||
}
|
||||
if let Err(e) = uapi::execvp(req.path, &args2) {
|
||||
self.send_failed(&OsError(e.0).to_string());
|
||||
}
|
||||
Ok(())
|
||||
}
|
||||
}
|
||||
|
||||
object_base! {
|
||||
self = JayReexec;
|
||||
version = self.version;
|
||||
}
|
||||
|
||||
impl Object for JayReexec {}
|
||||
|
||||
simple_add_obj!(JayReexec);
|
||||
|
||||
#[derive(Debug, Error)]
|
||||
pub enum JayReexecError {
|
||||
#[error(transparent)]
|
||||
ClientError(Box<ClientError>),
|
||||
}
|
||||
efrom!(JayReexecError, ClientError);
|
||||
Loading…
Add table
Add a link
Reference in a new issue