Multiplatformní emulátor terminálu Ghostty byl vydán ve verzi 1.2 (𝕏, Mastodon). Přehled novinek, vylepšení a nových efektů v poznámkách k vydání.
Byla vydána nová verze 4.5 (𝕏, Bluesky, Mastodon) multiplatformního open source herního enginu Godot (Wikipedie, GitHub). Přehled novinek i s náhledy v příspěvku na blogu.
Byla vydána verze 3.0 (Mastodon) nástroje pro záznam a sdílení terminálových sezení asciinema (GitHub). S novou verzí formátu záznamu asciicast v3, podporou live streamingu a především kompletním přepisem z Pythonu do Rustu.
Canonical oznámil, že bude podporovat a distribuovat toolkit NVIDIA CUDA (Wikipedie) v Ubuntu.
Tržní hodnota americké společnosti Alphabet, která je majitelem internetového vyhledávače Google, dnes poprvé překonala hranici tří bilionů dolarů (62,1 bilionu Kč). Alphabet se připojil k malé skupině společností, které tuto hranici pokořily. Jsou mezi nimi zatím americké firmy Nvidia, Microsoft a Apple.
Spojené státy a Čína dosáhly dohody ohledně pokračování populární čínské platformy pro sdílení krátkých videí TikTok v USA. V příspěvku na síti Truth Social to dnes naznačil americký prezident Donald Trump. Dosažení rámcové dohody o TikToku vzápětí oznámil americký ministr financí Scott Bessent, který v Madridu jedná s čínskými představiteli o vzájemných obchodních vztazích mezi USA a Čínou. Bessentova slova později potvrdila také čínská strana.
MKVToolNix, tj. sada nástrojů pro práci s formátem (medialnym kontajnerom) Matroska, byl vydán ve verzi 95.0. Podpora přehrávání formátu Matroska míří do Firefoxu [Bug 1422891, Technický popis]. Přehrávání lze již testovat ve Firefoxu Nightly.
Spolek OpenAlt zve příznivce otevřených řešení a přístupu na 211. sraz, který proběhne v pátek 19. září od 18:00 ve Studentském klubu U Kachničky na Fakultě informačních technologií Vysokého učení technického na adrese Božetěchova 2/1. Na srazu proběhne přednáška Jiřího Eischmanna o nové verzi prostředí GNOME 49. Nemáte-li možnost se zúčastnit osobně, přednáškový blok bude opět streamován živě na server VHSky.cz a následně i zpřístupněn záznam.
Microsoft se vyhnul pokutě od Evropské komise za zneužívání svého dominantního postavení na trhu v souvislosti s aplikací Teams. S komisí se dohodl na závazcích, které slíbil splnit. Unijní exekutivě se nelíbilo, že firma svazuje svůj nástroj pro chatování a videohovory Teams se sadou kancelářských programů Office. Microsoft nyní slíbil jasné oddělení aplikace od kancelářských nástrojů, jako jsou Word, Excel a Outlook. Na Microsoft si
… více »Samba (Wikipedie), svobodná implementace SMB a Active Directory, byla vydána ve verzi 4.23.0. Počínaje verzí Samba 4.23 jsou unixová rozšíření SMB3 ve výchozím nastavení povolena. Přidána byla podpora SMB3 přes QUIC. Nová utilita smb_prometheus_endpoint exportuje metriky ve formátu Prometheus.
#!/usr/bin/env python import sys, os, threading, tty, fcntl, struct, time class CD_thread(threading.Thread): def __init__(self): threading.Thread.__init__(self) self.fd = fd def run(self): while True: fcntl.ioctl(fd, tty.TIOCMIWAIT, tty.TIOCM_CD) lock.acquire() print "DCD changed" lock.release() fd = os.open('/dev/ttyS0', os.O_RDWR | os.O_SYNC) lock = threading.Lock() cd_thread = CD_thread() cd_thread.start() try: while True: lock.acquire() print "heartbeat" os.write(fd, "\xff"*100) lock.release() time.sleep(3) except: cd_thread._Thread__stop()Hlavní vlákno každé tři sekundy něco pošle na sériový port, přičemž jiné vlákno hlídá změnu stavové linky DCD. Zámek hlídá, aby si vlákna moc nelezla do zelí (ale to se stejně trochu děje). Zdá se, že to funguje, ze sériového portu skutečně něco leze a na DCD to reaguje, ale fakt nevím, jestli nemůže nastat nějaká problémová situace.
man 2 signal man 2 alarmJe to jednoduché a mělo by to fungovat bez problémů. Spočívá to v tom, že si nastavíš, za jak dlouho ti má jádro poslat signál SIGALRM. A jakýkoliv příchozí signál by měl přerušit ten syscall, který se během něho prováděl. Takže do obsluhy signálu bych dal jen nastavení nějakého flagu a pořešil to v hlavní smyčce (nebudeš mít problémy se synchronizací).
void sig_alrm(int signo)
{
printf ("posilam heartbeat\n") ;
alarm(3); //znovu za 3 sec
}
int main()
{
int fd,er, rts = TIOCM_RTS, dtr = TIOCM_DTR, talk;
if ((fd=open("/dev/ttyS0", O_RDWR | O_NOCTTY | O_NONBLOCK)) < 0)
{
perror("open_port: Unable to open /dev/ttyS0 - ");
return 1;
}
//nastav bity potrebuju volty na diodu
ioctl(fd, TIOCMBIS, &rts);
ioctl(fd, TIOCMBIC, &dtr);
if (signal(SIGALRM, sig_alrm) == SIG_ERR)
perror("signal(SIGALRM) error");
while(1){
alarm(3);
er = ioctl(fd, TIOCMIWAIT, TIOCM_CAR);
if (er < 0)
{
if (er != EINTR /*ERESTARTSYS*/)
perror("wait_DCD");
}
else {
alarm(0);
if (ioctl(fd, TIOCMGET, &talk) < 0)
perror("get_DCD");
if (talk & TIOCM_CAR)
printf ("1\n");
else
printf ("0\n");
}
}
close (fd);
}
static int s, alarm_flag = 0 ;
static struct sockaddr_in server_address;
void send_data (int data)
{
if (sendto(s, &data, 1, 0, (struct sockaddr*)&server_address, sizeof(server_address))==-1)
{perror("Error sending datagram: "); close(s); exit(-1); }
}
void sig_alrm(int signo)
{
alarm_flag++;
}
int main()
{
int fd, rts = TIOCM_RTS, dtr = TIOCM_DTR, talk, mask = TIOCM_CAR, result, DCD,er;
s = socket(PF_INET, SOCK_DGRAM, 0);
if (s == -1) {
perror("Server: Error Opening socket \n");
exit (-1);
}
// pripravime adresu serveru
server_address.sin_family=AF_INET;
server_address.sin_port=htons(32000);
server_address.sin_addr.s_addr=inet_addr("127.0.0.1");
printf("Sending datagram to server\n");
// posleme datagram na pripravenou adresu serveru
//open the device
if ((fd=open("/dev/ttyS0", O_RDWR | O_NOCTTY | O_NONBLOCK)) < 0)
{
perror("open_port: Unable to open /dev/ttyS0 - ");
return 1;
}
//nastav bity potrebuju volty na diodu
ioctl(fd, TIOCMBIS, &rts);
ioctl(fd, TIOCMBIC, &dtr);
siginterrupt (SIGALRM,1);
if (signal(SIGALRM, sig_alrm) == SIG_ERR)
perror("signal(SIGALRM) error");
while(1){
alarm(3);
if ( ioctl(fd, TIOCMIWAIT, TIOCM_CAR)< 0) if (errno != EINTR /*ERESTARTSYS*/) perror("wait_DCD");
if (alarm_flag) {
printf ("posilam heartbeat\n") ;
send_data (1);
alarm_flag = 0;
}
else {
alarm(0);
if (ioctl(fd, TIOCMGET, &talk) < 0)
perror("get_DCD");
if (talk & TIOCM_CAR)
{printf ("1\n");send_data (10);}
else
{printf ("0\n");send_data (0);}
}
}
close(fd);
close(s);
}
SA_RESTART
, viz sigaction(2)
.
Tiskni
Sdílej: