Dnes v 17:30 bude oficiálně vydána open source počítačová hra DOGWALK vytvořena v 3D softwaru Blender a herním enginu Godot. Release party proběhne na YouTube od 17:00.
McDonald's se spojil se společností Paradox a pracovníky nabírá také pomocí AI řešení s virtuální asistentkou Olivii běžící na webu McHire. Ian Carroll a Sam Curry se na toto AI řešení blíže podívali a opravdu je překvapilo, že se mohli přihlásit pomocí jména 123456 a hesla 123456 a získat přístup k údajům o 64 milionech uchazečů o práci.
Byla vydána (𝕏) červnová aktualizace aneb nová verze 1.102 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.102 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.
Byla vydána nová verze 2.4.64 svobodného multiplatformního webového serveru Apache (httpd). Řešeno je mimo jiné 8 bezpečnostních chyb.
Společnost xAI na síti 𝕏 představila Grok 4, tj. novou verzi svého AI LLM modelu Grok.
Ministerstvo vnitra odhalilo závažný kyberincident v IT systému resortu. Systém, do kterého se dostal útočník bez oprávnění, byl odpojen a nedošlo k odcizení dat [𝕏].
Před rokem byla streamovací služba HBO Max přejmenována na Max. Dle managementu slovo HBO v názvu nebylo důležité. Včera byl Max přejmenován zpět na HBO Max. Kolik milionů dolarů to stálo? 😂
Byla vydána nová major verze 8.0.0 svobodného systému pro detekci a prevenci průniků a monitorování bezpečnosti počítačových sítí Suricata (Wikipedie). Přehled novinek v oficiálním oznámení a v aktualizované dokumentaci.
Mastodon (Wikipedie) - sociální síť, která není na prodej - byl vydán ve verzi 4.4. Přehled novinek s náhledy a videi v oznámení na blogu.
Instituce státní správy nebudou smět využívat produkty, aplikace, řešení, webové stránky a webové služby poskytované čínskou společností DeepSeek. Na doporučení Národního úřadu pro kybernetickou a informační bezpečnost rozhodla o jejich zákazu vláda Petra Fialy na jednání ve středu 9. července 2025.
Zdravím všechny ..
nedávno jsem se tady dotazoval, jak oddělím zrno od plév (soubory a /*teď už vím, že se to jmenuje */ nody ). Dalším googlením jsem se dostal až ke knihovně pylibparted (stará, neudržovaná, ale dobře se s tím pracuje, no, a hlavně, je v opensuse repu.
Nicméně ... knihovna má problém ( spíše to bude vlastnost ) s CDROMkou, některé funkce na tom padají, a pro mnou zamýšlený program stejně o práci s CDROMkou neuvažuju.
Ok, takže zase odděluji zrno od plév. Otázka zní, jak poznám, že nod patří CDROMce ?.
Jedna možnost se nabízí načíst si /proc/partitions a pylibparted se dotázat na path (pylibparted.PedDevice.getPath() ) k zařízení a tuto cestu najít v partitions, kde máme major minor, podle http://lxr.free-electrons.com/source/include/uapi/linux/major.h?v=3.14 tohoto nějak určit, že dané zařízení je CD, a loopnout se na další zařízení v pořadí (tj, nepokračovat dalším očucháváním CDčka ).
Tato konstrukce může fungovat, ale pak jsem si uvědomil, že mc a dokonce i ls -l mi prásknou major minor u nodu, tak proč to takto zdaleka obcházet?
Hm, ale teď nemůžu přijít na to, jak se k major minor v pythonu dostanu.
os.stat sice vrací st_dev, ale u těch nodů je to míněno asi jako device, kde leží (možná ani to ne, protože to, co se mi vrací, není stejné číslo jako v partitions ... moc o tom nevím).
Prolézal jsem další možnosti, zkusil jsem googlit, ale rozmanitost ( a nepoužitelnost ) nalezených výsledků mne opět zahnala tam "kde mi rozumějí " ) tak snad jste to pochopili,
předem díky za nápovědu.
Milan
Řešení dotazu:
CDROM_GET_CAPABILITY
). Pokud to CD-ROM není, tak řekne, že to neumí.
To druhé je ještě jednodušší. Při pokusu to zařízení otevřít dostanete chybu “No medium found” (ENOMEDIUM).
import pylibparted, os (a možná ještě něco) def collect_disks( ): result = { } devs = pylibparted.probeAllDevices() for p in devs : # Device d = pylibparted.PedDevice(p) devpath = d.getPath() devpath_stat = os.stat(devpath) d_mode = devpath_stat.st_mode if ( d_mode & 24576 <> 24576 ) : #print 'Device:', devpath, ' is not block' continue d_major = devpath_stat.st_rdev >> 8 #print d_major if ( not d_major in (8, 3, 22 ) ): #print "Device ", devpath, ' is not a disk' continue result[ devpath ] = {} model = d.getModel() #print 'Model: ', model result[ devpath ][ 'model' ] = model result[ devpath ][ 'type' ] = 'D' #print 'Device type :', d.getType() size = d.getLength() #print 'Size:', size result[ devpath ][ 'size' ] = size ssize = d.getSectorSize() #print 'Sector size: ', ssize result[ devpath ][ 'ssize' ] = ssize disktype = d.diskProbe() subtype = disktype.getName() #print'Name: ', subtype result[ devpath ][ 'subtype' ] = subtype c,h,s = d.getBiosCHS() chs = str(c) + '/' + str(h) + '/' + str(s) #print 'BIOS CHS:', chs c,h,s = d.getHwCHS() chs = str(c) + '/' + str(h) + '/' + str(s) #print 'HW CHS:', chs # Partition table pt = d.diskNew() parts = pt.getPartitions() for part in parts : if part.isActive() : part_path = part.getPath() #print ' Partition:', part_path result[ part_path ] = {} result[ part_path ]['type'] = 'P' parttype = part.getTypeName() #print ' Type Name:', parttype #print ' ID:', part.getId() result[ part_path ][ 'model' ] = parttype geom = part.getGeometry() #print ' Start:', geom.getStart() #print ' End:', geom.getEnd() size = geom.getLength() #print ' Length:', size result[ part_path ][ 'ssize' ] = ssize result[ part_path ][ 'size' ] = size fs = part.getFsType() if fs : #print ' FS:', fs.getName() result[ part_path ]['subtype'] = fs.getName() # parts # devs return result
Tiskni
Sdílej: