Byłem w stanie użyć niektórych przykładów z tego samego artykułu na temat SO, zatytułowanego: Jak uzyskać pozycję kursora w bash? . Zamieszczam to tutaj tylko po to, aby pokazać, że działają i że zawartość rozwiązań jest również w U&L.
Rozwiązania Bash
Z wnętrza skryptu
#!/bin/bash
# based on a script from http://invisible-island.net/xterm/xterm.faq.html
exec < /dev/tty
oldstty=$(stty -g)
stty raw -echo min 0
# on my system, the following line can be replaced by the line below it
echo -en "\033[6n" > /dev/tty
# tput u7 > /dev/tty # when TERM=xterm (and relatives)
IFS=';' read -r -d R -a pos
stty $oldstty
# change from one-based to zero based so they work with: tput cup $row $col
row=$((${pos[0]:2} - 1)) # strip off the esc-[
col=$((${pos[1]} - 1))
echo "(row,col): $row,$col"
UWAGA: Lekko zmieniłem wyjście!
Przykład
$ ./rowcol.bash
(row,col): 43,0
$ clear
$ ./rowcol.bash
(row,col): 1,0
Interaktywna powłoka
Ten łańcuch poleceń pracował dla uzyskania pozycji wiersza i kolumny kursora:
$ echo -en "\E[6n";read -sdR CURPOS; CURPOS=${CURPOS#*[};echo "${CURPOS}"
Przykład
$ echo -en "\E[6n";read -sdR CURPOS; CURPOS=${CURPOS#*[};echo "${CURPOS}"
13;1
$ clear
$ echo -en "\E[6n";read -sdR CURPOS; CURPOS=${CURPOS#*[};echo "${CURPOS}"
2;1
UWAGA: Ta metoda nie wydaje się użyteczna z żadnego rodzaju skryptu. Nawet proste polecenia w interaktywnym terminalu nie działały dla mnie. Na przykład:
$ pos=$(echo -en "\E[6n";read -sdR CURPOS; CURPOS=${CURPOS#*[};echo "${CURPOS}")
po prostu zawiesza się na czas nieokreślony.
rozwiązania dash / sh
Z wnętrza skryptu
To rozwiązanie jest przeznaczone dla systemów Ubuntu / Debian, które są dostarczane z zapasami dash
, co jest zgodne z POSIX. Z tego powodu read
polecenie nie obsługuje -d
przełączania między innymi różnicami.
Aby obejść ten problem, istnieje rozwiązanie wykorzystujące sleep 1
zamiast -d
przełącznika. To nie jest idealne, ale oferuje przynajmniej działające rozwiązanie.
#!/bin/sh
exec < /dev/tty
oldstty=$(stty -g)
stty raw -echo min 0
tput u7 > /dev/tty
sleep 1
IFS=';' read -r row col
stty $oldstty
row=$(expr $(expr substr $row 3 99) - 1) # Strip leading escape off
col=$(expr ${col%R} - 1) # Strip trailing 'R' off
echo "(row,col): $col,$row"
Przykład
$ ./rowcol.sh
(row,col): 0,24
$ clear
$ ./rowcol.sh
(row,col): 0,1
Interaktywna powłoka
Nie mogłem znaleźć wykonalnego rozwiązania, które działałoby tylko sh
w interaktywnej powłoce.