Projekt VideoLAN a multimediální přehrávač VLC (Wikipedie) dnes slaví 25 let. Vlastní, tenkrát ještě studentský projekt, začal již v roce 1996 na vysoké škole École Centrale Paris. V první únorový den roku 2001 ale škola oficiálně povolila přelicencování zdrojových kódů na GPL a tím pádem umožnila používání VLC mimo akademickou půdu.
Moltbook je sociální síť podobná Redditu, ovšem pouze pro agenty umělé inteligence - lidé se mohou účastnit pouze jako pozorovatelé. Agenti tam například rozebírají podivné chování lidí, hledají chyby své vlastní sociální sítě, případně spolu filozofují o existenciálních otázkách 🤖.
scx_horoscope je „vědecky pochybný, kosmicky vtipný“ plně funkční plánovač CPU založený na sched_ext. Počítá s polohami Slunce a planet, fázemi měsíce a znameními zvěrokruhu. Upozornil na něj PC Gamer.
O víkendu probíhá v Bruselu konference FOSDEM 2026 (Free and Open source Software Developers’ European Meeting). Program konference je velice nabitý: 37 místností, 71 tracků, 1184 přednášejících, 1069 přednášek, prezentací a workshopů. Sledovat je lze i online. K dispozici budou jejich videozáznamy. Aktuální dění lze sledovat na sociálních sítích.
Společnost Nex Computer stojící za "notebooky bez procesorů a pamětí" NexDock představila telefon NexPhone, který může funguje jako desktop PC, stačí k němu připojit monitor, klávesnici a myš nebo NexDock. Telefon by měl být k dispozici ve třetím čtvrtletí letošního roku. Jeho cena by měla být 549 dolarů. Předobjednat jej lze s vratní zálohou 199 dolarů. V dual-bootu by měl být předinstalovaný Android s Linuxem (Debian) jako aplikací a Windows 11.
Byla vydána nová major verze 9.0 softwaru pro správu elektronických knih Calibre (Wikipedie). Přehled novinek v poznámkách k vydání. Vypíchnuta je podpora AI.
Wasmer byl vydán ve verzi 7.0. Jedná se o běhové prostředí pro programy ve WebAssembly. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT.
V reakci na nepopulární plán Microsoftu ještě více ve Windows prohloubit integraci umělé inteligence Copilot, Opera na sociální síti 𝕏 oznámila, že připravuje nativní linuxovou verzi prohlížeče Opera GX. Jedná se o internetový prohlížeč zaměřený pro hráče, přičemž obsahuje všechny základní funkce běžného prohlížeče Opera. Kromě integrace sociálních sítí prohlížeč například disponuje 'omezovačem', který umožňuje uživatelům omezit využití sítě, procesoru a paměti prohlížečem, aby se tak šetřily systémové zdroje pro jinou aktivitu.
NVIDIA vydala nativního klienta své cloudové herní služby GeForce NOW pro Linux. Zatím v beta verzi.
Open Gaming Collective (OGC) si klade za cíl sdružit všechny klíčové projekty v oblasti linuxového hraní počítačových her. Zakládajícími členy jsou Universal Blue a Bazzite, ASUS Linux, ShadowBlip, PikaOS a Fyra Labs. Strategickými partnery a klíčovými přispěvateli ChimeraOS, Nobara, Playtron a další. Cílem je centralizovat úsilí, takže namísto toho, aby každá distribuce udržovala samostatné opravy systému a podporu hardwaru na
… více »
typedef struct
{
int x;
const char **pole;
} Struktura;
#define STRUKTURA(__jmeno__, __x__, __pole__) \
Struktura __jmeno__ = { __x__, __pole__ };
A nedaří se mi docílit požadovaného výsledku. Zkouším to zavolat takto:
STRUKTURA(jmeno, 10, {"bla", "bla2", "bla3"})
Ale preprocesor na mě řve, že jsem makru předal 5 argumentů místo 3
Napisat makro s "neznamym" poctom parametrov nie je problem,
makro:
#define STRUKTURA(jmeno, x, pole...) Struktura jmeno = { x , { pole } }
sa expanduje ako:
Struktura jmeno = { 10 , { "bla", "bla1", "bla2" } };
problem je v tom, ze toto kompilator Cecka nezozere:
typedef struct
{
int x;
char *pole[];
} Struktura_1;
typedef struct
{
int x;
char **pole;
} Struktura_2;
typedef struct
{
int x;
const char *pole[];
} Struktura_3;
typedef struct
{
int x;
const char **pole;
} Struktura_4;
typedef struct
{
int x;
const char *pole[8];
} Struktura_5;
int main()
{
/*
Struktura_1 jmeno = { 10, {"bla", "bla1", "bla2"} }; // nepojde skompilovat
Struktura_2 jmeno = { 10, {"bla", "bla1", "bla2"} }; // nepojde skompilovat
Struktura_3 jmeno = { 10, {"bla", "bla1", "bla2"} }; // NEpojde skompilovat
Struktura_4 jmeno = { 10, {"bla", "bla1", "bla2"} }; // NEpojde skompilovat
*/
Struktura_5 jmeno = { 10, {"bla", "bla1", "bla2"} }; // pojde skompilovat
}
const char** vícekrát a to tím proměnným počtem argumentů nepořeším a stejně by to teda nevzal kompilátor ... zůstanu teda u toho řešení "s\0ošklivým\0řetězcem\0"
typedef struct {
int x;
const char **array;
} Structure;
#define MAKE_STRUCTURE(name, x, array...) \
const char *name##__array_data[] = array; \
Structure name = { x, name##__array_data }
MAKE_STRUCTURE(joe, 3, {"foo", "bar", "baz"});
Je nevím, proč by to mělo být lepší než ten kód nenapsat rovnou (a pokud je ho hodně, tak generovat, nebo naopak příslušná data run-time načítat).
typedef struct {
int x;
const char **array;
} Structure;
#define MAKE_STRUCTURE(name, x, ...) \
const char *name##__array_data[] = __VA_ARGS__; \
Structure name = { x, name##__array_data }
MAKE_STRUCTURE(joe, 3, {"foo", "bar", "baz"});
STRUKTURA(jmeno, 10, ((char * []){"bla", "bla2", "bla3"}));
Tiskni
Sdílej: