Microsoft představil Azure Linux 4.0 a Azure Container Linux. Na konferenci Open Source Summit North America 2026 organizované konsorciem Linux Foundation a sponzorované také Microsoftem. Azure Linux 4.0 vychází z Fedora Linuxu. Azure Container Linux je založen na projektu Flatcar. Azure Linux (GitHub, Wikipedie) byl původně znám jako CBL-Mariner.
Nové číslo časopisu Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 165 (pdf).
Byla vydána verze 9.2 open source virtualizační platformy Proxmox VE (Proxmox Virtual Environment, Wikipedie) založené na Debianu. Přehled novinek v poznámkách k vydání a informačním videu.
Firefox 151 podporuje Web Serial API. Pro komunikaci s různými mikrokontroléry připojenými přes USB nebo sériové porty už není nutné spouštět Chrome nebo na Chromiu postavené webové prohlížeče.
Byla vydána nová stabilní verze 8.0 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 148. Přehled novinek i s náhledy v příspěvku na blogu.
Ve FreeBSD byla nalezena a opravena zranitelnost FatGid aneb CVE-2026-45250. Jedná se o lokální eskalaci práv. Neprivilegovaný uživatel se může stát rootem.
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.
Správce oken OpenBox má jednu moc fajn fičůrku, jmenuje se pipe-menu, zprvu jsem jí nevěnoval pozornost, později se nad ní rozplýval blahem Botanicus na ubuntu@chat.linjab.net , tak jsem začal zjišťovat co že to umí, a ono to umí 
Je to vlastně úplně jednoduché, je to dynamicky generované menu, tedy položka menu je generovaná jako výstup z nějakého skriptu, je jedno jestli Python, Ruby nebo cokoli ... důležitý je správně naformátovaný výstup, potom se dá vykouzlit teba 5 nejvíce RAM-žeroucích procesů s možností killu po kliknutí, nebo měnič pozadí který zobrazuje výpis souborů z určené složky, nebo udělátko které vypíše .iso soubory ze složky, a po kliknutí jej připojí, právě toto jsem řešil já.
Skript jsem psal v Pythonu, konečně jsem se rozhoupal a začal něco tvořit, pořád jenom čučím na cizí skripty, nebo louskám PyGTK tutoriál, ale k psaní jsem se nějak neměl. Skriptík je to pravda jedoduchý, ale i přesto jsem s ní měl problémy, naštěstí hodní lidé na fóru pomohli, stejně tak na Ubuntu konfeře se mi pomoci dostalo.
Takže, obecně platí, do menu.xml se musí fláknout toto:
<menu id="ID" label="TITLE" execute="COMMAND" />Přičemž COMMAND je právě onen příkaz, který spustí náš skript a zajistí výstup do menu. label je popisek menu.
<openbox_pipe_menu>
<item label="LABEL">
ACTIONS
</item>
</openbox_pipe_menu>
LABEL je popisek položky, ACTIONS je akce, která se provede po kliku na položku, je to kapitolka sama pro sebe.
<action name="NAME">PARAMETERS</action>A prakticky, například když chceme po kliku spustit příkaz :
<action name="Execute"><execute>xterm</execute></action>O dalších ACTIONS se dočtete tady
#!/usr/bin/python
## STIBIHO MOUNTOVATKO PRO OPENBOX - PIPE MENU
## VERZE 1.0
import os,re
class Mountovatko:
def __init__(self):
def vypis():
regexp = re.compile("([a-zA-Z0-9_]+).(iso)")
pole_out = []
for prvek in os.listdir("/home/stibi/ISOimage/"):
if regexp.search(prvek) is not None:
pole_out.append(prvek)
return pole_out
polozka = vypis()
def menu():
print "<openbox_pipe_menu>"
for x in range(len(polozka)):
print '<item label='+'"'+polozka[x]+'"'+'>'
print '<action name='+'"'+'Execute'+'"'+'>'
print '<execute>'
print 'gksu'+' "'+'mount -t iso9660 -o loop /home/stibi/ISOimage/'+ polozka[x]+' /mnt/dvd/'+'"'
print '</execute>'
print '</action>'
print '</item>'
print "</openbox_pipe_menu>"
menu()
if __name__ == "__main__":
mount = Mountovatko()
Projede zadaný adresář a do menu vyplivne jenom .iso soubory. Nejlepší by bylo, kdyby se testoval typ souboru, to už mám v ToDo do další verze.
Tiskni
Sdílej:
for x in range(len(polozka)):polozka-->polozky, tak se to da napsat prehledneji:for polozka in polozky:
...
vim ~/.emacsMyslel jsem si, že když připojím .iso soubor, tak před připojením jiného musím ten připojený odpojit, ale ne, odpojí se sám, to jsem se docela divil, žádný program na automatické připojování mechanik či souborů u mě nebeží, takže určitě záleží na nastavení....Nemountuješ spíše ty isa přes sebe?
if mount | grep " on $adresar " then umount "$adresar" && mount "$novej_soubor" else mount "$novej_soubor" fia máš to :)
def vypis():
regexp = re.compile("\.iso$") # na konci retezce je posloupnost znaku .iso
return filter(regexp.search, os.listdir("/home/stibi/ISOimage/"))
nebo uplne bez regexpu:
def vypis(): path="/home/stibi/ISOimage/" return filter(lambda f:os.path.splitext(f)[1].lower()=='.iso', os.listdir(path))pripadne pokud bys jeste chtel kontrolovat jestli zakerny uzivatel nevytvoril adresar ktery se jmenuje "cokoli.iso" tak:
def vypis(): path="/home/stibi/ISOimage/" return filter(lambda f: os.path.isfile(path+f) && os.path.splitext(f)[1].lower()=='.iso', os.listdir(path))
....
def main(self):
def vypis():
def menu():
...
je zverstvo :) (bez urazky).
class Mountovatko:
def __init__(self):
path="/home/stibi/ISOimage/"
polozky=filter(lambda f: os.path.isfile(path+f) && os.path.splitext(f)[1].lower()=='.iso', os.listdir(path))
print "<openbox_pipe_menu>"
for polozka in polozky:
print '<item label='+'"'+polozka+'"'+'>'
print '<action name='+'"'+'Execute'+'"'+'>'
print '<execute>'
print 'gksu'+' "'+'mount -t iso9660 -o loop /home/stibi/ISOimage/'+ polozka +' /mnt/dvd/'+'"'
print '</execute>'
print '</action>'
print '</item>'
print "</openbox_pipe_menu>" #tenhle radek mas v originale ve for cyklu - asi chyba odsazeni, nebo sem to nepochopil :)
....
def main(self):
def vypis():
def menu():
...
ma byt samozrejme
....
def __init__(self):
def vypis():
def menu():
...
jej :)
No, tak to se mám ještě co učit :) JInak díky, mám v tom jasno trošičku víc :) S regulárními výrazy se člověk nenudí... hmm, že bych si to dal do patičky ... :) To je hláška jak z laTrine (kdo zná ... )
).