This commit is contained in:
2024-10-18 22:19:09 +02:00
parent a850f644de
commit ece099b6a4
11 changed files with 1056 additions and 229 deletions

View File

@@ -1,4 +1,4 @@
#!/bin/bash
#!/usr/bin/env bash
trap clean_up EXIT
trap clean_up INT
@@ -23,7 +23,7 @@ function show_help() {
# <sequence> ST, and for all ESCs in <sequence> to be replaced with ESC ESC. It
# only accepts ESC backslash for ST.
function print_osc() {
if [[ $TERM == screen* ]] ; then
if [[ $TERM == screen* || $TERM == tmux* ]] ; then
printf "\033Ptmux;\033\033]"
else
printf "\033]"
@@ -32,13 +32,52 @@ function print_osc() {
# More of the tmux workaround described above.
function print_st() {
if [[ $TERM == screen* ]] ; then
if [[ $TERM == screen* || $TERM == tmux* ]] ; then
printf "\a\033\\"
else
printf "\a"
fi
}
send_tmux() {
uid=$RANDOM$RANDOM
print_osc
inosc=1
printf '1337;Copy=2;%s' "$uid"
print_st
inosc=0
fold | while read line
do
print_osc
inosc=1
printf '1337;Copy=3;%s:%s' "$uid" "$line"
print_st
inosc=0
done
print_osc
inosc=1
printf '1337;Copy=4;%s' "$uid"
print_st
inosc=0
}
send_regular() {
print_osc
inosc=1
printf '1337;Copy=:%s' "$data"
print_st
inosc=0
}
send() {
if [[ $TERM == tmux* ]]; then
send_tmux
else
send_regular
fi
}
# Look for command line flags.
while [ $# -gt 0 ]; do
case "$1" in
@@ -53,12 +92,7 @@ while [ $# -gt 0 ]; do
;;
*)
if [ -r "$1" ] ; then
data=$(base64 < "$1")
print_osc
inosc=1
printf '1337;Copy=:%s' "$data"
print_st
inosc=0
base64 < $1 | send
exit 0
else
error "it2copy: $1: No such file or directory"
@@ -69,10 +103,4 @@ while [ $# -gt 0 ]; do
shift
done
data=$(base64)
print_osc
inosc=1
printf '1337;Copy=:%s' "$data"
print_st
inosc=0
base64 | send