Na crowdsourcingové platformě Crowd Supply byla spuštěna kampaň na podporu open source biometrického monitoru ve tvaru hodinek HealthyPi Move. Cena je 249 dolarů a plánovaný termín dodání listopad letošního roku.
Firma Murena představila /e/OS verze 2.0. Jde o alternativní sestavení Androidu bez aplikací Google. Mezi novinkami je podrobnější nastavení ochrany soukromí před sledováním aplikacemi. Murena prodává několik smartphonů s předinstalovaným /e/OS (Fairphone, repasovaný Google Pixel 5).
Do 30. května lze v rámci akce Warhammer Skulls 2024 získat na Steamu zdarma hru Warhammer 40,000: Gladius - Relics of War.
HelenOS (Wikipedie), tj. svobodný operační systém českého původu založený na architektuře mikrojádra, byl vydán ve verzi 0.14.1. Přehled novinek v poznámkách k vydání. Vypíchnou lze nabídku Start. Videopředstavení na YouTube.
BreadboardOS je firmware pro Raspberry Pi Pico (RP2040) umožňující s tímto MCU komunikovat pomocí řádkového rozhraní (CLI). Využívá FreeRTOS a Microshell.
Vývojáři KDE oznámili vydání balíku aplikací KDE Gear 24.05. Přehled novinek i s náhledy a videi v oficiálním oznámení. Do balíku se dostalo 5 nových aplikací: Audex, Accessibility Inspector, Francis, Kalm a Skladnik.
Byla vydána (𝕏) nová verze 18.0.0 open source webového aplikačního frameworku Angular (Wikipedie). Přehled novinek v příspěvku na blogu.
V neděli 26. května lze navštívit Maker Faire Rychnov nad Kněžnou, festival plný workshopů, interaktivních činností a především nadšených a zvídavých lidí.
Byla vydána nová stabilní verze 3.20.0, tj. první z nové řady 3.20, minimalistické linuxové distribuce zaměřené na bezpečnost Alpine Linux (Wikipedie) postavené na standardní knihovně jazyka C musl libc a BusyBoxu. Z novinek lze vypíchnou počáteční podporu 64bitové architektury RISC-V.
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: