Máirín Duffy a Brian Smith v článku pro Fedora Magazine ukazují použití LLM pro diagnostiku systému (Fedora Linuxu) přes Model Context Protocol od firmy Anthropic. I ukázkové výstupy v samotném článku obsahují AI vygenerované nesmysly, např. doporučení přeinstalovat balíček pomocí správce balíčků APT z Debianu místo DNF nativního na Fedoře.
Projekt D7VK dospěl do verze 1.0. Jedná se o fork DXVK implementující překlad volání Direct3D 7 na Vulkan. DXVK zvládá Direct3D 8, 9, 10 a 11.
Byla vydána nová verze 2025.4 linuxové distribuce navržené pro digitální forenzní analýzu a penetrační testování Kali Linux (Wikipedie). Přehled novinek se seznamem nových nástrojů v oficiálním oznámení na blogu.
Národní úřad pro kybernetickou a informační bezpečnost (NÚKIB) zveřejnil Národní politiku koordinovaného zveřejňování zranitelností (pdf), jejímž cílem je nejen zvyšování bezpečnosti produktů informačních a komunikačních technologií (ICT), ale také ochrana objevitelů zranitelností před negativními právními dopady. Součástí je rovněž vytvoření „koordinátora pro účely CVD“, jímž je podle nového zákona o kybernetické … více »
Vývojáři KDE oznámili vydání balíku aplikací KDE Gear 25.12. Přehled novinek i s náhledy a videi v oficiálním oznámení.
Společnost System76 vydala Pop!_OS 24.04 LTS s desktopovým prostředím COSMIC. Videoukázky na YouTube.
Byla vydána verze 1.92.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.
Free Software Foundation zveřejnila ocenění Free Software Awards za rok 2024. Oceněni byli Andy Wingo, jeden ze správců GNU Guile, Alx Sa za příspěvky do Gimpu a Govdirectory jako společensky prospěšný projekt.
Bylo vydáno Eclipse IDE 2025-12 aneb Eclipse 4.38. Představení novinek tohoto integrovaného vývojového prostředí také na YouTube.
U příležitosti oslav osmi let prací na debianím balíčku vyšlo GPXSee 15.6. Nová verze přináší především podporu pro geotagované MP4 soubory, včetně GoPro videí. Kdo nechce čekat, až nová verze dorazí do jeho distribuce, nalezne zdrojové kódy na GitHubu.
Bashtop je nástroj s TUI rozhraním pro monitorování systému naprogramovaný v Bashi. Aktuálně má tento skript 3508 řádků.
Tiskni
Sdílej:
┌─┤resize window├──────────────────────────────────────────────────────────────┐ │ │ │ Current size: │ │ 80x24 │ │ Need to be atleast: │ │ 80x25 │ │ │ └──────────────────────────────────────────────────────────────────────────────┘
for s in `ls /proc`; do path="/proc/$s/comm"; if [ -e $path ]; then cat $path; fi; done | sort
php -r '$c = []; foreach (glob("/proc/*/comm") as $f) { $c[] = file_get_contents($f);}; sort($c); echo join($c);'
php -r '$c = array_map(function($f) {return file_get_contents($f);}, glob("/proc/*/comm")); sort($c); echo join($c);'
... a běží to jen 10× rychleji.
cat /proc/*/comm | sort
Jen pozor, že tohle předá názvy všech těch souborů jako argumenty příkazu cat (který se spustí jen jednou), které mají omezenou délku. Ale prakticky by se ti nemělo stát, že bys ten limit překročil, viz:
getconf ARG_MAX
Např. na mém systému to jsou 2 MB.
Nějaké limity máš v podstatě všude (přeteče int, naplní se RAM, dojde místo na disku, zahltí se kapacita sítě a začnou se zahazovat pakety atd.) Ono napsat program, který by fungoval za všech okolností, je dost těžké až nemožné.
Allowed memory size of 2097152 bytes exhausted (tried to allocate 78 bytes) in phptop.php 1
A pak mi někdo vykládajte, jak jsou PHP* skripty spolehlivé.
* při vhodné úpravě chybového hlášení lze vložit jazyk dle volby čtenáře.
# echo /proc/*/comm |wc -c 3141 # (cd /proc; ls */comm | wc -c) 1952
Neměl by se odfiltrovat self a thread-self, protože už tam jednou je? Třeba brát jenom čísla…
cat /proc/+([0-9])/comm | sort
A kdybychom chtěli cat zavolat „bezpečně“, jak už někteří naznačovali:
find /proc -mindepth 2 -maxdepth 2 -regex '/proc/[0-9]+/comm' -exec cat '{}' + | sort
Nebo kdybychom to chtěli jenom v Bashi, jenom ten sort bychom si ještě dovolili spustit: 
for comm in /proc/+([0-9])/comm; do echo "$(< "$comm")" done | sort
Nebo kdybychom to fakt chtěli jenom v Bashi a ani ten sort bychom si nedovolili spustit, tak potom upravíme tohle, aby to bralo stringy, a…
mergesort() {
local -n -r input_reference="$1"
local -n output_reference="$2"
local -r -i size="${#input_reference[@]}"
local merge previous
local -a -i runs indices
local -i index previous_idx merged_idx \
run_a_idx run_a_stop \
run_b_idx run_b_stop
output_reference=("${input_reference[@]}")
if ((size == 0)); then return; fi
previous="${output_reference[0]}"
runs=(0)
for ((index = 0;;)) do
for ((++index;; ++index)); do
if ((index >= size)); then break 2; fi
if [[ "${output_reference[index]}" < "$previous" ]]; then break; fi
previous="${output_reference[index]}"
done
previous="${output_reference[index]}"
runs+=(index)
done
runs+=(size)
while (("${#runs[@]}" > 2)); do
indices=("${!runs[@]}")
merge=("${output_reference[@]}")
for ((index = 0; index < "${#indices[@]}" - 2; index += 2)); do
merged_idx=runs[indices[index]]
run_a_idx=merged_idx
previous_idx=indices[$((index + 1))]
run_a_stop=runs[previous_idx]
run_b_idx=runs[previous_idx]
run_b_stop=runs[indices[$((index + 2))]]
unset runs[previous_idx]
while ((run_a_idx < run_a_stop && run_b_idx < run_b_stop)); do
if [[ "${merge[run_a_idx]}" < "${merge[run_b_idx]}" ]]; then
output_reference[merged_idx++]="${merge[run_a_idx++]}"
else
output_reference[merged_idx++]="${merge[run_b_idx++]}"
fi
done
while ((run_a_idx < run_a_stop)); do
output_reference[merged_idx++]="${merge[run_a_idx++]}"
done
while ((run_b_idx < run_b_stop)); do
output_reference[merged_idx++]="${merge[run_b_idx++]}"
done
done
done
}
stupidsort() {
local -a input output
readarray -t input
mergesort input output
for line in "${output[@]}"; do echo "$line"; done
}
for comm in /proc/+([0-9])/comm; do
echo "$(< "$comm")"
done | stupidsort
Uf. Měl bych s takovými ptákovinami přestat.
Ale nemohl jsem si pomoct.
sorted([open('/proc/%s/comm'%file).read() for file in os.listdir('/proc') if os.path.exists('/proc/%s/comm'%file)])
Ma to ale naprosto stejny problem s race condition jako ten bash (overim sice ze soubor funguje ale ouha, on zmizi). Osobne bych neco takoveho v bashi udelal stejne jako Andrej s mirnou modifikaci (zjednoduseni findu a omezeni spousteni cat procesu):
find /proc -maxdepth 2 -path '/proc/*/comm' | xargs cat | sort
Btw. jak tu delate ten barevny kod? :)
Btw. jak tu delate ten barevny kod? :)
<pre class="brush: html">...</pre>
Té race condition se dá odpomoct tak, že soubory, jejichž čtení nějak selže, se nebudou vypisovat. Pořád ten výpis sice nepředstavuje „atomický snapshot“ adresáře /proc, ale aspoň v něm pak nebudou náhodné chybové hlášky na stderr a prázdné řádky na stdout:
for comm in /proc/+([0-9])/comm; do
if content="$(< "$comm")"; then
echo "$content"
fi 2>/dev/null
done | sort
To původní řešení, ... if [ -e $path ]; then cat $path; fi; ..., je samozřejmě (pokud jde o race condition) taky špatně. Leda že by se někde později (nebo globálně) zahazoval stderr; to by pak dávalo smysl. (Pak ale nemá smysl dávat tam tu podmínku, která nijak nepomáhá. Přivřené race window je pořád race window.)