1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44
//! > **Kitty remote command bindings for rust**
//!
//! This crate provides access to the Kitty terminal's remote control functionality. At the moment
//! this is achieved ! by creating `std::process::Command` objects through a convenient API interface.
//!
//! ## Examples:
//!
//! Send text to Window 1
//! ```
//! use std::process::Command;
//!
//! use kitty_remote_bindings::{Matcher, MatcherExt, SendText, model::WindowId};
//!
//! let mut send_text = SendText::new(r#"echo "Hello world""#.to_string());
//! send_text.matcher(Matcher::Id(WindowId(2)));
//!
//! Command::from(&send_text)
//! .status()
//! .expect("failed to execute send-text");
//! ```
pub mod model;
mod remote_command;
pub use remote_command::CommandOutput;
pub use remote_command::options::Matcher;
pub use remote_command::options::MatcherExt;
pub use remote_command::focus_window::FocusWindow;
pub use remote_command::ls::Ls;
pub use remote_command::send_text::SendText;
pub type Result<T> = std::result::Result<T, Error>;
#[derive(Debug, thiserror::Error)]
pub enum Error {
#[error("I/O error")]
IoError(#[from] std::io::Error),
#[error("JsonDecoding error")]
JsonDecodingError(#[from] serde_json::Error),
#[error("The sub-process `{0}` exited with a non zero status")]
ErrorExit(String),
}