iced_term
iced_term copied to clipboard
Terminal emulator widget powered by ICED framework and alacritty terminal backend.
data:image/s3,"s3://crabby-images/683a7/683a7c235e317cb023e48224422f484cd2205668" alt=""
iced_term
Terminal emulator widget powered by ICED framework and alacritty terminal backend.
data:image/s3,"s3://crabby-images/e7d05/e7d0579af905bf17f8ff135ee500df8bc97c5d51" alt=""
data:image/s3,"s3://crabby-images/aa06c/aa06c3a40d7c196bed6917201935d850643ba7c7" alt=""
Features
The widget is currently under development and does not provide full terminal features make sure that widget is covered everything you want.
- PTY content rendering
- Multiple instance support
- Basic keyboard input
- Adding custom keyboard or mouse bindings
- Resizing
- Scrolling
- Focusing
- Selecting
- Changing Font/Color scheme
- Hyperlinks processing (hover/open)
This widget tested on MacOS and Linux and is not tested on Windows.
Installation
iced_term = "0.4.0"
Overview
Interacting with the widget is happened via:
Commands - you can send commands to widget for changing the widget state.
#[derive(Debug, Clone)]
pub enum Command {
InitBackend(Sender<alacritty_terminal::event::Event>),
ChangeTheme(Box<ColorPalette>),
ChangeFont(FontSettings),
AddBindings(Vec<(Binding<InputKind>, BindingAction)>),
ProcessBackendCommand(BackendCommand),
}
Events - widget is produced some events that can be handled in application. Every event has the first u64
argument that is terminal instance id.
#[derive(Debug, Clone)]
pub enum Event {
CommandReceived(u64, Command),
}
Right now there is the only internal CommandReceived event that is needed for backend <-> view communication. You can also handle this event unwrap the command and process command additionally if you want.
Actions - widget's method update(&mut self, cmd: Command)
returns Action that you can handle after widget updated.
#[derive(Debug, Clone, PartialEq)]
pub enum Action {
Redraw,
Shutdown,
ChangeTitle,
Ignore,
}
For creating workable widget instance you need to do a few steps:
Add widget to your app struct
struct App {
term: iced_term::Term,
}
Create pure instance in app constructor
impl Application for App {
type Executor = executor::Default;
type Message = Message;
type Theme = Theme;
type Flags = ();
fn new(_flags: ()) -> (Self, Command<Message>) {
let system_shell = std::env::var("SHELL")
.expect("SHELL variable is not defined")
.to_string();
let term_id = 0;
let term_settings = iced_term::TermSettings {
font: iced_term::FontSettings {
size: 14.0,
..iced_term::FontSettings::default()
},
theme: iced_term::ColorPalette::default(),
backend: iced_term::BackendSettings {
shell: system_shell.to_string(),
},
};
(
Self {
term: iced_term::Term::new(term_id, term_settings.clone()),
},
Command::none(),
)
}
}
Add message that contained widget events to application message enum
#[derive(Debug, Clone)]
pub enum Message {
// ... other messages
IcedTermEvent(iced_term::Event),
}
Add IcedTermEvent processing to application update
method
impl Application for App {
// ... other methods
fn update(&mut self, message: Self::Message) -> Command<Message> {
match message {
Message::IcedTermEvent(iced_term::Event::CommandReceived(
_,
cmd,
)) => match self.term.update(cmd) {
iced_term::actions::Action::Shutdown => window::close(),
_ => Command::none(),
},
}
}
}
Add view to your application
impl Application for App {
// ... other methods
fn view(&self) -> Element<Message, iced::Renderer> {
container(iced_term::term_view(&self.term).map(Message::IcedTermEvent))
.width(Length::Fill)
.height(Length::Fill)
.into()
}
}
Activate backend events subscription in your app
impl Application for App {
// ... other methods
fn subscription(&self) -> Subscription<Message> {
self.term.subscription().map(Message::IcedTermEvent)
}
}
Make main func
fn main() -> iced::Result {
App::run(Settings {
window: window::Settings {
size: (1280, 720),
..window::Settings::default()
},
..Settings::default()
})
}
Run your application
cargo run --release
Examples
You can also look at examples directory for more information about widget using.
- full_screen - The basic example of terminal emulator.
- split_view - The example based on split_view iced widget that show how multiple instance feature work.
- custom_bindings - The example that show how you can add custom keyboard or mouse bindings to your terminal emulator app.
- themes - The example that show how you can change terminal color scheme.
- fonts - The examples that show how you can change font type or font size in your terminal emulator app.