V Redisu byla nalezena a v upstreamu již opravena kritická zranitelnost CVE-2025-49844 s CVSS 10.0 (RCE, vzdálené spouštění kódu).
Ministr a vicepremiér pro digitalizaci Marian Jurečka dnes oznámil, že přijme rezignaci ředitele Digitální a informační agentury Martina Mesršmída, a to k 23. říjnu 2025. Mesršmíd nabídl svou funkci během minulého víkendu, kdy se DIA potýkala s problémy eDokladů, které některým občanům znepříjemnily využití možnosti prokázat se digitální občankou u volebních komisí při volbách do Poslanecké sněmovny.
Společnost Meta představila OpenZL. Jedná se o open source framework pro kompresi dat s ohledem na jejich formát. Zdrojové kódy jsou k dispozici na GitHubu.
Google postupně zpřístupňuje českým uživatelům Režim AI (AI Mode), tj. nový režim vyhledávání založený na umělé inteligenci. Režim AI nabízí pokročilé uvažování, multimodalitu a možnost prozkoumat jakékoliv téma do hloubky pomocí dodatečných dotazů a užitečných odkazů na weby.
Programovací jazyk Python byl vydán v nové major verzi 3.14.0. Podrobný přehled novinek v aktualizované dokumentaci.
Bylo oznámeno, že Qualcomm kupuje Arduino. Současně byla představena nová deska Arduino UNO Q se dvěma čipy: MPU Qualcomm Dragonwing QRB2210, na kterém může běžet Linux, a MCU STM32U585 a vývojové prostředí Arduino App Lab.
Multiplatformní open source voxelový herní engine Luanti byl vydán ve verzi 5.14.0. Podrobný přehled novinek v changelogu. Původně se jedná o Minecraftem inspirovaný Minetest v říjnu loňského roku přejmenovaný na Luanti.
Byla vydána nová stabilní verze 6.10 (YouTube) multiplatformního frameworku a GUI toolkitu Qt. Podrobný přehled novinek v poznámkách k vydání.
Netwide Assembler (NASM) byl vydán v nové major verzi 3.00. Přehled novinek v poznámkách k vydání v aktualizované dokumentaci.
Ajax GUI framework qooxdoo se dočkal verze 1.2. Ta přináší lepší podporu Selenium pro tvorbu automatických testů. Dále je novinkou virtual list, který pojme mnohem větší množství dat. Opraveno bylo na 200 bugů. Vývojáři se chlubí rozsáhlým manuálem čítajícím 400 stran. Ten je nově přístupný přes SVN. Více detailů v oficiálním oznámení.
Tiskni
Sdílej:
var simple = new Ext.form.FormPanel({ standardSubmit: true, frame: true, title: 'Register', width: 350, defaults: { width: 230 }, defaultType: 'textfield', items: [{ fieldLabel: 'Username', name: 'username', allowBlank: false }, { inputType: 'hidden', id: 'submitbutton', name: 'myhiddenbutton', value: 'hiddenvalue' } ], buttons: [{ text: 'Submit', handler: function () { simple.getForm().getEl().dom.action = 'test.php'; simple.getForm().getEl().dom.method = 'POST'; simple.getForm().submit(); } }] });ako
qx.Class.define("twitter.LoginWindow", { extend: qx.ui.window.Window, construct: function () { this.base(arguments, "Login", "twitter/t_small-c.png"); } }); var layout = new qx.ui.layout.Basic(); this.setLayout(layout); this.setModal(true); var form = new qx.ui.form.Form(); var username = new qx.ui.form.TextField(); username.setRequired(true); form.add(username, "Username", null, "username"); var password = new qx.ui.form.PasswordField(); password.setRequired(true); form.add(password, "Password", null, "password"); var controller = new qx.data.controller.Form(null, form); var model = controller.createModel(); var loginbutton = new qx.ui.form.Button("Login"); form.addButton(loginbutton); var cancelbutton = new qx.ui.form.Button("Cancel"); form.addButton(cancelbutton); cancelbutton.addListener("execute", function () { this.close(); }, this);Oba kódy robia formuláre, ale keďže sa mi nechce čítať dokumentácia k qooxdoo, tak vyzerajú a fungujú mierne inak, ale snáď sa na tom kóde dá vidieť, v čom je hlavný rozdiel. Hlavná výhoda (pre mňa) je to, že si nemusím pamätať poradie parametrov funkcií (a keďže to funguje práve takto, tak sa dá celá tá štruktúra poslať ako JSON zo serveru a jedným volaním funkcie sa potom vytvorí nové okno...).
qx.Class.define("ex.template.Editor", { extend: ex.data.form.DaoFormWindow, construct: function(dao, data) { // Call superclass constructor. this.base(arguments, dao, data); }, members: { createForm: function() { this.createItems({ items: [ { className: "ex.data.form.TextField" , id: "name" , autoLabel: true }, { className: "ex.data.form.TextField" , id: "title" , autoLabel: true }, { className: "ex.data.form.TextArea" , id: "content" , autoLabel: true, rowFlex: 1 } ] }); this.createRules({ rules: [ { className: "ex.data.form.Rule" , id: "name" , required: true } ] }); }, applyPersistent: function(persistent) { this.setItemsEnabled(["name"], !persistent); } } });Já chápu qooxdoo jako low level toolkit, kde si člověk musí naprogramovat vlastní datovou a formulářovou vrstvu. To co tam je mi přijde jako hodně jednoduché. Na druhou stranu moje vrstva má asi 2000 řádků a řeší formuláře, jejich layout a data access.