Společnost Flipper Devices oznámila Flipper One. Zcela nový Flipper postavený od nuly. Jedná se o open-source linuxovou platformu založenou na čipu Rockchip RK3576. Hledají se dobrovolníci pro pomoc s dokončením vývoje (ovladače, testování, tvorba modulů).
Vývojáři Wine oznámili vydání verze 2.0 knihovny vkd3d pro překlad volání Direct3D na Vulkan. Přehled novinek na GitLabu.
Společnost Red Hat oznámila vydání Red Hat Enterprise Linuxu (RHEL) 10.2 a 9.8. Vedle nových vlastností a oprav chyb přináší také aktualizaci ovladačů a předběžné ukázky budoucích technologií. Vypíchnout lze CLI AI asistenta goose. Podrobnosti v poznámkách k vydání (10.2 a 9.8).
Organizace Apache Software Foundation (ASF) vydala verzi 30 integrovaného vývojového prostředí a vývojové platformy napsané v Javě NetBeans (Wikipedie). Přehled novinek na GitHubu. Instalovat lze také ze Snapcraftu a Flathubu.
Byla vydána nová verze 7.0 svobodného open source redakčního systému WordPress. Kódové jméno Armstrong bylo vybráno na počest amerického jazzového trumpetisty a zpěváka Louise Armstronga (What A Wonderful World).
V Drupalu byla nalezena a opravena kritická zranitelnost SA-CORE-2026-004 (CVE-2026-9082). Útočník může provádět libovolné SQL dotazy na webech používajících databázi PostgreSQL.
Richard Hughes oznámil, že službu Linux Vendor Firmware Service (LVFS) umožňující aktualizovat firmware zařízení na počítačích s Linuxem, nově sponzoruje také společnost HP.
O víkendu proběhla demopárty Outline 2026. Publikována byla prezentovaná dema. Upozornit lze na 16 bajtové, opravdu šestnáct bajtové, zvukově obrazové demo Wake Up! 16b (YouTube).
Byla vydána nová verze 9.5 multiplatformní digitální pracovní stanice pro práci s audiem (DAW) Ardour. Přehled novinek, vylepšení a oprav v poznámkách k vydání a na YouTube.
Dnes a zítra probíhá vývojářská konference Google I/O 2026. Sledovat lze na YouTube a na síti 𝕏 (#GoogleIO).
Jak jednoduše vypínat, zapínat a přepínat stav bezdrátových zařízení?
No přeci používáním RF Kill Switch! Protože se mi s posledním jádrem začly chovat rozumě, po softwarové blokaci se samovolně neodblokují - například wifi to s oblibou dělala, jsem si napsal malý skript na obsluhu této vymoženosti. Ano existuje utilita rfkill, ale tam jaksi není ono jednoduché překlopení stavu, proto vlastní řešení, podobnost ostatního je čistě náhodná.
#!/bin/bash
SYS_DIR="/sys/class/rfkill"
SYS_FILE="index"
Usage()
{
echo "usage:" >&2
echo "${0##*/} list" >&2
echo "${0##*/} block [index|type]" >&2
echo "${0##*/} unblock [index|type]" >&2
echo "${0##*/} toggle [index|type]" >&2
echo "type:" >&2
echo "all" >&2
cat "$SYS_DIR"/*/type | sort -u >&2
exit 1
}
GetStatusText()
{
case "$1" in
0)
echo "soft blocked"
;;
1)
echo "unblocked"
;;
2)
echo "hard blocked"
;;
esac
}
List()
{
for DIR in "$SYS_DIR"/*; do
INDEX=$(cat "$DIR"/index)
NAME=$(cat "$DIR"/name)
TYPE=$(cat "$DIR"/type)
STATE=$(GetStatusText $(cat "$DIR"/state))
echo "$INDEX: $NAME: $TYPE: $STATE"
done
}
SetState()
{
for DIR in "$SYS_DIR"/*; do
if [ "$3" = "all" ] || [ "$3" = $(cat "$DIR"/"$2") ]; then
echo "$1" > $DIR/state || exit 1
fi
done
}
Toggle()
{
for DIR in "$SYS_DIR/"*; do
if [ "$2" = "all" ] || [ "$2" = $(cat "$DIR"/"$1") ]; then
echo "$((! $(cat "$DIR"/state)))" > "$DIR"/state || exit 1
fi
done
}
if ! [ -d "$SYS_DIR" ]; then
echo "${0##*/}: no RF Kill Switch found!"
exit 1
fi
if [ "$1" = "list" ]; then
List
exit 0
fi
if [ -z "$2" ]; then
Usage
exit 1
fi
if cat "$SYS_DIR"/*/type | grep -q ^"$2"$; then
SYS_FILE="type"
elif cat "$SYS_DIR"/*/index | grep -q ^"$2"; then
SYS_FILE="index"
elif [ "$2" != "all" ]; then
echo "${0##*/}: no such index or type" >&2
exit 1
fi
case "$1" in
unblock)
SetState 1 "$SYS_FILE" $2
;;
block)
SetState 0 "$SYS_FILE" $2
;;
toggle)
Toggle "$SYS_FILE" $2
;;
*)
Usage
;;
esac
Tiskni
Sdílej:
Err " ${0/*\/} toggle [index|type]"
Err "type:"
Err " all"
for TYPE in `cat "$SYS_DIR"/*/type | sort | uniq`; do
${0##*/} je lepší než ${0/*\/}, když ti jde o oříznutí řetězce od začátku.
for x in `cat ...` je hrůza. Tohle nejde?
cat "$SYS_DIR"/*/type | sort -u | while read TYPEDál jsem to neřešil. Neber to jako buzeraci, jen se snažím pomoct...
Jo a ještě přesměrování do stderr je obecnější pomocí tohoto chvatu: >&2.
for i in ` comman`;do je bohuzel nekdy nutnosti. Min. ve dvou pripadech.
Prvni pripad je, kdyz kod v cykly neco cte ze stdin, potom totiz command | while read a;do command2 "$a" ; done probehne pouze jednou, protoze z nejakyho duvodu sezere ten command2 ze stdin zbytek toho vystupu z command. Uz se mi to parkrat stalo, pokud si vzpominam, tak to bylo se ssh. generate-host-list | while read host; do ssh "$host" remote-cmd ; done bezelo jenom jednou pro prvniho hosta.
Druhy pripad je, kdyz chces v cyklu nastavit nejakou hodnotu, kterou pak pouzijes dal. Pipe totiz vyvola dalsi bash, takze veskere upravy jsou pouze lokalni, cili generate-list | while read item;do if [ $item -gt $max ] ; then max=$item;fi;done ; pracuj-dale-s-max nebude to same jako for item in `generate-list` ; do if [ $item -gt $max ];then max=$item;fi;done;pracuj-dale-s-max
"-n" pre ssh, potom ssh necita standardny vstup.
dave@amd64 ~ $ for x in $(echo a b c); do max=$item; done dave@amd64 ~ $ echo $max
$ for x in a b c; do max=$x; done $ echo $max c