Organizátoři Dne IPv6, tradiční akce věnované tématům spojeným s tímto protokolem, vyhlásili Call for Abstracts. Na webu konference mohou zájemci přihlašovat příspěvky o délce 20 nebo 40 minut či 10minutové lighting talky a to až do 30. dubna. Tvůrci programu uvítají návrhy přednášek z akademického i komerčního sektoru, které mohou být technického i netechnického zaměření. Den IPv6 se letos uskuteční 4. června a místem konání bude i
… více »Euro-Office (Wikipedie) je evropský fork open source kancelářského balíku OnlyOffice. Za forkem stojí koalice firem IONOS, Nextcloud, Eurostack, XWiki, OpenProject, Soverin, Abilian a BTactic. Cílem je zajistit digitální suverenitu Evropy a snížit závislost na neevropských platformách. Projekt vznikl mimo jiné v reakci na nedávné uzavření cloudové služby OnlyOffice. OnlyOffice obviňuje Euro-Office z porušení licenčních podmínek. Na možné problémy upozorňuje i Collabora Online. Jednostranná změna licence není v pořádku.
Byly zpracovány a na YouTube zveřejněny videozáznamy jednotlivých přednášek z letošního Installfestu.
Během akce Arduino Days 2026 byl publikován Arduino Open Source Report 2025 (pdf) a oznámeno 7 nových produktů kompatibilních s deskou UNO Q (Arduino USB-C Power Supply, USB-C Cable, USB-C Hub, UNO Media Carrier, UNO Breakout Carrier, Bug Hopper, Modulino LED Matrix).
Google v pátek spustil v Česku Vyhledávání Live. Tato novinka umožňuje lidem vést plynulou konverzaci s vyhledávačem v češtině. A to prostřednictvím hlasu, nebo prostřednictvím toho, na co ukážou svým fotoaparátem či kamerou v mobilu. Rozšíření této multimodální funkce je možné díky nasazení Gemini 3.1 Flash Live, nového hlasového a audio modelu, který je od základu vícejazyčný, takže umožňuje lidem po celém světě mluvit na vyhledávač přirozeně a v jazyce, který je jim nejbližší.
Jsongrep je open-source nástroj, který efektivně prohledává JSON dokumenty (editovat je neumí). Kompiluje regulérní jazyk dotazu do podoby deterministického konečného automatu (DFA), díky čemuž prochází strom JSON dokumentu pouze jednou a je v tom tedy rychlejší než jiné nástroje jako jsou například jq, JMESPath nebo jql. Jsongrep je napsaný v programovacím jazyce Rust, zdrojový kód je dostupný na GitHubu.
O víkendu probíhá v Praze na Karlově náměstí 13 konference Installfest 2026. Na programu je celá řada zajímavých přednášek a workshopů. Vstup na konferenci je zcela zdarma, bez nutnosti registrace. Přednášky lze sledovat i online na YouTube.
Mozilla a společnost Mila oznámily strategické partnerství za účelem rozvoje open source a suverénní AI. Cílem je ukázat, že open source AI může konkurovat uzavřeným systémům. Obě organizace chtějí posílit technologickou suverenitu a snížit závislost na hrstce velkých technologických firem.
Adam Rice předvedl, že pomocí DNS lze distribuovat a spustit kompletní hru DOOM. Rozdělil WAD soubory a binárky do téměř 2000 DNS záznamů v Cloudflare zóně (jeden TXT záznam v DNS může nést okolo 2000 znaků textu). Ty pak stáhl PowerShellem, dekomprimoval a spustil přímo v paměti počítače bez nutnosti zápisu na disk, což prakticky dokazuje, že DNS může sloužit jako distribuované úložiště dat a možný kanál pro načítání kódu. Repozitář projektu je na GitHubu.
Dnes a zítra probíhají Arduino Days 2026. Na programu je řada zajímavých přednášek. Sledovat je lze od 17:00 na YouTube. Zúčastnit se lze i lokálních akcí. Dnes v Poličce v městské knihovně a zítra v Praze na Matfyzu.
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.