Byla vydána (𝕏) nová verze 24.7 open source firewallové a routovací platformy OPNsense (Wikipedie). Jedná se o fork pfSense postavený na FreeBSD. Kódový název OPNsense 24.7 je Thriving Tiger. Přehled novinek v příspěvku na fóru.
Binarly REsearch upozorňuje na bezpečnostní problém PKFail (YouTube) v ekosystému UEFI. Stovky modelů zařízení používají pro Secure Boot testovací Platform Key vygenerovaný American Megatrends International (AMI) a jeho privátní část byla při úniku dat prozrazena. Do milionů zařízení (seznam v pdf) po celém světě tak útočníci mohou do Secure Bootu vložit podepsaný malware. Otestovat firmware si lze na stránce pk.fail. Ukázka PoC na Linuxu na Windows na YouTube.
Mobilní operační systém /e/OS (Wikipedie) založený na Androidu / LineageOS, ale bez aplikací a služeb od Googlu, byl vydán ve verzi 2.2 (Mastodon, 𝕏). Přehled novinek na GitLabu. Vypíchnuta je rodičovská kontrola.
Společnost OpenAI představila vyhledávač SearchGPT propojující OpenAI modely umělé inteligence a informace z webů v reálném čase. Zatím jako prototyp pro vybrané uživatele. Zapsat se lze do pořadníku čekatelů.
Distribuce Linux Mint 22 „Wilma“ byla vydána. Je založená na Ubuntu 24.04 LTS, ale s desktopovým prostředím Cinnamon (aktuálně verze 6.2), příp. MATE nebo Xfce, balíkem aplikací XApp, integrací balíčků Flatpak a dalšími změnami. Více v přehledu novinek a poznámkách k vydání.
Příspěvek na blogu Truffle Security: Kdokoli může přistupovat ke smazaným a privátním repozitářům na GitHubu.
Byla vydána nová verze 14 integrovaného vývojového prostředí (IDE) Qt Creator. Podrobný přehled novinek v cgitu. Vypíchnout lze podporu rozšíření v Lua.
Byla vydána verze 1.80.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.
Apple oznámil, že v beta verzi spustil své Apple Maps na webu. Podporován je také webový prohlížeč Chrome. Ne však na Linuxu.
Portál Stack Overflow po roce opět vyzpovídal své uživatele, jedná se především o vývojáře softwaru, a zveřejnil detailní výsledky průzkumu. Průzkumu se letos zúčastnilo více než 65 tisíc vývojářů. Z Česka jich bylo 710. Ze Slovenska 246.
#define MACRO 5
...
int var = 10;
#undef MACRO
#define MACRO var
Nejsem si teda jistej, jestli to vůbec jde... Díky
var
. A to je taky ta jediná úplná jistota, kterou máš.
Dost nejasné naopak je, jak si vlastně představuješ, že makra fungují.
template<char * context, int i> class Macro { enum { value = i}; } template<<int i> class Macro<"kontext1"> { enum { value = 10}; }popripade jeste by sly pouzit namespaces.
namespace Kontext1 { enum makro { value = 10 }; } namespace Kontext2 { enum makro { value = 5 }; } a pak uz jen: using namespace Kontext1;
#ifdef MAKRO 5
int a = 0;
#elif MAKRO 3
int a = 1;
#endif
A jediný problém je, že nevím, jak makro předefinovat, aby mělo hodnotu nějaké proměnné
int MACRO = 5; ... MACRO = 3;
#define MS_NOSEC (1 << 28)
static void foo(void)
{
printf("%d\n", MS_NOSEC);
}
preprocesor vyexpanduje vsechny makra a vlozi jejich obsah na misto jmnena makra. vysledny kod pro preklad bude vypadat takhle
...
printf("%d\n", (1 << 28));
...
z toho plyne i tvuj problem. #define MACRO var vyexpanduje na symbol var nebo jinimy slovy, prejmenuje symbol var na MACRO
#define MACRO 1
static void foo(void)
{
printf("%d\n", MACRO);
#undef MACRO
#define MACRO var
printf("%d\n", MACRO);
}
se po preprocesoru stane
...
printf("%d\n", 1);
printf("%d\n", var);
...
Jedine, kdy se kod prelozi je, kdyz var bude deklarovane. V tomhle pripade to nutne musi byt promnenna.
Vytvareni takoveho kodu vede pouze a jedine k chybam a necitelnosti. Timhle zpusobem to opravdu nepouzivej. A ono, predefinovani makra se
opravdu deje, ale musi to mit svuj smysl. Makra jsou uzitecna, dobra, ale opatrne na ne.
/*
* max() macros that also do strict type-checking
*/
#define max(x, y) ({ \
typeof(x) _max1 = (x); \
typeof(y) _max2 = (y); \
(void) (&_max1 == &_max2); \
_max1 > _max2 ? _max1 : _max2; })
#define gen_localtime(name) \
static inline int localtime_##name(time_t *t) \
{ \
struct tm *lt = localtime(t); \
if (!lt) \
die_errno("localtime"); \
\
return lt->tm_##name; \
}
gen_localtime(mday);
Tiskni
Sdílej: