Byla vydána únorová aktualizace aneb nová verze 1.110 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.110 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.
Apple představil 13palcový MacBook Neo s čipem A18 Pro. V základní konfiguraci za 16 990 Kč.
Kalifornský zákon AB 1043 platný od 1. ledna 2027 vyžaduje, aby operační systémy požadovaly po uživatelích věk nebo datum narození a skrze API poskytovaly aplikacím informaci, zda je uživatel mladší 13 let, má 13 až 16 let, má 16 až 18 let nebo má alespoň 18 let. Vývojáři linuxových distribucí řeší, co s tím (Ubuntu, Fedora, …).
Konference LinuxDays 2026 proběhne o víkendu 3. a 4. října v Praze v areálu ČVUT v Dejvicích na FIT. Čekají vás desítky přednášek, workshopy, stánky a setkání se spoustou chytrých lidí.
Nové verze webových prohlížečů Chrome a Firefox jsou vydávány každé 4 týdny. Aktuální verze Chrome je 145. Aktuální verze Firefoxu je 148. Od září přejde Chrome na dvoutýdenní cyklus vydávání. V kterém týdnu bude mít Chrome větší číslo verze než Firefox? 😀
Apple představil nové čipy M5 Pro a M5 Max, MacBook Pro s čipy M5 Pro a M5 Max, MacBook Air s čipem M5 a Studio Display a nový Studio Display XDR.
Bylo spuštěno hlasování o přednáškách a workshopech pro letošní Installfest, jenž proběhne o víkendu 28. a 29. března v Praze na Karlově náměstí 13.
Byla vydána (Mastodon, 𝕏) třetí RC verze GIMPu 3.2. Přehled novinek v oznámení o vydání. Podrobně v souboru NEWS na GitLabu.
Apple představil iPhone 17e a iPad Air s čipem M4.
Byla vydána verze 1.0 editoru kódů Gram. Jedná se o fork editoru Zed bez telemetrie a umělé inteligence.
void EventPumpX11::waitForWork()
{
UISystemX11* uiSystem = UI_SYSTEM();
int fd = uiSystem->_fd;
int fdSize = fd + 1;
fd_set fdSet;
struct timeval tval;
FD_ZERO(&fdSet);
FD_SET(fd, &fdSet);
TimeDelta delay = _delayedWorkTime - Time::now();
if (delay > TimeDelta())
{
// Go to sleep. X11 will wake us to process X events. We also set interval
// to wake up if there are planned tasks to specific time (Timers).
int64_t udelay = delay.inMicroseconds();
tval.tv_sec = (int)(udelay / 1000000);
tval.tv_usec = (int)(udelay % 1000000);
if (tval.tv_usec <= 100) tval.tv_usec = 100;
int ret = ::select(fdSize, &fdSet, NULL, NULL, &tval);
// TODO: Check for select result
}
else
{
// It looks like delayedWorkTime indicates a time in the past, so we
// need to call doDelayedWork now.
_delayedWorkTime = Time();
}
}
kde fd je deskriptor, který jsem obdržel pomocí ConnectionNumber(Display*) (Xlib). O co mi jde, potřeboval bych probudit event loop, když chci z jiného vlákna poslat událost do toho hlavního, které čeká buď na událost z X11 nebo na vypršení časového limitu potřebného pro jiné úkoly (delay).
Myslím, že správná cesta bude vytvořit vlastní file descriptor, na který pošlu 1 byte v případě, že budu chtít probudit event loop, ale nějak nevím jak přesně na to (toto jsem ještě nikdy nedělal). Použít fd_set a do masky dát vlastní fd?
Stačí mi nakopnutí správným směrem ;)
void EventPumpX11::waitForWork()
{
UISystemX11* uiSystem = UI_SYSTEM();
int fd = uiSystem->_fd;
int fdSize = fog_max(fd, uiSystem->_wakeUpPipe[0]) + 1;
fd_set fdSet;
struct timeval tval;
struct timeval* ptval = NULL;
FD_ZERO(&fdSet);
FD_SET(fd, &fdSet);
FD_SET(uiSystem->_wakeUpPipe[0], &fdSet);
if (_delayedWorkTime.isNull())
{
// There are no scheduled tasks, so ptval is NULL and this tells to select()
// that it should wait infitine time.
}
else
{
TimeDelta delay = _delayedWorkTime - Time::now();
if (delay > TimeDelta())
{
// Go to sleep. X11 will wake us to process X events and we also set
// interval to wake up to run planned tasks (usually Timers).
int64_t udelay = delay.inMicroseconds();
tval.tv_sec = (int)(udelay / 1000000);
tval.tv_usec = (int)(udelay % 1000000);
if (tval.tv_usec <= 100) tval.tv_usec = 100;
ptval = &tval;
}
else
{
// It looks like delayedWorkTime indicates a time in the past, so we
// need to call doDelayedWork now.
_delayedWorkTime = Time();
return;
}
}
int ret = ::select(fdSize, &fdSet, NULL, NULL, ptval);
if (ret < 0)
{
fog_debug("Fog::EventPumpX11::waitForWork() - select() failed (errno=%d).", errno);
}
if (ret > 0)
{
if (FD_ISSET(uiSystem->_wakeUpPipe[0], &fdSet))
{
// Dummy c, the actual value is out of our interest.
uint8_t c;
read(uiSystem->_wakeUpPipe[0], &c, 1);
_wakeUpSent.cmpXchg(1, 0);
}
}
}
a Kód pro probuzen9 z jiiného vlákna vypadá takto:
void EventPumpX11::sendWakeUp()
{
if (_wakeUpSent.cmpXchg(0, 1))
{
UISystemX11* uiSystem = UI_SYSTEM();
uint8_t c = 'W';
write(uiSystem->_wakeUpPipe[1], &c, 1);
}
}
požil jsem atomické operace k tomu, abych do pipe neposílal příliš moc, teď tam je normálně jen ten 1 BYTE, který probudí select. Funguje to, ale samořejmě to může obsahovat chyby (zase tak moc jsem to neotestoval)...
Ke kompletnosti ještě vytvoření pipe:
// Create wakeup pipe.
if (pipe(_wakeUpPipe) < 0)
{
fog_debug("Fog::UISystemX11::Can't create wakeup pipe");
goto fail;
}
K zápisu používám _wakeUpPipe[1] a ke čtení _wakeUpPipe[0], doufám, že jsem to pochopil správně...:)
Tiskni
Sdílej: