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.
Byla vydána beta verze Ubuntu 26.04 LTS s kódovým názvem Resolute Raccoon. Přehled novinek v poznámkách k vydání. Dle plánu by Ubuntu 26.04 LTS mělo vyjít 23. dubna 2026.
Byla vydána aktualizována Příručka pro začínající wikipedisty a wikipedistky (pdf).
Ubuntu plánuje v budoucích verzích nahradit tradiční nástroje pro synchronizaci času (chrony, linuxptp a gpsd) novým, v Rustu napsaným ntpd-rs, který nabídne vyšší bezpečnost a stabilitu.
Byla vydána nová verze 7.6 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Správce hesel KeePassXC byl nahrazen správcem hesel GNOME Secrets. Bitcoinová peněženka Electrum byla povýšena na verzi 4.7.0. Tor Browser byl povýšen na verzi 15.0.8. Další novinky v příslušném seznamu.
Chris Down v obsáhlém článku „vyvrací mýty o zswap a zram“, vysvětluje, co vlastně dělají a jaké jsou mezi nimi rozdíly. Doporučuje vyhýbat se zram na serveru a bez OOM.
Porota v Los Angeles shledala firmy Google a Meta odpovědnými v přelomovém soudním sporu, který se týká závislosti na sociálních sítích; firmy musí zaplatit odškodné tři miliony dolarů (63,4 milionu Kč). Společnosti, které s verdiktem nesouhlasí, čelily obvinění, že své sociální sítě a platformy záměrně navrhly tak, aby si na nich děti vypěstovaly závislost. Porota došla k závěru, že technologické společnosti při navrhování a
… více »Jelikož vývojáři editorů Vim a Neovim začali při vývoji využívat LLM, Drew DeVault se rozhodl forknout Vim a vytvořil projekt Vim Classic. Vychází z Vimu 8.2.0148, tj. těsně před zavedením Vim9 skriptování.
Byla vydána nová verze 0.56 open source počítačové hry Unvanquished (Wikipedie), forku počítačové hry Tremulous. Instalovat ji lze také z Flathubu.
CREATE FUNCTION accounting.basefun(
IN var_year character,
IN var_month character)
RETURNS TABLE(
account character,
debit11 double precision,
credit11 double precision,
debit double precision,
credit double precision,
debitxx double precision,
creditxx double precision) AS
$BODY$
.....
......
Nyní potřebuji ji použít jako zdroj dat v jiné funkci , tam jsem narazil na problém s identifikací sloupců.
CREATE FUNCTION extfun(
IN var_year character,
IN var_month character)
RETURNS TABLE(
account character,
accountname character,
debit11 double precision,
credit11 double precision,
debit double precision,
credit double precision,
debit1x double precision,
credit1x double precision,
debitxx double precision,
creditxx double precision,
debitact double precision,
creditact double precision
) AS
$BODY$
SELECT
ledg.account, //error
Zde nemohu přijít jak identifikovat sloupce
ledg.debit11,
ledg.credit11
.........
FROM
(SELECT
accounting.basechangeledger(var_year,var_month)
) AS ledg
$BODY$
Předem dík za nakopnutí správným směrem.
Řešení dotazu:
(SELECT * FROM accounting.basechangeledger(var_year,var_month) ) AS ledgTvůj zápis sešrotuje sloupce do pole a vrací to jako jeden sloupec, jestli se nepletu.
CREATE FUNCTION accounting.test(
IN var_year character,
IN var_month character)
RETURNS TABLE(
account character,
debit11 double precision,
credit11 double precision,
debit double precision,
credit double precision,
debitxx double precision,
creditxx double precision
) AS
$BODY$
SELECT
*
FROM
(SELECT
accounting.basefunc(var_year,var_month)
) AS ledg
$BODY$
LANGUAGE sql VOLATILE
SELECT accounting.basefunc(var_year,var_month) vola funkciu vracajucu "sadu" (set returning function). Ak ju zavolas priamo v SELECT klauzule, tak musi vratit cely viacstlpcovy riadok v jedinom stlpci typu ROW(*). Predrecnik to sice chybne oznacil ako pole, ale trafil pricinu problemu. Je to to iste, ako keby si zavolal
SELECT ROW(e.*) FROM accounting.basefunc(var_year,var_month);
Ak chces pracovat s jednotlivymi stlpcami, musis to volat ako SELECT * FROM accounting.basefunc(var_year,var_month).
Tvoja funkcia by potom mohla vyzerat takto:
BODY$
SELECT
ledg.*,
ledg.debit11,
ledg.credit11
FROM
(SELECT *
FROM accounting.basechangeledger(var_year,var_month)
) AS ledg
$BODY$
co je ale to iste ako:
BODY$
SELECT
ledg.*,
ledg.debit11,
ledg.credit11
FROM accounting.basechangeledger(var_year,var_month) AS ledg
$BODY$
Tiskni
Sdílej: