Z upstreamu GNOME Mutter byl zcela odstraněn backend X11. GNOME 50 tedy poběží už pouze nad Waylandem. Aplikace pro X11 budou využívat XWayland.
Byl publikován plán na odstranění XSLT z webových prohlížečů Chrome a Chromium. S odstraněním XSLT souhlasí také vývojáři Firefoxu a WebKit. Důvodem jsou bezpečnostní rizika a klesající využití v moderním webovém vývoji.
Desktopové prostředí LXQt (Lightweight Qt Desktop Environment, Wikipedie) vzniklé sloučením projektů Razor-qt a LXDE bylo vydáno ve verzi 2.3.0. Přehled novinek v poznámkách k vydání.
Organizace Open Container Initiative (OCI) (Wikipedie), projekt nadace Linux Foundation, vydala Runtime Specification 1.3 (pdf), tj. novou verzi specifikace kontejnerového běhového prostředí. Hlavní novinkou je podpora FreeBSD.
Nový open source router Turris Omnia NG je v prodeji. Aktuálně na Allegro, Alternetivo, Discomp, i4wifi a WiFiShop.
Na YouTube a nově také na VHSky byly zveřejněny sestříhané videozáznamy přednášek z letošního OpenAltu.
Jednou za rok otevírá společnost SUSE dveře svých kanceláří široké veřejnosti. Letos je pro vás otevře 26. listopadu v 16 hodin v pražském Karlíně. Vítáni jsou všichni, kdo se chtějí dozvědět více o práci vývojářů, prostředí ve kterém pracují a o místní firemní kultuře. Můžete se těšit na krátké prezentace, které vám přiblíží, na čem inženýři v Praze pracují, jak spolupracují se zákazníky, partnery i studenty, proč mají rádi open source a co
… více »Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za říjen (YouTube).
Jeff Quast otestoval současné emulátory terminálu. Zaměřil se na podporu Unicode a výkon. Vítězným emulátorem terminálu je Ghostty.
Amazon bude poskytovat cloudové služby OpenAI. Cloudová divize Amazon Web Services (AWS) uzavřela s OpenAI víceletou smlouvu za 38 miliard USD (803,1 miliardy Kč), která poskytne majiteli chatovacího robota s umělou inteligencí (AI) ChatGPT přístup ke stovkám tisíc grafických procesů Nvidia. Ty bude moci využívat k trénování a provozování svých modelů AI. Firmy to oznámily v dnešní tiskové zprávě. Společnost OpenAI také nedávno
… více »Řešení dotazu:
[/hint]
#include <stdio.h>
#define do(x) for(x) {
#define while }
void main(void) {
unsigned short i;
do (i=0; i<10; i++)
printf("%i\n", i);
while;
}
int main()
{
int i = 1;
int n = 7;
label_start:
i = i + 1;
if( i > n ) goto label_end;
/* do work */
goto label_start;
label_end:
return 0;
}
Na vysvetlenou. Nekonecny cyklus (simulujici do-while) je mezi label_start a goto label_start. Podminka na ukonceni pak je if se skokem mimo smycku.
Ano. Presne takhle se ve starych jazycich kodovaly tyhle veci. Dneska uz maji oba zminene konstrukce analogicke obou tymum cyklu a je skoda, ze si jich nevazite.
S ohledem na odpovědi mám trochu obavu, co vlastně víte. Takže pro pořádek:
for (INIT; COND; ITER) {
BODY;
}
lze (za předpokladu, že v těle nepoužijete continue) ekvivalentně přepsat jako
INIT;
while (COND) {
BODY;
ITER;
}
Pomocí do-while je to horší, protože ten vždy proběhne aspoň jednou. Takže by bylo potřeba použít nějaký špinavý trik typu
INIT;
do {
if (!(COND))
break;
BODY;
ITER;
while (true);
a samozřejmě ani tady to nebude fungovat správně, pokud v těle použijete continue.
Podstatná otázka samozřejmě je, k čemu je to dobré.
for(int i=1;…){
}
ale fungoval jako:
int i;
for(i=1;…){
}
což měnilo platný scope pro 'i'.
{
INIT;
while (COND) {
BODY;
ITER;
}
}
C EKVIVALENT V FORTRAN 77 DO
INTEGER I
INTEGER N
N=7
DO 10 I=1,N
C DO WORK
10 CONTINUE
STOP
END
totéž pomocí IF
C EKVIVALENT V FORTRAN 77 IF
INTEGER I
INTEGER N
10 IF (N=I) 40,30,20
20 I=I+1
C DO WORK
30 GOTO 50
40 PRINT 'CHYBA I JE VETSI NEZ N'
50 STOP
END
C EKVIVALENT V FORTRAN 77 IF
INTEGER I
INTEGER N
10 IF (N-I) 40,30,20
20 I=I+1
C DO WORK
30 GOTO 50
40 PRINT 'CHYBA I JE VETSI NEZ N'
50 STOP
END
jak už 20 let píšu do if podmínku, tak ty prsty to napsaly automaticky, přitom tohle FORTRANí IF je na číslo.
#define LIMIT 100
int i;
//--- FOR LOOP -----------
for(i = 0; i < LIMIT; i++)
f(i);
//--- WHILE LOOP -----------
i = 0;
while(i < LIMIT)
{
f(i);
i++;
}
//--- DO-WHILE LOOP -----------
i = 0;
if(i < LIMIT)
{
do
{
f(i);
} while(++i < LIMIT);
}
Tiskni
Sdílej: