Fedora je od 10. února dostupná v Sýrii. Sýrie vypadla ze seznamu embargovaných zemí a Fedora Infrastructure Team mohl odblokovat syrské IP adresy.
Ministerstvo zahraničí Spojených států amerických vyvíjí online portál Freedom.gov, který umožní nejenom uživatelům v Evropě přístup k obsahu blokovanému jejich vládami. Portál bude patrně obsahovat VPN funkci maskující uživatelský provoz tak, aby se jevil jako pocházející z USA. Projekt měl být původně představen již na letošní Mnichovské bezpečnostní konferenci, ale jeho spuštění bylo odloženo.
Byla vydána pro lidi zdarma ke stažení kniha The Book of Remind věnovaná sofistikovanému kalendáři a připomínači Remind.
Grafický editor dokumentů LyX, založený na TeXu, byl vydán ve verzi 2.5.0. Oznámení připomíná 30. výročí vzniku projektu. Novinky zahrnují mj. vylepšení referencí nebo použití barev napříč aplikací, od rozhraní editoru po výstupní dokument.
F-Droid bannerem na svých stránkách a také v aplikacích F-Droid a F-Droid Basic upozorňuje na iniciativu Keep Android Open. Od září 2026 bude Android vyžadovat, aby všechny aplikace byly registrovány ověřenými vývojáři, aby mohly být nainstalovány na certifikovaných zařízeních Android. To ohrožuje alternativní obchody s aplikacemi jako F-Droid a možnost instalace aplikací mimo oficiální obchod (sideloading).
Svobodná historická realtimová strategie 0 A.D. (Wikipedie) byla vydána ve verzi 28 (0.28.0). Její kódový název je Boiorix. Představení novinek v poznámkách k vydání. Ke stažení také na Flathubu a Snapcraftu.
Multimediální server a user space API PipeWire (Wikipedie) poskytující PulseAudio, JACK, ALSA a GStreamer rozhraní byl vydán ve verzi 1.6.0 (Bluesky). Přehled novinek na GitLabu.
UBports, nadace a komunita kolem Ubuntu pro telefony a tablety Ubuntu Touch, vydala Ubuntu Touch 24.04-1.2 a 20.04 OTA-12.
Byla vydána (Mastodon, 𝕏) nová stabilní verze 2.0 otevřeného operačního systému pro chytré hodinky AsteroidOS (Wikipedie). Přehled novinek v oznámení o vydání a na YouTube.
WoWee je open-source klient pro MMORPG hru World of Warcraft, kompatibilní se základní verzí a rozšířeními The Burning Crusade a Wrath of the Lich King. Klient je napsaný v C++ a využívá vlastní OpenGL renderer, pro provoz vyžaduje modely, grafiku, hudbu, zvuky a další assety z originální kopie hry od Blizzardu. Zdrojový kód je na GitHubu, dostupný pod licencí MIT.
void CDECL ShowInfoF(const char *str, ...);Nejsou mi jasné dvě věci: 1) Co znamená CDECL mezi typem a jménem funkce? Připadá mi to jako syntaktická chyba (asi není, když to šlo zkompilovat
). Podobnou věc jsem viděl i ve Win32 API, tam bylo tuším int APIENTRY WinMain(). Nebo také v JNI - JNIEXPORT void JNICALL Java_MyCanvas_paint
(JNIEnv* env, jobject canvas, jobject graphics). Tady je ještě navíc nějaké JNIEXPORT před návratovým typem.
2) Tři tečky místo parametru - to je nepovinný počet parametrů? Jak se pak k těmto parametrům ve funkci přistupuje, když nejsou pojmenované? (možná to je něco úplně jiného, já s C začínám).
Předem díky za odpověď,
Martin
_cdecl. Na co jinde, nevím. Ale chce to projít zdrojáky a použít preprocesor. Informace jsou na stránkách microsoftu.
Použití proměnného počtu argumentů je například zde. Ale proč se tedy nepodíváš na tělo samotné funkce, abys věděl, jak se s tím pracuje?
void _cdecl ShowInfoF(const char *str, ...);Co se stane s funkcí, když je před jejím názvem _cdecl, je už starostí překladače? ad 2: Já jsem se podíval, ale vůbec nic jsem z toho nepochopil
void CDECL ShowInfoF(const char *str, ...)
{
va_list va;
char buf[1024];
va_start(va, str);
vsprintf(buf, str, va);
va_end(va);
ShowInfo(buf);
}
CDECL tak definován, tak ano. Jinde může být CDECL zanedbáno. Význam _cdecl a spol je záležitostí konkrétního překladače protože ANSI C nic takového nemá.
ad 2: to je zrovna blbý příklad, protože ukazuje jak pracovat se seznamem parametrů (předaných přes výpustku) jako celek (tj. "převedení seznamu volitelných parametrů na jediný parametr"). Lepší příklad je v stdarg(3).
#define CDECL
int CDECL main(void) {
return(0);
}
CDECL, který preprocessor MSVC nahradí _cdecl (a kterému on rozumí), ale preprocessor gcc jej zase zlikviduje.
CDECL je modifikátor fce, pro kompilátor. Podobně jako __stdcall, __fastcall atd. Určují, jak se mají předávat argumenty volané funkce (přes stack, registry, haldu).
Více zde. Doufám že mě neukamenujete za MS
.
void funkce(register int parametr);. Nevím však, zda to funguje a pokud ano, jestli i na Windows.
Označuji téma za vyřešené.
-E zariadi, že kompilátor miesto zvyčajného vytvorenia .o vypíše výsledok pre-processingu. To znamená, že ak príkaz na kompilovanie
gcc -DMOJEMAKRO -I/usr/X11/include -c subor.c -o subor.o
prepíšem napr. na
gcc -DMOJEMAKRO -I/usr/X11/include -E subor.c
dostanem výstup, v ktorom sa dozviem, ako sa tie makrá rozvinuli. V našom prípade nám to pomôže k tomu, že sa dozviem, ako v skutočnosti bude vyzerať deklarácia tej mojej funkcie.
// typ myShort bude mít všude 2 bajty #ifdef sizeof(short) == 2 typedef short myShort; #elif sizeof(int) == 2 typedef int myShort; #endifBohužel, nefunguje to. Takže to asi nebude ten správný způsob. Ale přece nějaká možnost existovat musí. Všiml jsem si, že třeba OpenGL nebo SDL používají typy, které jsou všude stejné. Jak na to tedy?
Prenositelne integer datove typy by mali na vacsine systemov byt pristupne cez
#include <inttypes.h>Tieto typy su potom napr.
int8_t pre 8 bitovy int znamienkovy typ, int16_t 2B znamienkovy typ atd...
int8_t apod., ale tyto typy nejsou povinné. Povinné jsou pouze int_least8_t, int_least16_t, int_least32_t a int_least64_t. Tedy samozřejmě i některé další, např. intptr_t, ale zrovna ty, které jste jmenoval, to nejsou. Důvod je jednoduchý: platforma totiž vůbec nemusí nabízet něco jako 16-bitové číslo.
<inttypes.h>. Navíc znovu upozorňuji, že technicky vzato typy jako "16-bitové číslo bez znaménka" nebo "32-bitové číslo se znaménkem" vůbec nemusejí být k dispozici.
Potřeboval bych spojit řetězec (pole char, nikoliv string z C++) dohromady s číslem tak, aby vznikl zase řetězec. Předpokládám, že zápis retezec + cislo nebude fungovat (pravděpodobně by pak retezec ukazoval o cislo bajtů v paměti dál).
snprintf(buffer, delka_buffer, "%s%d", retezec, cislo);
Tiskni
Sdílej: