Dnes a zítra probíhá vývojářská konference Google I/O 2026. Sledovat lze na YouTube a na síti 𝕏 (#GoogleIO).
Canonical vydal Ubuntu Core 26. Vychází z Ubuntu 26.04 LTS a podporováno bude 15 let. Ubuntu Core je minimální neměnný operační systém určený pro vestavěné systémy.
Bylo vydáno OpenBSD 7.9. Po dlouhé době opět se songem: Diamond in the Rough.
Byl vydán Mozilla Firefox 151.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 151 bude brzy k dispozici také na Flathubu a Snapcraftu.
Elon Musk prohrál soudní spor se společností OpenAI, která se podle jeho žaloby odchýlila od původně uváděného cíle vyvíjet umělou inteligenci (AI) ku prospěchu lidstva. Porota včera po necelých dvou hodinách dospěla k jednomyslnému závěru, že Musk žalobu podal příliš pozdě. Musk byl jedním ze spoluzakladatelů společnosti OpenAI, která vznikla v roce 2015 a vyvinula populární chatovací systém ChatGPT. V roce 2018 na svůj post ve vedení
… více »Byla vydána nová verze 10.4 z Debianu vycházející linuxové distribuce DietPi pro (nejenom) jednodeskové počítače. Přehled novinek v poznámkách k vydání. Opraveny jsou zranitelnosti Copy Fail a Dirty Frag. Přibyl nový obraz pro Orange Pi 5B.
Pokud je zranitelnost Linuxu v nepoužívaném jaderném modulu, lze ji jednoduše vyřešit zakázáním automatického načítání tohoto konkrétního zranitelného modulu. Projekt ModuleJail si klade za cíl zvýšit bezpečnost Linuxu zakázáním automatického načítání všech nepoužívaných jaderných modulů. Jedná se o skript, který dá všechny nepoužívané jaderné moduly na blacklist (/etc/modprobe.d/modulejail-blacklist.conf).
Odborníci z Penn State University zkoumají způsob ukládání informací na lepicí pásku. Principiálně by podle nich bylo možné kombinací odlepení a zpětného přilepení dosáhnout uložení informace, kterou opětovným odlepením dokážou přečíst. Výhodou je, že způsob uložení i přečtení je čistě mechanický. Zde o tom referují ve volně dostupném článku. Zajímavé bude sledovat zda se jim v rámci výzkumu podaří prokázat použitelnost i v jiné než
… více »Na GitHubu byl publikován reprodukovatelný návod, jak rozchodit Adobe Lightroom CC na Linuxu a Wine. Návod byl vytvořený pomocí AI Claude Code.
Pokud by někdo potřeboval Wayland kompozitor uvnitř počítačové hry Minecraft, aby mohl zobrazovat okna desktopových aplikací přímo v herním prostředí, může sáhnout po Waylandcraftu. Ukázka na YouTube.
##################
#
########### # #
# ######
###### ###### #
# ##
##################
Ve vstupních datech je stěna bludiště zadávána jako znak '#' (mřížka) a volné políčko jako znak mezera. Bludiště může mít jakýkoliv tvar, nemusí to být pouze obdélník. Pokud řádky nebudou stejně dlouhé, doplní se kratší řádky volným místem na délku nejdelšího řádku. Můžeme předpokládat, že pokud se soubor podaří otevřít, tak v něm bude korektně zadané bludiště.
Muj (pseudo)algoritmus, resp planovany postup je nasledujici:
1) nacist txt do char buffer[] 2) spocitat radky (y) a delku nejdelsiho radku (x) 3) vytvorit v allegru display velikosi y krat x 4) definovat prvek bitmapy 10x10 pixelu 5) jeden prvek = jeden znak '#' 6) Kontroluj kazdy prvek v bufferu, pokud narazis na znak, tak vykresli bitmapu: if buffer[] = '#' vykresli prvek bitmapy jdi na dalsi prvek bufferu else zkontroluj dalsi prvek v bufferuKnihovna allergo5 je rozsahla, byl bych proto rad, kdyby mi nekdo poradil, jake fce by se nejvic hodily. Z toho, co o allegru zatim vim, se domnivam, ze budu muset pouzit fci create_display o velikosti strlen(nejdelsi radek) * 10(rozmer bitmapoveho prvku). Potom vytvorit bitmapu 10x10. Ma otazka zni, jake fce budu potrebovat na tisknuti bludiste? Nasel jsem fci al_put_pixel, ktera tiskne pixel na urcitou souradnici. Mam si tedy vyhradit pri kazdem nacteni '#' bitmapu 10x10, tu zaplnit pixely dane barvy, a pak jit o policko dal? Nebo je tu jina, mene pracna moznost?
Řešení dotazu:
#define TILE_H 10
#define TILE_W 10
int main(void){
al_init();
al_init_image_addon();
ALLEGRO_DISPLAY *display = NULL;
const int BOUNCER_SIZE = 10;
ALLEGRO_BITMAP *tile = NULL;
//ZACATEK - nacte text ze souboru
FILE *in;
FILE *out;
char buffer[1204];
buffer[0] = 0;
char input[1204];
int i;
int vyska = 0;
int delka = i = 0;
float dx = 0.0;
float dy = 0.0;
char c;
in = fopen ("input.txt" , "r");
if (in == NULL) perror ("Error opening file");
while( fgets(input , 800 , in) != NULL ){ //kopiruje data z jednoho souboru do druheho
strcat(buffer, input);
i = strlen(input);
i-= 1;
//pocita delku nejdelsiho radku
if (i > delka)
delka = i;
//pocet radku
vyska++;
}
fclose (in);
delka *= 10;
vyska *= 10;
display = al_create_display(delka, vyska);
if(!display) {
fprintf(stderr, "failed to create display!\n");
return -1;
}
tile = al_create_bitmap(TILE_H, TILE_W);
if(!tile) {
fprintf(stderr, "failed to create bouncer bitmap!\n");
al_destroy_display(display);
return -1;
}
al_clear_to_color(al_map_rgb(255,255,255));
al_set_target_bitmap(tile);
al_clear_to_color(al_map_rgb(0,0,0));
al_set_target_bitmap(al_get_backbuffer(display));
in = fopen ("input.txt" , "r");
do {
c = getc (in);
if (c == '#')al_draw_bitmap(tile, dx, dy, 0);
dx+=10;
if (c == '\n'){
dy+= 10;
dx = 0;
}
} while (c != EOF);
al_save_bitmap("screen.bmp" , al_get_backbuffer(display));
al_destroy_bitmap(tile);
al_destroy_display(display);
return 0;
}
Tiskni
Sdílej: