Add bracketed paste support

This commit is contained in:
Mikayla Maki 2022-07-15 19:01:08 -07:00
parent cfc956d78f
commit 8349ead6b2
2 changed files with 13 additions and 2 deletions

View file

@ -7,7 +7,7 @@ use alacritty_terminal::{
event_loop::{EventLoop, Msg, Notifier}, event_loop::{EventLoop, Msg, Notifier},
grid::Scroll, grid::Scroll,
sync::FairMutex, sync::FairMutex,
term::SizeInfo, term::{SizeInfo, TermMode},
tty::{self, setup_env}, tty::{self, setup_env},
Term, Term,
}; };
@ -228,6 +228,17 @@ impl TerminalConnection {
false false
} }
} }
///Paste text into the terminal
pub fn paste(&mut self, text: &str) {
if self.term.lock().mode().contains(TermMode::BRACKETED_PASTE) {
self.write_to_pty("\x1b[200~".to_string());
self.write_to_pty(text.replace('\x1b', "").to_string());
self.write_to_pty("\x1b[201~".to_string());
} else {
self.write_to_pty(text.replace("\r\n", "\r").replace('\n', "\r"));
}
}
} }
impl Drop for TerminalConnection { impl Drop for TerminalConnection {

View file

@ -191,7 +191,7 @@ impl Terminal {
fn paste(&mut self, _: &Paste, cx: &mut ViewContext<Self>) { fn paste(&mut self, _: &Paste, cx: &mut ViewContext<Self>) {
if let Some(item) = cx.read_from_clipboard() { if let Some(item) = cx.read_from_clipboard() {
self.connection.update(cx, |connection, _| { self.connection.update(cx, |connection, _| {
connection.write_to_pty(item.text().to_owned()); connection.paste(item.text());
}) })
} }
} }