Nástroj sql-tap je proxy mezi aplikací a databází, které zachytává všechny SQL dotazy a zobrazuje je v terminálovém rozhraní. Zde lze téměř v reálném čase zkoumat dotazy, sledovat transakce a spouštět SQL příkaz EXPLAIN. Podporované databázové systémy jsou pouze PostgreSQL a MySQL. Zdrojový kód je dostupný na GitHubu, pod licencí MIT.
Byla vydána nová verze 9.2 textového editoru Vim (Vi IMproved). Přináší vylepšené doplňování, podporu schránky ve Waylandu, podporu XDG Base Directory (konfigurace v $HOME/.config/vim), vylepšené Vim9 skriptování nebo lepší zvýrazňování změn. Vim zůstává charityware. Nadále vybízí k podpoře dětí v Ugandě. Z důvodu úmrtí autora Vimu Brama Moolenaara a ukončení činnosti jím založené charitativní organizace ICCF Holland projekt Vim navázal spolupráci s charitativní organizaci Kuwasha.
Byl představen editor MonoSketch, webová aplikace pro tvorbu diagramů, technických nákresů, flowchartů a různých dalších vizualizací, to vše jenom z ASCII znaků. Všechny operace běží pouze v prohlížeči uživatele a neprobíhá tedy žádné nahrávání dat na server. Zdrojový kód aplikace (drtivá většina Kotlin, žádné C#) je dostupný na GitHubu pod licencí Apache 2.0.
Byla vydána nová verze 3.7.0 multiplatformního svobodného frameworku pro zpracování obrazu G'MIC (GREYC's Magic for Image Computing, Wikipedie). Přehled novinek i s náhledy nových filtrů na PIXLS.US.
Všem na AbcLinuxu vše nejlepší k Valentýnu aneb Dni lásky ke svobodnému softwaru (I love Free Software Day, Mastodon, 𝕏).
Eric Migicovsky představil Pebble Emulator, tj. emulátor hodinek Pebble (PebbleOS) běžící ve webovém prohlížeči. Za 6 hodin jej napsal Claude Code. Zdrojové kódy jsou k dispozici na GitHubu.
Byla vydána nová verze 3.41 frameworku Flutter (Wikipedie) pro vývoj mobilních, webových i desktopových aplikací a nová verze 3.11 souvisejícího programovacího jazyka Dart (Wikipedie).
Rusko zcela zablokovalo komunikační platformu WhatsApp, řekl včera mluvčí Kremlu Dmitrij Peskov. Aplikace, jejímž vlastníkem je americká společnost Meta Platforms a která má v Rusku na 100 milionů uživatelů, podle Peskova nedodržovala ruské zákony. Mluvčí zároveň lidem v Rusku doporučil, aby začali používat domácí aplikaci MAX. Kritici tvrdí, že tato aplikace ruské vládě umožňuje lidi sledovat, což úřady popírají.
Před 34 lety, ve čtvrtek 13. února 1992, se tehdejší Česká a Slovenská Federativní Republika oficiálně (a slavnostně) připojila k Internetu.
Agent umělé inteligence vytvořil 'útočný' článek o Scottu Shambaughovi, dobrovolném správci knihovny matplotlib, poté, co vývojář odmítl agentem navrženou změnu kódu (pull request). 'Uražený' agent autonomně sepsal a publikoval na svém blogu článek, který přisuzuje Shambaughovi smyšlené motivace, egoismus a strach z AI coby konkurence.
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: