Byla vydána nová verze 1.6 otevřeného, licenčními poplatky nezatíženého, univerzálního ztrátového formátu komprese zvuku Opus (Wikipedie) a jeho referenční implementace libopus. Podrobnosti na demo stránce.
Vojtěch Polášek představil Vojtux, tj. linuxovou distribuci pro zrakově postižené uživatele. Vychází ze spinu Fedory 43 s desktopovým prostředím MATE. Konečným cílem je, aby žádný Vojtux nebyl potřeba a požadovaná vylepšení se dostala do upstreamu.
Byla vydána (Mastodon, 𝕏) druhá RC verze GIMPu 3.2. Přehled novinek v oznámení o vydání. Podrobně v souboru NEWS na GitLabu.
Nové číslo časopisu Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 160 (pdf).
Izrael od února zakáže dětem používat v prostorách základních škol mobilní telefony. Podle agentury AFP to uvedlo izraelské ministerstvo školství, které zdůraznilo negativní dopady, které na žactvo používání telefonů má. Izrael se tímto krokem přidává k rostoucímu počtu zemí, které dětem ve vzdělávacích zařízeních přístup k telefonům omezují.
Internetová společnost Google ze skupiny Alphabet pravděpodobně dostane příští rok pokutu od Evropské komise za nedostatečné dodržování pravidel proti upřednostňování vlastních služeb a produktů ve výsledcích vyhledávání. V březnu EK obvinila Google, že ve výsledcích vyhledávání upřednostňuje na úkor konkurence vlastní služby, například Google Shopping, Google Hotels a Google Flights. Případ staví Google proti specializovaným
… více »Byl oznámen program a spuštěna registrace na konferenci Prague PostgreSQL Developer Day 2026. Konference se koná 27. a 28. ledna a bude mít tři tracky s 18 přednáškami a jeden den workshopů.
Na webu československého síťařského setkání CSNOG 2026 je vyvěšený program, registrace a další informace k akci. CSNOG 2026 se uskuteční 21. a 22. ledna příštího roku a bude se i tentokrát konat ve Zlíně. Přednášky, kterých bude více než 30, budou opět rozdělené do tří bloků - správa sítí, legislativa a regulace a akademické projekty. Počet míst je omezený, proto kdo má zájem, měl by se registrovat co nejdříve.
Máirín Duffy a Brian Smith v článku pro Fedora Magazine ukazují použití LLM pro diagnostiku systému (Fedora Linuxu) přes Model Context Protocol od firmy Anthropic. I ukázkové výstupy v samotném článku obsahují AI vygenerované nesmysly, např. doporučení přeinstalovat balíček pomocí správce balíčků APT z Debianu místo DNF nativního na Fedoře.
Projekt D7VK dospěl do verze 1.0. Jedná se o fork DXVK implementující překlad volání Direct3D 7 na Vulkan. DXVK zvládá Direct3D 8, 9, 10 a 11.
Zdravim mohl byste mi nekdo poradit jak se da resit programek v cecku abych si pri spusteni navolil v prikazove radce jaky pseudo terminal se bude pouzivat ( ptsX ). Program se pak propoji na dalsi pseudo terminal a navzajem si posilaji data.
Presne zadani zde:
........................................Napište program, teletype. Tento program otevře sériový port a vyšle na něj každý z klávesnice zapsaný znak a vypíše každý jednotlivý znak ze sériové linky přijatý. Pomocí sériového kabelu propojte COM1 a COM2 a spusťte 2 instance programu teletype. Který COM se bude používat specifikujte z příkazové řádky při spouštění programu.
________________Vim jak udelat abych se propojil na terminal a cetl z nej znaky ale nevim jak udelat aby jsme mohl navzajem mezi terminali prijimat i odesilat. Snad pomoci fce select? Prosim poradte, ( nechci to naprogramovat, jen nakopnout), zatim je to pro me spanelska vesnice. Dekuji
EXAMPLE
#include <stdio.h>
#include <sys/time.h>
#include <sys/types.h>
#include <unistd.h>
int
main(void) {
fd_set rfds;
struct timeval tv;
int retval;
/* Watch stdin (fd 0) to see when it has input. */
FD_ZERO(&rfds);
FD_SET(0, &rfds);
/* Wait up to five seconds. */
tv.tv_sec = 5;
tv.tv_usec = 0;
retval = select(1, &rfds, NULL, NULL, &tv);
/* Don't rely on the value of tv now! */
if (retval == -1)
perror("select()");
else
if (retval)
printf("Data is available now.\n");
/* FD_ISSET(0, &rfds) will be true. */
else
printf("No data within five seconds.\n");
return 0;
}
#define BUF_LEN 200
struct termios set_attributes;
int main(int argc, char *argv[]) {
char *ttyID;
char buffer[BUF_LEN];
int result;
fd_set terminal, klavesnice;
struct timeval timeout; /* Struktura s časovým limitem */
size_t len;
ttyID = argv[1]; /* Nacteme ttyID pseudo terminalu */
int tty = open(ttyID, O_RDWR);
// nastav nove parametry terminalu
tcgetattr(tty, &set_attributes);
set_attributes.c_lflag &= ~ICANON; // necekej na cely radek (noncanonical)
//set_attributes.c_lflag &= ~ECHO; // nezobrazuj ctene znaky
set_attributes.c_cc[VMIN] = 1;
set_attributes.c_cc[VTIME] = 0;
tcsetattr(tty, TCSAFLUSH, &set_attributes);
while(1){
FD_ZERO(&terminal); /* Odstranime nahodna data z mnoziny */
FD_ZERO(&klavesnice); /* Odstranime nahodna data z mnoziny */
FD_SET(fileno(stdin), &klavesnice); /* Naplnime mnozinu stdin */
FD_SET(tty, &terminal); /* Naplnime mnozinu ttyckem */
// Nadefinovany casovy interval 4 sekundy a 5 milis..
timeout.tv_sec = 4;
timeout.tv_usec = 50000;
// Zavolám select (V Linuxu musím mít nastavenou proměnnou FD_SETSIZE) --- tezko rict co je na tom pravdy
result = select(FD_SETSIZE, &klavesnice, &terminal, NULL, &timeout);
switch(result){
case -1:
perror("select"); /* Nastala chyba */
exit(1);
case 0:
printf("timeout \n"); /* Vypršel časový limit */
break;
default:
/* Obsluha soketu. Zde je možné vytvořit nové vlákno nebo proces,
který obslouží událost na soketu. Server pak je vícevláknový.
*/
if (FD_ISSET(fileno(stdin), &klavesnice)) {
/* Data available on stdin */
char a;
read(fileno(stdin), &a, sizeof(a));
write(tty, &a, sizeof(a));
}
if (FD_ISSET(tty, &terminal)) {
char c;
read(tty, &c, sizeof(c));/*:!*/
if(c == '\004') { // `C-d'
// program skonci az prijme Ctrl-D
break;
}
else {
putchar(c);
// vyprazdni vystupni buffer
// a zpusob tak zobrazeni znaku
// i v nekanonickem modu terminalu
fflush(stdout);
}
}
break;
}
}
}
.
.
.
switch(select(1, &rfds, NULL, NULL, &tv))
{
case -1:
perror("select()");
return -1;
/* no break */
case 0:
printf("No data in 5 sec.\n");
break;
default:
printf("DAATAAA!!!.\n");
/* FD_ISSET(0, &rfds) will be true. */
break;
}
return 0;
.
.
.
hlavicky
void *readFromTERMINAL( void *ptr )
{
char *terminal;
terminal = (char *) ptr;
int tty = open(terminal, O_RDONLY);/*:!*/
if(tty < 0) {
perror("ERROR open device /dev/ttyS1");
exit(EXIT_FAILURE);
}
while(1) {
char c;
read(tty, &c, sizeof(c));
if(c == '\004') { // `C-d'
// program skonci az prijme Ctrl-D
close(tty);
break;
}
else {
putchar(c);
// vyprazdni vystupni buffer
// a zpusob tak zobrazeni znaku
// i v nekanonickem modu terminalu
fflush(stdout);
}
}
close(tty);
}
int main(int argc, char *argv[])
{
pthread_t thread1, thread2;
char *parametr;
parametr = argv[1];
// vlakno cte z daneho portu a vypisuje na terminal
pthread_create( &thread1, NULL, readFromTERMINAL, parametr);
pthread_join(thread1, NULL);
printf("\nKonec\n");
return EXIT_SUCCESS;
}
moje_skvela_utilita </dev/bagr/jahoda/konzole >/dev/bagr/jahoda/konzole
Tiskni
Sdílej: