Projekt VideoLAN a multimediální přehrávač VLC (Wikipedie) dnes slaví 25 let. Vlastní, tenkrát ještě studentský projekt, začal již v roce 1996 na vysoké škole École Centrale Paris. V první únorový den roku 2001 ale škola oficiálně povolila přelicencování zdrojových kódů na GPL a tím pádem umožnila používání VLC mimo akademickou půdu.
Moltbook je sociální síť podobná Redditu, ovšem pouze pro agenty umělé inteligence - lidé se mohou účastnit pouze jako pozorovatelé. Agenti tam například rozebírají podivné chování lidí, hledají chyby své vlastní sociální sítě, případně spolu filozofují o existenciálních otázkách 🤖.
scx_horoscope je „vědecky pochybný, kosmicky vtipný“ plně funkční plánovač CPU založený na sched_ext. Počítá s polohami Slunce a planet, fázemi měsíce a znameními zvěrokruhu. Upozornil na něj PC Gamer.
O víkendu probíhá v Bruselu konference FOSDEM 2026 (Free and Open source Software Developers’ European Meeting). Program konference je velice nabitý: 37 místností, 71 tracků, 1184 přednášejících, 1069 přednášek, prezentací a workshopů. Sledovat je lze i online. K dispozici budou jejich videozáznamy. Aktuální dění lze sledovat na sociálních sítích.
Společnost Nex Computer stojící za "notebooky bez procesorů a pamětí" NexDock představila telefon NexPhone, který může funguje jako desktop PC, stačí k němu připojit monitor, klávesnici a myš nebo NexDock. Telefon by měl být k dispozici ve třetím čtvrtletí letošního roku. Jeho cena by měla být 549 dolarů. Předobjednat jej lze s vratní zálohou 199 dolarů. V dual-bootu by měl být předinstalovaný Android s Linuxem (Debian) jako aplikací a Windows 11.
Byla vydána nová major verze 9.0 softwaru pro správu elektronických knih Calibre (Wikipedie). Přehled novinek v poznámkách k vydání. Vypíchnuta je podpora AI.
Wasmer byl vydán ve verzi 7.0. Jedná se o běhové prostředí pro programy ve WebAssembly. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT.
V reakci na nepopulární plán Microsoftu ještě více ve Windows prohloubit integraci umělé inteligence Copilot, Opera na sociální síti 𝕏 oznámila, že připravuje nativní linuxovou verzi prohlížeče Opera GX. Jedná se o internetový prohlížeč zaměřený pro hráče, přičemž obsahuje všechny základní funkce běžného prohlížeče Opera. Kromě integrace sociálních sítí prohlížeč například disponuje 'omezovačem', který umožňuje uživatelům omezit využití sítě, procesoru a paměti prohlížečem, aby se tak šetřily systémové zdroje pro jinou aktivitu.
NVIDIA vydala nativního klienta své cloudové herní služby GeForce NOW pro Linux. Zatím v beta verzi.
Open Gaming Collective (OGC) si klade za cíl sdružit všechny klíčové projekty v oblasti linuxového hraní počítačových her. Zakládajícími členy jsou Universal Blue a Bazzite, ASUS Linux, ShadowBlip, PikaOS a Fyra Labs. Strategickými partnery a klíčovými přispěvateli ChimeraOS, Nobara, Playtron a další. Cílem je centralizovat úsilí, takže namísto toho, aby každá distribuce udržovala samostatné opravy systému a podporu hardwaru na
… více »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: