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).
Canonical vydal Ubuntu Core 26. Vychází z Ubuntu 26.04 LTS a podporováno bude 15 let. Ubuntu Core je minimální neměnný operační systém určený pro vestavěné systémy.
Bylo vydáno OpenBSD 7.9. Po dlouhé době opět se songem: Diamond in the Rough.
Byl vydán Mozilla Firefox 151.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 151 bude brzy k dispozici také na Flathubu a Snapcraftu.
Elon Musk prohrál soudní spor se společností OpenAI, která se podle jeho žaloby odchýlila od původně uváděného cíle vyvíjet umělou inteligenci (AI) ku prospěchu lidstva. Porota včera po necelých dvou hodinách dospěla k jednomyslnému závěru, že Musk žalobu podal příliš pozdě. Musk byl jedním ze spoluzakladatelů společnosti OpenAI, která vznikla v roce 2015 a vyvinula populární chatovací systém ChatGPT. V roce 2018 na svůj post ve vedení
… více »Byla vydána nová verze 10.4 z Debianu vycházející linuxové distribuce DietPi pro (nejenom) jednodeskové počítače. Přehled novinek v poznámkách k vydání. Opraveny jsou zranitelnosti Copy Fail a Dirty Frag. Přibyl nový obraz pro Orange Pi 5B.
Pokud je zranitelnost Linuxu v nepoužívaném jaderném modulu, lze ji jednoduše vyřešit zakázáním automatického načítání tohoto konkrétního zranitelného modulu. Projekt ModuleJail si klade za cíl zvýšit bezpečnost Linuxu zakázáním automatického načítání všech nepoužívaných jaderných modulů. Jedná se o skript, který dá všechny nepoužívané jaderné moduly na blacklist (/etc/modprobe.d/modulejail-blacklist.conf).
Odborníci z Penn State University zkoumají způsob ukládání informací na lepicí pásku. Principiálně by podle nich bylo možné kombinací odlepení a zpětného přilepení dosáhnout uložení informace, kterou opětovným odlepením dokážou přečíst. Výhodou je, že způsob uložení i přečtení je čistě mechanický. Zde o tom referují ve volně dostupném článku. Zajímavé bude sledovat zda se jim v rámci výzkumu podaří prokázat použitelnost i v jiné než
… více »Na GitHubu byl publikován reprodukovatelný návod, jak rozchodit Adobe Lightroom CC na Linuxu a Wine. Návod byl vytvořený pomocí AI Claude Code.
tail -f). Zkoušel jsem to přes fork a semafor, ale dostal jsem tip, že by se to mělo nějak dát udělat přes MainLoop() - to je koneckonců smyčka, která by měla zavolat určitou funkci kontrolující soubor.
Ale zatím jsem nenašel "obecný" postup, jak toho dosáhnout. Programátor nejsem, netuším, po čem vlastně pátrám.
Používám wxPython (ale postup asi bude obecný pro jaký koliv toolkit), část kódu:
class Monitor(wx.App):
def OnInit(self):
init GUI
[....]
def watcher(self):
if zmena_v_souboru:
zmena_v_gui
def main():
pymonitor = Monitor(0)
pymonitor.MainLoop()
main()
Jak na to?
Díky

#!/usr/bin/env python
import sys, os, select, fcntl, signal
SEEK_SET, SEEK_CUR, SEEK_END = 0, 1, 2
bufsize = 4096
def handler_SIGIO(a, b):
pass
def dump_to_end(fd):
while True:
chunk = os.read(fd, bufsize)
if not chunk: break
sys.stdout.write(chunk)
fd = os.open(sys.argv[1], os.O_RDONLY)
signal.signal(signal.SIGIO, handler_SIGIO)
filepos = 0
while True:
os.lseek(fd, filepos, SEEK_SET)
dump_to_end(fd)
filepos = os.lseek(fd, 0, SEEK_CUR)
print filepos
fcntl.fcntl(fd, fcntl.F_SETLEASE, fcntl.F_RDLCK)
signal.pause()
Dá se to udělat i jinak? Nevýhodou je to šaškování se signálem a volání pause()
, pokud si je explicitně neuděláš (třeba přes rouru). Není lepší použít vlákna?
#!/usr/bin/env python
import pygtk
pygtk.require('2.0')
import gtk, gobject, stat, os, sys
class WatchFile:
def __init__(self, filename):
self.filename = filename
self.window = gtk.Window(gtk.WINDOW_TOPLEVEL)
self.window.connect('delete_event', self.delete_event)
self.window.connect('destroy', self.quit)
self.checkbut = gtk.CheckButton('File "%s" has changed' %filename)
self.checkbut.show()
self.times = (None, None, None)
self.has_changed()
gobject.timeout_add(1000, self.periodic_check, None)
self.window.add(self.checkbut)
self.window.show()
def periodic_check(self, object):
if self.has_changed():
self.checkbut.set_active(1)
return True
def has_changed(self):
sr = os.lstat(self.filename)
t = (sr.st_atime, sr.st_mtime, sr.st_ctime)
if t != self.times:
self.times = t
return True
else:
return False
def delete_event(self, widget, data):
return False
def quit(self, widget, data = None):
gtk.main_quit()
def main(self):
gtk.main()
if __name__ == '__main__':
wtch = WatchFile(sys.argv[1])
wtch.main()
Tohle ukáže checkbox, který se automaticky zaškrtne při každé změně souboru. Odšktrnutí jsem ponechal na uživateli, ať si klikne myší. Každou sekundu to kontroluje všechny tři časy u souboru. Jádrem pudla je timeout_add, o kterém psal Petr Mach.
self.timer = wx.wxPyTimer(self.watcher)
self.timer.Start(1000)
self.watcher() # to je ta funkce, která to celé dělá
čerpal jsem z roota (cirkus s okny)
dík za nasměrování správným směrem.
Tiskni
Sdílej: