Byla vydána nová verze 1.16.0 klienta a serveru VNC (Virtual Network Computing) s názvem TigerVNC (Wikipedie). Z novinek lze vypíchnout nový server w0vncserver pro sdílení Wayland desktopu. Zdrojové kódy jsou k dispozici na GitHubu. Binárky na SourceForge. TigerVNC je fork TightVNC.
Byla vydána nová verze 4.6 (𝕏, Bluesky, Mastodon) multiplatformního open source herního enginu Godot (Wikipedie, GitHub). Přehled novinek i s náhledy v příspěvku na blogu.
Rozsáhlá modernizace hardwarové infrastruktury Základních registrů měla zabránit výpadkům digitálních služeb státu. Dnešnímu výpadku nezabránila.
Čínský startup Kimi představil open-source model umělé inteligence Kimi K2.5. Nová verze pracuje s textem i obrázky a poskytuje 'paradigma samosměřovaného roje agentů' pro rychlejší vykonávání úkolů. Kimi zdůrazňuje vylepšenou schopnost modelu vytvářet zdrojové kódy přímo z přirozeného jazyka. Natrénovaný model je dostupný na Hugging Face, trénovací skripty však ne. Model má 1 T (bilion) parametrů, 32 B (miliard) aktivních.
V Raspberry Pi OS lze nově snadno povolit USB Gadget Mode a díky balíčku rpi-usb-gadget (CDC-ECM/RNDIS) mít možnost se k Raspberry Pi připojovat přes USB kabel bez nutnosti konfigurování Wi-Fi nebo Ethernetu. K podporovaným Raspberry Pi připojeným do USB portu podporujícího OTG.
Konference Installfest 2026 proběhne o víkendu 28. a 29. března v budově FELu na Karlově náměstí v Praze. Přihlásit přednášku nebo workshop týkající se Linuxu, otevřených technologií, sítí, bezpečnosti, vývoje, programování a podobně lze do 18. února 0:15.
Fedora Flock 2026, tj. konference pro přispěvatele a příznivce Fedory, bude opět v Praze. Proběhne od 14. do 16. června. Na Flock navazuje DevConf.CZ 2026, který se uskuteční 18. a 19. června v Brně. Organizátoři konferencí hledají přednášející, vyhlásili Call for Proposals (CfP).
Z80-μLM je jazykový model 'konverzační umělé inteligence' optimalizovaný pro běh na 8-bitovém 4Mhz procesoru Z80 s 64kB RAM, technologii z roku 1976. Model používá 2-bitovou kvantizaci a trigramové hashování do 128 položek, což umožňuje zpracování textu i při velmi omezené paměti. Natrénovaný model se vejde do binárního souboru velkého pouhých 40 KB. Tento jazykový model patrně neprojde Turingovým testem 😅.
Digitální a informační agentura (DIA) na přelomu roku dokončila rozsáhlou modernizaci hardwarové infrastruktury základních registrů. Projekt za 236 milionů korun by měl zabránit výpadkům digitálních služeb státu, tak jako při loňských parlamentních volbách. Základní registry, tedy Registr práv a povinností (RPP), Informační systém základních registrů (ISZR) a Registr obyvatel (ROB), jsou jedním z pilířů veřejné správy. Denně
… více »Evropská komise (EK) zahájila nové vyšetřování americké internetové platformy 𝕏 miliardáře Elona Muska, a to podle unijního nařízení o digitálních službách (DSA). Vyšetřování souvisí se skandálem, kdy chatbot s umělou inteligencí (AI) Grok na žádost uživatelů na síti 𝕏 generoval sexualizované fotografie žen a dětí. Komise o tom dnes informovala ve svém sdělení. Americký podnik je podezřelý, že řádně neposoudil a nezmírnil rizika spojená se zavedením své umělé inteligence na on-line platformě.
Stručný návod pro převod LibGlade.xml na GtkBuilder.xml, který nemusí pokrývat vše co se může při konverzi pokazit.
Glade 3.8.x umí pracovat s LibGlade i GtkBuilder, je určen pro GTK+2. Naproti tomu novější verze jsou určené pouze pro GTK+3. Debian Wheezy bohužel obsahuje pouze verzi pro GTK+3, Bug #638478: allow installing both glade 3.8 and 3.10.
Nejprve si otevřeme LibGlade.xml v Glade 3.8.x, poté uložíme projekt jako GtkBuilder.xml a při ukládání nezapomeneme přepnout radiobutton na GtkBuilder.
U všech widgetů, které využívají property "adjustment", ztratíme toto nastavení. Můžeme to napravit zavoláním následujícího skriptu, kterému se předají dva argumenty reprezentující dva výše uvedené XML soubory. Z LibGlade.xml se načte property "adjustment" jednotlivých witgetů, přidá se k odpovídajícím widgetům z GtkBuilder.xml a výsledek se vypíše na stdout.
$ ./g2b_gtkscale.py LibGlade.xml GtkBuilder.xml >output.xml
#! /usr/bin/env python2.7
# -*- coding: utf-8 -*-
import sys
from lxml import etree
class G2B_GtkScale:
def __init__(self, lib_glade_xml, gtk_builder_xml):
lib_glade_doc = etree.parse(lib_glade_xml)
self.lib_glade_root = lib_glade_doc.getroot()
parser = etree.XMLParser(remove_blank_text=True)
gtk_builder_doc = etree.parse(gtk_builder_xml, parser)
self.gtk_builder_root = gtk_builder_doc.getroot()
# LibGlade
# <widget class="GtkHScale" id="NAME">
# <property name="adjustment">-255 -255 255 1 0 0</property>
# </widget>
# GtkBuilder
# <widget class="GtkHScale" id="NAME">
# <property name="adjustment">NAME_ADJ</property>
# </widget>
lib_glade_elts = self.get_elements(lib_glade_doc, "widget")
gtk_builder_elts = self.get_elements(gtk_builder_doc, "object")
for key in lib_glade_elts.keys():
adjs = lib_glade_elts[key].text.split()
prop_adj = gtk_builder_elts[key]
self.glade2builder(key, adjs, prop_adj)
print etree.tostring(self.gtk_builder_root, pretty_print=True, \
xml_declaration=True, encoding="UTF-8")
def get_elements(self, doc, name):
result = {}
elements = doc.findall(".//%s" % name)
for element in elements:
eclass = element.get("class")
eid = element.get("id")
if (eclass in ["GtkHScale", "GtkVScale", "GtkSpinButton"]):
for subelt in element.findall("property"):
name = subelt.get("name")
if (name == "adjustment"):
result[eid] = subelt
return result
def glade2builder(self, eid, adjs, prop_adj):
# <object class="GtkAdjustment" id="NAME_ADJ">
# <property name="lower">0</property>
# <property name="upper">100</property>
# <property name="step_increment">1</property>
# <property name="page_increment">10</property>
# </object>
oid = "%s_ADJ" % eid
elt_adj = etree.SubElement(self.gtk_builder_root, "object")
elt_adj.set("class", "GtkAdjustment")
elt_adj.set("id", oid)
#value, lower, upper, step_inc, page_inc, page_size = adjs
props = ["lower", "upper", "step_increment", "page_increment"]
idx = 1
for prop in props:
elt_prop = etree.SubElement(elt_adj, "property")
elt_prop.set("name", prop)
elt_prop.text = adjs[idx]
idx += 1
prop_adj.text = oid
#print etree.tostring(elt_adj, pretty_print=True)
def main():
if (len(sys.argv) != 3):
print "Usage: %s LibGlade.xml GtkBuilder.xml" % sys.argv[0]
sys.exit()
G2B_GtkScale(sys.argv[1], sys.argv[2])
if __name__ == '__main__':
main()
Podrobněji jsem se tím nezabýval, soustředil jsem se pouze na převod svých projektů. Třeba to bude užitěčné i někomu dalšímu. Pokud máte nějakou připomínku, nápad či dotaz, na toto téma, pište do diskuze.
Na základě podnětu diskutujícího chrono uvádím druhé řešení, ke kterému není třeba Glade.
libgtk2.0-dev: /usr/bin/gtk-builder-convert
Výše uvedený distribuční skript nastavuje u nově vytvářených GtkAdjustment id na adjustment1 až adjustmentN. Já chci, aby toto id reprezentovalo id widgetu, ke kterému GtkAdjustment patří, tj. přidá se k němu suffix "_adj".
Řeší to drobná úprava distribučního skriptu gtk-builder-convert
Tiskni
Sdílej:
# aptitude install libgtk2.0-dev $ gtk-builder-convert LibGlade.xml GtkBuilder.xml
Děkuji za připomínku, i Pythonovský skript gtk-builder-convert řeší property "adjustment", ovšem nastavuje u GtkAdjustment id na adjustment1 až adjustmentN, takže se v tom člověk ztratí. Já nastavuji id na základě názvu widgetu, ke kterému patří tj. NAME_ADJ.