Design (GitHub) je 2D CAD pro GNOME. Instalovat lze i z Flathubu. Běží také ve webovém prohlížeči.
Příspěvek na blogu herního enginu Godot představuje aplikaci Xogot přinášející Godot na iPad a iPhone. Instalovat lze z App Storu. Za Xogotem stojí Miguel de Icaza (GitHub) a společnost Xibbon.
Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za březen (YouTube).
ESP-IDF (Espressif IoT Development Framework), tj. oficiální vývojový framework pro vývoj aplikací na mikrokontrolérech řady ESP32, byl vydán v nové verzi 6.0. Detaily na portálu pro vývojáře.
DeepMind (Alphabet) představila novou verzi svého multimodálního modelu, Gemma 4. Modely jsou volně k dispozici (Ollama, Hugging Face a další) ve velikostech 5-31 miliard parametrů, s kontextovým oknem 128k až 256k a v dense i MoE variantách. Modely zvládají text, obrázky a u menších verzí i audio. Modely jsou optimalizované pro běh na desktopových GPU i mobilních zařízeních, váhy všech těchto modelů jsou uvolněny pod licencí Apache 2.0. Návod na spuštění je už i na Unsloth.
Cursor (Wikipedie) od společnosti Anysphere byl vydán ve verzi 3. Jedná se o multiplatformní proprietární editor kódů s podporou AI (vibe coding).
Průkopnická firma FingerWorks kolem roku 2000 vyvinula vícedotykové trackpady s gesty a klávesnice jako TouchStream LP. V roce 2005 ji koupil Apple, výrobu těchto produktů ukončil a dotykové technologie využil při vývoji iPhone. Multiplatformní projekt Apple Magic TouchstreamLP nyní implementuje funkcionalitu TouchStream LP na současném Apple Magic Trackpad, resp. jejich dvojici. Diskuze k vydání probíhá na Redditu.
Byla vydána nová verze 10.3 sady aplikací pro SSH komunikaci OpenSSH. Přináší řadu bezpečnostních oprav, vylepšení funkcí a oprav chyb.
Cloudflare představil open source redakční systém EmDash. Jedná se o moderní náhradu WordPressu, která řeší bezpečnost pluginů. Administrátorské rozhraní lze vyzkoušet na EmDash Playground.
Bratislava OpenCamp 2026 zverejnil program a spustil registráciu. Štvrtý ročník komunitnej konferencie o otvorených technológiách prinesie 19 prednášok na rôzne technologické témy. Konferencia sa uskutoční v sobotu 25. apríla 2026 v priestoroch FIIT STU v Bratislave.
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: