Celkový počet stažení aplikací z Flathubu překročil 2 miliardy. Aktuální Statistiky Flathubu: Celkový počet stažení 2 002 793 783. Celkem desktopových aplikací 2 636.
Byla vydána nová verze 4.8.0 programu na úpravu digitálních fotografií darktable (Wikipedie).
Nová čísla časopisů od nakladatelství Raspberry Pi: MagPi 142 (pdf) a HackSpace 79 (pdf).
Qtractor (Wikipedie) dospěl do verze 1.0.0. Jedná se o Audio/MIDI vícestopý sekvencer.
Byl vydán svobodný kancelářský balík OnlyOffice Docs 8.1. Vedle četných oprav přináší několik funkcí včetně podpory editace textu v PDF a vytváření formulářů v PDF.
Daniel Stenberg, autor nástroje curl, z databáze SteamDB zjistil, že aktuálně 22 734 her na Steamu používá curl.
Společnost Anthropic vydala Claude 3.5 Sonnet, tj. novou verzi své umělé inteligence Claude (Wikipedie). Videoukázky na YouTube. S Claude 3, stejně jak s GPT-3.5, Llama 3 a Mixtral, si lze pokecat bez přihlašování na DuckDuckGo AI Chat.
Byla vydána nová stabilní verze 6.8 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 126. Přehled novinek i s náhledy v příspěvku na blogu a na YouTube. Vypíchnuta jsou vylepšení v integrovaném poštovním klientu.
Příspěvek Aukce domén – měsíc po spuštění na blogu CZ.NIC shrnuje první měsíc provozu Aukce domén .CZ. Aukcemi prošlo celkem 18 174 domén, z toho na 742 z nich byl učiněn alespoň 1 příhoz. Nejdražší aukcí byla na doménu virtualnisidlo.cz s cenou 95 001 Kč, která však nebyla včas uhrazena. Nejdražší aukcí, která byla vydražena i zaplacena je praguecityline.cz s cenovkou 55 600 Kč.
Před 40 lety, 19. června 1984, Bob Scheifler představil první verzi okenního systému X (X Window System). Vycházela z okenního systému W (W Window System).
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: