Na čem aktuálně pracují vývojáři GNOME a KDE? Pravidelný přehled novinek v Týden v GNOME a Týden v KDE.
Před 70 lety, 7. června 1954, ve věku 41 let, zemřel Alan Turing, britský matematik, logik, kryptoanalytik a zakladatel moderní informatiky.
NiceGUI umožňuje používat webový prohlížeč jako frontend pro kód v Pythonu. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT.
Open source platforma Home Assistant (Demo, GitHub, Wikipedie) pro monitorování a řízení inteligentní domácnosti byla vydána ve verzi 2024.6. Z novinek lze vypíchnout lepší integraci LLM (OpenAI, Google AI, Ollama) nebo podporu Matter 1.3.
IKEA ve Spojeném království hledá zaměstnance do své nové pobočky. Do pobočky v počítačové hře Roblox. Nástupní mzda je 13,15 liber na hodinu.
Alyssa Rosenzweig se v příspěvku na svém blogu Vulkan 1.3 na M1 za 1 měsíc rozepsala o novém Vulkan 1.3 ovladači Honeykrisp pro Apple M1 splňujícím specifikaci Khronosu. Vychází z ovladače NVK pro GPU od Nvidie. V plánu je dále rozchodit DXVK a vkd3d-proton a tím pádem Direct3D, aby na Apple M1 s Asahi Linuxem běžely hry pro Microsoft Windows.
Byla vydána (𝕏) květnová aktualizace aneb nová verze 1.90 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a animovanými gify v poznámkách k vydání. Ve verzi 1.90 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.
Byla vydána (Mastodon, 𝕏) nová verze 2024.2 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í.
Počítačová hra Tetris slaví 40 let. Alexej Pažitnov dokončil první hratelnou verzi 6. června 1984. Mezitím vznikla celá řada variant. Například Peklo nebo Nebe. Loni měl premiéru film Tetris.
MicroPython (Wikipedie), tj. implementace Pythonu 3 optimalizovaná pro jednočipové počítače, byl vydán ve verzi 1.23.0. V přehledu novinek je vypíchnuta podpora dynamických USB zařízení nebo nové moduly openamp, tls a vfs.
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: