Byl vydán Mozilla Firefox 145.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Ukončena byla podpora 32bitového Firefoxu pro Linux. Přidána byla podpora Matrosky. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 145 bude brzy k dispozici také na Flathubu a Snapcraftu.
Lidé.cz (Wikipedie) jsou zpět jako sociální síť s "ambicí stát se místem pro kultivované debaty a bezpečným online prostředím".
Byla vydána nová verze 4.4 multiplatformního integrovaného vývojového prostředí (IDE) pro rychlý vývoj aplikaci (RAD) ve Free Pascalu Lazarus (Wikipedie). Využíván je Free Pascal Compiler (FPC) 3.2.2.
ASUS má v nabídce komplexní řešení pro vývoj a nasazení AI: kompaktní stolní AI superpočítač ASUS Ascent GX10 poháněný superčipem NVIDIA GB10 Grace Blackwell a platformou NVIDIA DGX Spark. S operačním systémem NVIDIA DGX založeném na Ubuntu.
Desktopové prostredie Trinity Desktop vyšlo vo verzii R14.1.5. Je tu opravená chyba v tqt komponente spôsobujúca 100% vyťaženie cpu, dlaždice pre viac monitorov a nemenej dôležité su dizajnové zmeny v podobe ikon, pozadí atď. Pridaná bola podpora distribúcií Debian Trixie, Ubuntu Questing, RHEL 10 a OpenSUSE Leap 16.
Grafická aplikace Easy Effects (Flathub), původně PulseEffects, umožňující snadno povolovat a zakazovat různé audio efekty v aplikacích používajících multimediální server PipeWire, byla vydána ve verzi 8.0.0. Místo GTK 4 je nově postavená nad Qt, QML a Kirigami.
Na YouTube lze zhlédnout Godot Engine – 2025 Showreel s ukázkami toho nejlepšího letos vytvořeného v multiplatformním open source herním enginu Godot.
Blíží se konec roku a tím i všemožná vyhlášení slov roku 2025. Dle Collins English Dictionary je slovem roku vibe coding, dle Dictionary.com je to 6-7, …
Cloudflare Radar: podíl Linuxu na desktopu dosáhl v listopadu 6,2 %.
Chcete vědět, co se odehrálo ve světě techniky za poslední měsíc? Nebo si popovídat o tom, co zrovna bastlíte? Pak doražte na listopadovou Virtuální Bastlírnu s mikrofonem a kamerou, nalijte si něco k pití a ponořte se s strahovskými bastlíři do diskuze u virtuálního piva o technice i všem možném okolo. Mezi nejvýznamnější novinky patří Průšovo oznámení Core One L, zavedení RFID na filamentech, tisk silikonu nebo nový slicer. Dozvíte se ale i
… více »
for s in bla ' bla' 'bla ' ' bla '; do
echo -n "'${s}': "
if [[ "${s:0:1}" != ' ' && "${s: -1}" != ' ' ]]; then
echo 'jo'
else
echo 'ne'
fi
done
...
if [[ "$s" = "${s# }" && "$s" = "${s% }" ]]; then
...
...
if [[ "${s}${s}" = "${s# }${s% }" ]]; then
...
if printf "%s" "$string" | grep -vo '^\s\|\s$'; then
Mám naprosto běžný grep (OK, GNU grep), který defaultně argument interpretuje jako basic regular expression, ne jako PCRE (to by dělal s přepínačem -P).
Nebo prostě jen nepoužívejte \s.
Já to nepoužívám, použil jste to vy - což byla chyba.
Expanze v nejsou prapodivné. Dokonce nejsou specifické pro Bash; byly i ve standardním shellu (a umí je tedy i Dash). Prapodivné je záměrně nepoužívat některé části Bashe (nebo shellu obecně). Od toho jsou přece manuálové stránky, aby expanze uživatelům přestaly připadat prapodivné.
Roury jsou přehledné pro zpracování delšího streamu dat, který jimi prochází a který se celý zpracuje na jedno spuštění zúčastněných procesů. Pro manipulaci s jednotlivými proměnnými jsou roury krajně nevhodné. Je to takový mor skriptů (anglicky antipattern) a jednou z výhod Bashe je, že umožňuje vyhnout se takovým zlozvykům.
Nic moc se nestane, když někdo zbytečnou rouru použije na zpracování jednoho vstupního parametru. Horší ale bude, když se něco takového dostane do cyklu, který čte vstup a stále dokola pak spouští grep. Viděl jsem až příliš mnoho skriptů, které běžely minutu, zatímco po odstranění zbytečného spouštění procesů jim stačila sekunda.
Pokud jde o nepřehlednou logiku, myslím si, že jednoduchá podmínka, která nápadně připomíná různé další jazyky, je nesrovnatelně přehlednější než ošklivý trik s grepem.
read aux <<<"$s" if [ "$s" = "$aux" ]; then
case "$s" in
\ *|*\ ) ... ;;
*) ... ;;
esac
read se hodí hlavně v situaci, kdy nepotřebuji kontrolu, ale spíš se těch počátečních a koncových mezer chci zbavit. Na druhou stranu, tenhle nenápadný rozdíl mezi "read" a "read var" mi vždycky přišel tak trochu jako past.
$newstring=$(printf "%s" "$string" | grep -Po '\S.*\S')Většinou to člověk ocení až při matchnutí něčeho složitějšího. Tím rozdílem mezi read a read var myslíte co?
V posixových shellech by to znamenalo spojení rourou s printf a to je pak lepší použít rovnou grep.
Ne, není. Kromě zpracování delších souborů nebo vstupů není nikdy "lepší" použít grep. Zatímco printf je efektivní vestavěný příkaz shellu, grep je zbytečný externí proces.
Asi jo, kdyby to bylo nějak nezbytné. Pokud ale můžu s proměnnou nějak přímo manipulovat v shellu (nebo v Bashi, který má integery a aritmetické výrazy, pár expanzí navíc a další vychytávky), asi bych tam tu rouru necpal za každou cenu. Jako jo, když mám kamna, tak tam budu mít rouru, ale jinak ji nepotřebuju.
Tiskni
Sdílej: