Byly publikovány informace (technické detaily) o bezpečnostním problému Snapu. Jedná se o CVE-2026-3888. Neprivilegovaný lokální uživatel může s využitím snap-confine a systemd-tmpfiles získat práva roota.
Nightingale je open-source karaoke aplikace, která z jakékoliv písničky lokálního alba (včetně videí) dokáže oddělit vokály, získat text a vše přehrát se synchronizací na úrovni jednotlivých slov a hodnocením intonace. Pro separaci vokálů využívá UVR Karaoke model s Demucs od Mety, texty písní stahuje z lrclib.net (LRCLIB), případně extrahuje pomocí whisperX, který rovněž využívá k načasování slov. V případě audiosouborů aplikace na
… více »Po půl roce vývoje od vydání verze 49 bylo vydáno GNOME 50 s kódovým názvem Tokyo (Mastodon). Podrobný přehled novinek i s náhledy v poznámkách k vydání a v novinkách pro vývojáře.
Článek na stránkách Fedora Magazinu informuje o vydání Fedora Asahi Remixu 43, tj. linuxové distribuce pro Apple Silicon vycházející z Fedora Linuxu 43.
Byl zveřejněn program konference Installfest 2026. Konference proběhne o víkendu 28. a 29. března v Praze na Karlově náměstí 13. Vstup zdarma.
Byla vydána Java 26 / JDK 26. Nových vlastností (JEP - JDK Enhancement Proposal) je 10. Odstraněno bylo Applet API.
Byla vydána nová verze 260 správce systému a služeb systemd (Wikipedie, GitHub). Odstraněna byla podpora skriptů System V. Aktualizovány byly závislosti. Minimální verze Linuxu z 5.4 na 5.10, OpenSSL z 1.1.0 na 3.0.0, Pythonu z 3.7.0 na 3.9.0…
Byla vydána nová verze 5.1 svobodného 3D softwaru Blender. Přehled novinek i s náhledy a videi v poznámkách k vydání. Videopředstavení na YouTube.
Bylo oznámeno vydání nové verze 8.1 "Hoare" kolekce svobodného softwaru umožňujícího nahrávání, konverzi a streamovaní digitálního zvuku a obrazu FFmpeg (Wikipedie). Doprovodný příspěvek na blogu Khronosu rozebírá kódování a dekódování videa pomocí Vulkan Compute Shaders v FFmpeg.
Byl představen open-source a open-hardware prototyp nízkonákladového raketometu kategorie MANPADS, který byl sestaven z běžně dostupné elektroniky a komponent vytištěných na 3D tiskárně. Raketa využívá skládací stabilizační křidélka a canardovou stabilizaci aktivně řízenou palubním letovým počítačem ESP32, vybaveným inerciální měřicí jednotkou MPU6050 (gyroskop a akcelerometr). Přenosné odpalovací zařízení obsahuje GPS,
… více »
download=["pacman","-S","--noconfirm","program"]
process = subprocess.Popen(download, stdin = subprocess.PIPE, stdout = subprocess.PIPE)
while 1<2:
print process.stdout.readline()
Jak jsem se dočetl, readline() čeká na výstup z programu. Program vypíše první řádky vpořádku, ale když by měl zobrazovat progressbar, tak ze stdout nic neleze. Je to asi tím, že výstup se jakoby neustále překresluje. Je nějaký způsob jak zachytit veškerý výstup?
Je potřeba si uvědomit, že progressbar není "standartní" výstup. Pro vykreslování se používá knihovna ncurses a je to asi jako kdyby jsi chtěl přesměrovat do souboru výstup mc, schválně si to zkus:
$ mc &> /tmp/mc.out
$ less /tmp/mc.out
Pro "práci s písmenky" (mazání, vykreslování na dané pozici, obarvení) se používají speciální řídící sekvence, které terminál musí podporovat. Navíc některé programy jsou chytré a když zjistí, že terminál tyto sekvence nepodporuje, tak změní typ výstupu. Mezi ně patří např. wget.
$ wget http://www.abclinuxu.cz &> /tmp/wget.out
$ cat /tmp/wget.out
#!/usr/bin/python
import time, sys
for i in range(40):
sys.stdout.write("#" * i + '\r')
sys.stdout.flush()
time.sleep(0.2)
print
A výstup chci zachytávat jiným programem:
#!/usr/bin/python
import subprocess, sys
process = subprocess.Popen(['./druha.py',], stdout = subprocess.PIPE)
while True:
znak = process.stdout.read(1)
if not znak:
break
sys.stdout.write(znak)
sys.stdout.flush()
Tak to funguje, ale musí se číst po znacích. Ale jak psal Fuky, není jisté, jestli to Pacman dělá taky tak.
--noprogressbar
Do not show a progress bar when downloading files. This can be
useful for scripts that call pacman and capture the output.
Není tento výstup lepší?
Ano lze
Podívej se do zdrojáků frontendu napsaného v Pythonu gtkpacman. Jestli se nepletu, tak po letmém pohledu to vypadá, že to zařizuje modul vte.
$ aptitude show python-vte
The VTE library inserts terminal capability strings into a trie, and then uses it to determine if data received
from a pseudo-terminal is a control sequence or just random data. The sample program "interpret" illustrates more
or less what the widget sees after it filters incoming data.
This package contains the Python bindings for the VTE library.
Jak to myslíš? Tak, že děláš frontend v Qt? V tom případě se mrkni do zdrojáků pakman tj. frontend napsaný v Qt
Tiskni
Sdílej: