Uroš Popović v krátkém článku vysvětluje, co jsou emulátor terminálu, TTY a shell a jaké jsou mezi nimi rozdíly. Jde o první díl seriálu na jeho novém webu Linux Field Guide věnovaném nízkoúrovňové práci s linuxovými systémy.
Byl vydán Debian 13.5, tj. pátá opravná verze Debianu 13 s kódovým názvem Trixie a Debian 12.14, tj. čtrnáctá opravná verze Debianu 12 s kódovým názvem Bookworm. Řešeny jsou především bezpečnostní problémy, ale také několik vážných chyb. Instalační média Debianu 13 a Debianu 12 lze samozřejmě nadále k instalaci používat. Po instalaci stačí systém aktualizovat.
CiviCRM (Wikipedie) bylo vydáno v nové verzi 6.14.0. Podrobnosti o nových funkcích a opravách najdete na release stránce. CiviCRM je robustní open-source CRM systém navržený speciálně pro neziskové organizace, spolky a občanské iniciativy. Projekt je napsán v jazyce PHP a licencován pod GNU Affero General Public License (AGPLv3). Český překlad má nyní 45 % přeložených řetězců a přibližuje se milníku 50 %. Potřebujeme vaši pomoc, abychom se dostali dál. Pokud máte chuť přispět překladem nebo korekturou, přidejte se na platformu Transifex.
Další lokální zranitelností Linuxu je ssh-keysign-pwn. Uživatel si může přečíst obsah souborů, ke kterým má právo ke čtení pouze root, například soubory s SSH klíči nebo /etc/shadow. V upstreamu již opraveno [oss-security mailing list].
Singularity (YouTube) je nejnovější otevřený film od Blender Studia. Jedná se o jejich první 4K HDR film.
Vyšla hra Život Není Krásný: Poslední Exekuce (Steam, ProtonDB). Kreslená point & click adventura ze staré školy plná černého humoru a nekorektního násilí. Vžijte se do role zpustlého exekutora Vladimíra Brehowského a projděte s ním jeho poslední pracovní den. Hra volně navazuje na sérii Život Není Krásný.
Společnost Red Hat představila Fedora Hummingbird, tj. linuxovou distribuci s nativním kontejnerovým designem určenou pro vývojáře využívající AI agenty.
Hru The Legend of Zelda: Twilight Princess od společnosti Nintendo si lze nově díky projektu Dusklight (původně Dusk) a reverznímu inženýrství zahrát i na počítačích a mobilních zařízeních. Vyžadována je kopie původní hry (textury, modely, hudba, zvukové efekty, …). Ukázka na YouTube. Projekt byl zahájen v srpnu 2020.
Byla vydána nová major verze 29.0 programovacího jazyka Erlang (Wikipedie) a související platformy OTP (Open Telecom Platform, Wikipedie). Detailní přehled novinek na GitHubu.
Po zranitelnostech Copy Fail a Dirty Frag přichází zranitelnost Fragnesia. Další lokální eskalace práv na Linuxu. Zatím v upstreamu neopravena. Přiřazeno ji bylo CVE-2026-46300.
Řešení dotazu:
Nějak nerozumim kde je problém. Pár IF a je hotovo ne. Zkus se rozepsat pro co to vlastně chceš popřípadě vložit kód co máš. Nerozumim tomu co ti nejde.
#!/bin/bash
ttt=("aaa" "bbb" "ccc" "ddd" "eee" "fff" "ggg" "hhh" "iii" "jjj")
sel=0
sum=${#itm[@]}
max=5
while [ 1 ]
do
clear
for ((i=0; i<$max; i++ ))
do
if [ $sel = $i ]
then
echo -e "\e[5;31m ${ttt[i]} \e[0m"
else
echo "${ttt[i]}"
fi
done
#sel=$((sel-1))
sel=$((sel+1))
sleep 1
done
Tohle ? (Pohyb kurzorovejma klávesama UP/DOWN) ESC konec
#!/bin/bash
ttt=("aaa" "bbb" "ccc" "ddd" "eee" "fff" "ggg" "hhh" "iii" "jjj")
sel=0
sum=${#itm[@]}
max=10
while [ 1 ]
do
clear
for ((i=0; i<$max; i++ ))
do
if [ $sel = $i ]
then
echo -e "\e[5;31m ${ttt[i]} \e[0m"
else
echo "${ttt[i]}"
fi
done
echo $k
read -sn1 -t1 c
l=`perl -e "printf('%d',ord('$c'));"`
k="$l"
if ((k == 66)) && ((sel < max -1 )) ; then
let sel++
fi
if ((k == 65)) && ((sel > 0)); then
let sel--
fi
if ((k == 27)) ; then
break
fi
done
Teda tohle UP/DOWN a stop je ctrl+c
#!/bin/bash
ttt=("aaa" "bbb" "ccc" "ddd" "eee" "fff" "ggg" "hhh" "iii" "jjj")
sel=0
sum=${#itm[@]}
max=10
while [ 1 ]
do
clear
for ((i=0; i<$max; i++ ))
do
if [ $sel = $i ]
then
echo -e "\e[5;31m ${ttt[i]} \e[0m"
else
echo "${ttt[i]}"
fi
done
read -sn1 -t1 c
l=`perl -e "printf('%d',ord('$c'));"`
k="$l"
if ((k == 66)) && ((sel < max -1 )) ; then
let sel++
fi
if ((k == 65)) && ((sel > 0)); then
let sel--
fi
No ještě jedna verze (vypisuje jen 5 ale roluje)
#!/bin/bash
ttt=("aaa" "bbb" "ccc" "ddd" "eee" "fff" "ggg" "hhh" "iii" "jjj")
sel=0
sum=${#ttt[@]}
max=5
pos=0
while [ 1 ]
do
clear
for ((i=$pos; i<($pos+$max); i++ ))
do
if [ $sel = $i ]
then
echo -e "\e[5;31m ${ttt[i]} \e[0m"
else
echo "${ttt[i]}"
fi
done
read -sn1 -t1 c
l=`perl -e "printf('%d',ord('$c'));"`
k="$l"
if ((k == 66)) && ((sel < (sum -1) )) ; then
let sel++
if (((pos +5) < sum)); then
let pos++
fi
fi
if ((k == 65)) && ((sel > 0)); then
let sel--
if (( (pos ) > 0 )); then
let pos--
fi
fi
done
Spustím program a dostanu výsledek >1111111111< 2222222222 3333333333 4444444444 5555555555 stisk klávesy dolů, výsledek 1111111111 >2222222222< 3333333333 4444444444 5555555555 stisk klávesy dolů, výsledek 1111111111 2222222222 >3333333333< 4444444444 5555555555 stisk klávesy dolů, výsledek 1111111111 2222222222 3333333333 >4444444444< 5555555555 stisk klávesy dolů, výsledek 1111111111 2222222222 3333333333 4444444444 >5555555555< stisk klávesy dolů, ted prijde zmena výsledek 2222222222 3333333333 4444444444 5555555555 >6666666666< stisk klávesy dolů, výsledek, tohle se opakuje až po poslední položku 3333333333 4444444444 5555555555 6666666666 >7777777777< *********************************** ted stisk klávesy nahoru, výsledek *********************************** 3333333333 4444444444 5555555555 >6666666666< 7777777777 stisk klávesy nahoru, výsledek 3333333333 4444444444 >5555555555< 6666666666 7777777777 stisk klávesy nahoru, výsledek 3333333333 >4444444444< 5555555555 6666666666 7777777777 stisk klávesy nahoru, výsledek >3333333333< 4444444444 5555555555 6666666666 7777777777 stisk klávesy nahoru, ted prijde zmena výsledek >2222222222< 3333333333 4444444444 5555555555 6666666666 stisk klávesy nahoru, výsledek >1111111111< 2222222222 3333333333 4444444444 5555555555Děkuji
Tady ?
#!/bin/bash
ttt=("aaa" "bbb" "ccc" "ddd" "eee" "fff" "ggg" "hhh" "iii" "jjj")
sel=0
sum=${#ttt[@]}
max=5
pos=0
center=0
while [ 1 ]
do
clear
for ((i=$pos; i<($pos+$max); i++ ))
do
if [ $sel = $i ]
then
echo -e ">\e[5;31m${ttt[i]}\e[0m<"
else
echo " ${ttt[i]} "
fi
done
read -sn1 -t1 c
l=`perl -e "printf('%d',ord('$c'));"`
k="$l"
if ((k == 66)) && ((sel < (sum -1) )) ; then
let sel++
if ((center < max)); then
let center++
fi
if ((center == max )) && (((pos +5) < sum)); then
let pos++
fi
fi
if ((k == 65)) && ((sel > 0)); then
let sel--
if ((center > 0)); then
let center--
fi
if ((center == 0 )) && (( (pos ) > 0 )); then
let pos--
fi
fi
done
a číslo účtu??
To je nekonečná práce , přidat ještě tunu IF proti všem možnejm kombinacím , přidat ( http://www.bashguru.com/2010/04/how-to-handle-cursor-movement-in-shell.html ) pozici zobrazení , orámování , a stále bude co vylepšovat. Nakonec to raději udělá někdo za pomoci ncurses v céčku. :)
Ať to čtu jak to čtu stále nevím co vlastně chcete ...
Zkuste svůj požadavek upřesnit.
Hodnotu těch proměnných echo $prommena si můžete vypsat. Nebo nechápete princip ? O co jde ?
Nebo jdi sem , pokud tam budu nebo někdo bude : http://cz3dtc.cz/linux.htm
Aha , celej kód je naprd , oprava bude : http://pastebin.com/9etQa14z
Teda až to předělam.
Děkuji za informace Veroniky která vyšťourala že je to celé na prd :)
Tak zde je opravená verze :
#!/bin/bash
start=1
clear
tput civis -- invisible
trap "stty $(stty -g)" EXIT
stty -echo -icanon time 2 || exit $?
KEYS="" ; IFS=$'\a'
ttt=("Volba 1" "Volba 2" "Volba 3" "Volba 4" "Volba 5" "Volba 6" "Volba 7" "Volba 8" "Volba 9" "Volba 10" "Volba 11" "Volba 12" "Volba 13" "Volba 14" "Volba 15")
ap=0; let start--
pp=${#ttt[@]}
mp=5
if ((pp < mp)) ; then let mp=pp ; fi
posun_seznamu=0
center=0
acc=5
function zobraz ()
{
let tmpap=ap ; let tmpap++
echo -en "\033[1;1H"
echo "ESC = Konec , ENTER = výběr volby"
let posa=$posun_seznamu ; let posb=($posun_seznamu+$mp)
let posa=($posa + $center) ; let posb=($posb + $center)
echo -e "\033[1m\033[46m \e[0m"
for ((i=$posa; i<($posb); i++ ))
do
if [ $ap = $i ]
then
echo -e "\033[1m\033[46m \e[0m\033[1m\033[44m${ttt[i]}\e[0m\033[1m\033[46m \e[0m"
else
echo -e "\033[1m\033[46m \e[0m\033[30m\033[47m${ttt[i]}\e[0m\033[1m\033[46m \e[0m"
fi
done
echo -e "\033[1m\033[46m \e[0m"
}
for ((l=0; l<($start); l++ ))
do
zobraz
if ((ap < (pp -1 ) )) ; then
let ap++
if (((center + (mp -1)) < ap)) ; then let center++ ; fi
fi
done
zobraz
while [ 1 ]; do
while read -t 0 ; do read -s -r -d "" -N 1 -t 0.2 CHAR && KEYS="$KEYS$CHAR" || break
done
if [ -z "$KEYS" ]; then sleep 0.05 ; continue ; fi
case "$KEYS" in
$'\x1B\x5B\x42'*)
KEYS="${KEYS##???}"
if ((ap < (pp -1 ) )) ; then
let ap++
if (((center + (mp -1)) < ap)) ; then let center++ ; fi
fi
zobraz
;;
$'\x1B\x5B\x41'*)
KEYS="${KEYS##???}"
if ((ap > 0)); then
let ap--
if ((ap < posa )) ; then let center-- ; fi
fi
zobraz
;;
$'\n'*|$'\r'*)
KEYS="${KEYS##?}"
echo "Vybraná položka : ${ttt[ap]} "
tput cnorm -- normal
exit 0
;;
$'\x1B')
KEYS="${KEYS##?}"
echo "Program ukončen ..."
tput cnorm -- normal
exit 0
;;
[$'\x01'-$'\x1F'$'\x7F']*)
KEYS="${KEYS##?}"
;;
*)
KEY="${KEYS:0:1}"
KEYS="${KEYS#?}"
;;
esac
done
Tiskni
Sdílej: