Dnešním dnem lze již také v Česku nakupovat na Google Store (telefony a sluchátka Google Pixel).
Apple představil (keynote) iPad Pro s čipem Apple M4, předělaný iPad Air ve dvou velikostech a nový Apple Pencil Pro.
Richard Biener oznámil vydání verze 14.1 (14.1.0) kolekce kompilátorů pro různé programovací jazyky GCC (GNU Compiler Collection). Jedná se o první stabilní verzi řady 14. Přehled změn, nových vlastností a oprav a aktualizovaná dokumentace na stránkách projektu. Některé zdrojové kódy, které bylo možné přeložit s předchozími verzemi GCC, bude nutné upravit.
Free Software Foundation zveřejnila ocenění Free Software Awards za rok 2023. Vybráni byli Bruno Haible za dlouhodobé příspěvky a správu knihovny Gnulib, nováček Nick Logozzo za front-end Parabolic pro yt-dlp a tým Mission logiciels libres francouzského státu za nasazování svobodného softwaru do praxe.
Před 10 lety Microsoft dokončil akvizici divize mobilních telefonů společnosti Nokia a pod značkou Microsoft Mobile ji zanedlouho pohřbil.
Fedora 40 release party v Praze proběhne v pátek 17. května od 18:30 v prostorách společnosti Etnetera Core na adrese Jankovcova 1037/49, Praha 7. Součástí bude program kratších přednášek o novinkách ve Fedoře.
Stack Overflow se dohodl s OpenAI o zpřístupnění obsahu Stack Overflow pro vylepšení OpenAI AI modelů.
AlmaLinux byl vydán v nové stabilní verzi 9.4 (Mastodon, 𝕏). S kódovým názvem Seafoam Ocelot. Přehled novinek v příspěvku na blogu a v poznámkách k vydání.
Před 50 lety, 5. května 1974 v žurnálu IEEE Transactions on Communications, Vint Cerf a Bob Kahn popsali protokol TCP (pdf).
Bylo vydáno do češtiny přeložené číslo 717 týdeníku WeeklyOSM přinášející zprávy ze světa OpenStreetMap.
TEXT="/etc/apache2/host|/tmp/apache2/host"
Řešení dotazu:
${TEXT%|*}
a ${TEXT#*|}
Případně obecněji pro libovolný počet částí: IFS='|' toks=($TEXT); echo "${toks[0]}, ${toks[1]}, ..."
(mezi nastavením IFS a přiřazením poli nemá být ani konec řádku, ani středník, aby se po přiřazení zachovalo původní IFS).
TEXT="/etc/apache2/host|/tmp/apache2/host|/var/apache2/host"
IFS="|" for READ in $(cat /tmp/data.txt) do TOKS=($READ) ${TOKS[0]} ${TOKS[1]} ${TOKS[2]} done
mezi nastavením IFS a přiřazením poli nemá být ani konec řádku, ani středník, aby se po přiřazení zachovalo původní IFS.
Rejp, tohle neplatí, nezachová se. Pokud v jednoduchém příkazu není nic jiného než přiřazení (a přesměrování), mění všechna proměnné aktuálního shellu (viz man bash, Simple Command Expansion). (Pokud je, nezmění se žádná z nich.)
I další doteď uvedené příklady změní IFS shellu, což si lze snadno ověřit skrze:set|grep IFS
, příp. povšimnout si na jaká slova se nadále expanduje proměnná TEXT: kupř. pomocí echo $TEXT "$TEXT"
(dělení slov dle $IFS
není totéž a tehdy, kdy se rozpoznávají jednotlivá slova-tokeny (ty v bashi vždy oddělují znaky: | & ; ( ) < > space tab
)).
LANG=POSIX df dfPrvní příkaz se vypíše v POSIXu, druhý zase s původní lokalizací.
a=b c=dcož skutečně není globální přiřazení c=d s lokálním nastavením a=b, ale globální přiřazení do c i a. Takže to IFS by se mělo raději nastavovat jinde...
TEXT="/etc/apache2/host|/tmp/apache2/host" echo "Old IFS: $IFS" IFS='|' toks=($TEXT); echo "${toks[0]}, ${toks[1]}, ..." echo "New IFS: $IFS"
Old IFS: /etc/apache2/host, /tmp/apache2/host, ... New IFS: |
moje() { local IFS=\|; toks=($TEXT);}
prirad() { local IFS=$1; eval $2=\(\$$3\);}
prirad \| toks TEXT
prirad() { [ $# -eq 3 ] || return 1; local IFS=$1; eval $2=\(\$$3\);}
prirad() { [[ $# -eq 3 ]] || return 1; IFS=$1 eval $2=\(\$$3\);}
ráno (někdy i může být) moudřejší večera :)
bash$ [ 1 < 2 ] && echo ok bash: 2: No such file or directory bash$ [ 1 \< 2 ] && echo ok ok bash$ [[ 1 < 2 ]] && echo ok ok bash$ a="1 2" bash$ [ $a = "1 2" ] && echo ok bash: [: too many arguments bash$ [ "$a" = "1 2" ] && echo ok ok bash$ [[ $a == "1 2" ]] && echo ok ok bash$ [[ "$a" =~ ^[[:digit:]]" "[[:digit:]] ]] && echo ok ok a=1;b=2 bash$ [[ $a > 0 && $b == 2 ]] && echo ok ok bash$ [ "$a" -gt 0 -a "$b" -eq 2 ] && echo ok okChtěl jsem přijít na to, proč tak důrazně radikálně trváš na tom, že by se to mělo řešit jinak, když tvé původní řešení bylo dobře a nové řešení nepřineslo žádnou změnu či výhodu.
test
(i se synonymem [
) je v bashi také builtin.
echo "$TEXT" | while IFS='|' read a b c; do echo "První část: $a" echo "Druhá: $b" echo "Zbytek: $c" done
Což má ale jednu podstatnou nevýhodu, totiž že rozsekané proměnné žijí jen v rámci subprocesu s while. V bashi to nicméně jde pěkně vyřešit pomocí while ... done <<<"$TEXT"
.
Jo, a while je pro jeden řádek samozřejmě zbytečné, takže případně prostě
IFS='|' read a b c <<<"$TEXT";
echo "$TEXT" | while IFS='|' read a b ctak to nefungovalo, ale
IFS='|' read a b c <<<"$TEXT";funguje bez problémů. Navíc jsi ušetřil jeden proces, takže to vidím jako skvělé řešení.
Tiskni Sdílej: