Databáze DuckDB (Wikipedie) dospěla po 6 letech do verze 1.0.0.
Intel na veletrhu Computex 2024 představil (YouTube) mimo jiné procesory Lunar Lake a Xeon 6.
Na blogu Raspberry Pi byl představen Raspberry Pi AI Kit určený vlastníkům Raspberry Pi 5, kteří na něm chtějí experimentovat se světem neuronových sítí, umělé inteligence a strojového učení. Jedná se o spolupráci se společností Hailo. Cena AI Kitu je 70 dolarů.
Byla vydána nová verze 14.1 svobodného unixového operačního systému FreeBSD. Podrobný přehled novinek v poznámkách k vydání.
Společnost Kaspersky vydala svůj bezplatný Virus Removal Tool (KVRT) také pro Linux.
Grafický editor dokumentů LyX, založený na TeXu, byl vydán ve verzi 2.4.0 shrnující změny za šest let vývoje. Novinky zahrnují podporu Unicode jako výchozí, export do ePub či DocBook 5 a velké množství vylepšení uživatelského rozhraní a prvků editoru samotného (např. rovnic, tabulek, citací).
Byla vydána (𝕏) nová verze 7.0 LTS open source monitorovacího systému Zabbix (Wikipedie). Přehled novinek v oznámení na webu, v poznámkách k vydání a v aktualizované dokumentaci.
Organizace Apache Software Foundation (ASF) vydala verzi 22 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.
Společnost AMD na veletrhu Computex 2024 představila (YouTube) mimo jiné nové série procesorů pro desktopy AMD Ryzen 9000 a notebooky AMD Ryzen AI 300.
OpenCV (Open Source Computer Vision, Wikipedie), tj. open source multiplatformní knihovna pro zpracování obrazu a počítačové vidění, byla vydána ve verzi 4.10.0 . Přehled novinek v ChangeLogu. Vypíchnout lze Wayland backend pro Linux.
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