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.
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.
split_string, ktora berie parameter ret ako navratovu hodnotu. Potom naalokuje dvojrozmerne pole. A spravne.
int split_string (char **ret, char *str, unsigned char del)
{
ret = (char **) malloc (sizeof (char *) * (count + 1));
ret[i] = (char *) malloc (sizeof (char) * (strlen (back_str) + 1));
}
Potom ju volam na tomto mieste:
char **row_parts = NULL;
unsigned int parts_count = split_string (row_parts, line, ';');
Tu to ale spadne.
printf ("%u %s\n", parts_count, row_parts[0]);
Preco je row_parts[0] nepovoleny pristup do pamati ak ret[0] v split_string je normalne dostupny?
Prikladam este vystup z debuggera:
Program received signal EXC_BAD_ACCESS, Could not access memory.
Reason: KERN_PROTECTION_FAILURE at address: 0x00000000
parse_row (line=0x400150 "chalupa") at proj4.c:169
169 printf ("%u %s\n", parts_count, row_parts[0]);
(gdb)
Vopred dakujem za kazdu radu.
Řešení dotazu:
split_string, proměnnou back_str atd.
Reason: KERN_PROTECTION_FAILURE at address: 0x00000000Přistupujete na adresu 0, čili derefernce NULL-pointeru. Skoro bych řekl, že tam ty hvězdičky v hlavičce funkce mají být 3 a parametr by se měl předávat jako
&row_parts), protože takhle to IMHO nezměníte. Čili bude stále NULL.
int split_string (char ***ret, char *str, unsigned char del)
{
...//tu sa s ret nepracuje
*ret = (char **) malloc (sizeof (char *) * (count + 1));
back_str = str;
for (i = 0; *back_str && i < strlen (str); i++)
{
printf ("%u: %ld", i, strlen (back_str));
*ret[i] = (char *) malloc (sizeof (char) * (strlen (back_str) + 1));
Povodne som to aj mal s tymi 3 "hviezdickami", ale potom mam chybu vnutri tej split_string.
Program received signal EXC_BAD_ACCESS, Could not access memory.
Reason: KERN_PROTECTION_FAILURE at address: 0x00000c00
0x00002a25 in split_string (ret=0xbffff55c, str=0x400150 "chalupa", del=59 ';') at proj4.c:244
244 *ret[i] = (char *) malloc (sizeof (char) * (strlen (back_str) + 1));
To sa mi ale velmi nezda, ten ret by uz mal byt na tom mieste alokovany ako ukazovatel na ukazovatele alebo sa mylim?
Este pre uplnost, tie ostatne premenne su nastavene spravne, takze by to miesto malo byt naalokovane dobre, sice neosetrujem tam zatial chyby mallocu, ale pamati mam zatial viac nez dost.
Dakujem za radu, nechcem byt nezdvorili, ale cely zdrojak sem dat nemozem.Taky nechci být nezdvořilý, ale tímhle si dost rapidně snížíte počet lidí, co budou ochotni odpovídat. O to ale nejde.
Povodne som to aj mal s tymi 3 "hviezdickami", ale potom mam chybu vnutri tej split_string.Střelím od boku, protože po půlnoci si s prioritou nejsem úplně jistý - je
*ret[i] správně uzávorkované - nemá to být (*ret)[i]?
Tiskni
Sdílej: