Ubuntu Cinnamon bude od Ubuntu 23.04 oficiální odnoží Ubuntu (návrh, schválení).
Byla vydána nová major verze 5.0 účetního softwaru GnuCash (Wikipedie). Ve formátu Flatpak je již k dispozici na Flathubu.
Na GOG.com běží Spring Sale. Při té příležitosti lze získat zdarma počítačovou hru Alwa's Awakening (ProtonDB).
Byla vydána verze 3.28.0 2D CAD (computer-aided design) softwaru QCAD (Wikipedie). Přehled novinek v Changelogu.
Změna ve vedení společnosti SUSE. Dosavadní CEO Melissa Di Donato odstoupila. Od 1. května je novým CEO Dirk-Peter van Leeuwen, bývalý Senior Vice President a General Manager ve společnosti Red Hat.
CyberChef je webová aplikace pro analýzu dat a jejich kódování a dekódování, šifrování a dešifrování, kompresi a dekompresi, atd. Často je využívaná při kybernetických cvičeních a CTF (Capture the Flag). Vydána byla nová major verze 10 (aktuálně 10.4.0). Přehled novinek v Changelogu.
UBports, nadace a komunita kolem Ubuntu pro telefony a tablety Ubuntu Touch, vydala Ubuntu Touch OTA-1 Focal založené na Ubuntu 20.04 Focal Fossa.
Společnost Red Hat slaví 30 let.
Ve věku 91 let zemřel izraelský informatik Ja'akov Ziv, spolutvůrce bezztrátových kompresních algoritmů LZ77, LZ78 a LZW (Lempel–Ziv–Welch).
Byla představena nová Arduino deska Arduino UNO R4 s 32bitovým MCU RA4M1 (Arm Cortex-M4). Desku lze zatím získat pouze v rámci early access programu.
#!/bin/bash NUM=1 # 1) ztratí hodnotu NUM # head -n 6 /proc/mounts | while read # 2) zde hodnotu NUM udrží... while [ $NUM -lt 5 ] do echo "NUM: "$NUM NUM=$((NUM+1)) done echo -- $NUMVýstup pro první a druhý případ vypadá takto:
alnagon ~ % alnagon ~ % ./scripts/01_pk_test_script.sh NUM: 1 NUM: 2 NUM: 3 NUM: 4 NUM: 5 -- 1 alnagon ~ % alnagon ~ % ./scripts/01_pk_test_script.sh NUM: 1 NUM: 2 NUM: 3 NUM: 4 NUM: 5 -- 6 alnagon ~ % alnagon ~ %Lze nějak docílit, aby hodnotu NUM zachoval i ve formě "while read" ?
Řešení dotazu:
head -n 6 /proc/mounts | while readTady neco chybi ne ?
prikaz | while read ...
sa spusta subshell a premenna NUM je inicializovana mimo tohto subshellu, takze na nu cokolvek co sa deje v subshelli ( v slucke s while ), nema ziadny dosledok. Nasledne nemusi fungovat v kazdom shelli, ale bash minimalne to podporuje. Je to sposob, ako zabranit, aby sa vytvoril subshell.
#!/bin/bash NUM=1 while read line do echo "NUM: "$NUM echo "$line" NUM=$((NUM+1)) done< <(head -n6 /proc/mounts) echo -- $NUM
Rovnako sa chovaju premenne aj vo funkciach, ak sa neexportuju.
Pravda s tym exportom, musim priznat. :)
Taktiez je mozne pouzit cisto declare namiesto local, aj ked logickejsie a osobne tiez pouzivam local, ak chcem lokalne premenne. To len na doplnenie, ze je to ekvivalent, nie na opravu tvojho tvrdenia. To je spravne. ;)
#!/bin/bash num=0 funkcia1(){ declare num num=$RANDOM echo num z funkcie1: $num } funkcia2(){ declare num num=$RANDOM echo num z funkcie2: $num } echo num: $num funkcia1 echo num: $num funkcia2 echo num: $num
Pajpa (teda |) spusta subshell, rovnako ako zatvorky. A subshell nemoze ovplyvnit to, co sa deje v "hlavnom" shelli.
Riesenim je pouzivat tu hodnotu len v subshelli, teda napr.
prikaz | while read VARIABLE; do echo "Tu mi premenna $VARIABLE funguje"; done
Tiskni
Sdílej: