Dle plánu byl vývoj Firefoxu přesunut z Mercurialu na Git. Oficiální repozitář se zdrojovými kódy je na GitHubu.
V terminálovém multiplexoru GNU Screen byly nalezeny a v upstreamu ve verzi 5.0.1 už opraveny bezpečnostních chyby CVE-2025-23395, CVE-2025-46802, CVE-2025-46803, CVE-2025-46804 a CVE-2025-46805. Podrobnosti na blogu SUSE Security Teamu.
Training Solo (Paper, GitHub) je nejnovější bezpečnostní problém procesorů Intel s eIBRS a některých procesorů ARM. Intel vydal opravnou verzi 20250512 mikrokódů pro své procesory.
Byla vydána nová verze 25.05.11 svobodného multiplatformního video editoru Shotcut (Wikipedie) postaveného nad multimediálním frameworkem MLT. Nejnovější Shotcut je již vedle zdrojových kódů k dispozici také ve formátech AppImage, Flatpak a Snap.
Svobodný elektronický platební systém GNU Taler (Wikipedie, cgit) byl vydán ve verzi 1.0. GNU Taler chrání soukromí plátců a zároveň zajišťuje, aby byl příjem viditelný pro úřady. S vydáním verze 1.0 byl systém spuštěn ve Švýcarsku.
Spolek OpenAlt zve příznivce otevřených řešení a přístupu na 209. brněnský sraz, který proběhne tento pátek 16. května 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. Jelikož se Brno stalo jedním z hlavních míst, kde se vyvíjí open source knihovna OpenSSL, tentokrát se OpenAlt komunita potká s komunitou OpenSSL. V rámci srazu Anton Arapov z OpenSSL
… více »GNOME Foundation má nového výkonného ředitele. Po deseti měsících skončil dočasný výkonný ředitel Richard Littauer. Vedení nadace převzal Steven Deobald.
Byl publikován přehled vývoje renderovacího jádra webového prohlížeče Servo (Wikipedie) za uplynulé dva měsíce. Servo zvládne už i Gmail. Zakázány jsou příspěvky generované pomocí AI.
Raspberry Pi Connect, tj. oficiální služba Raspberry Pi pro vzdálený přístup k jednodeskovým počítačům Raspberry Pi z webového prohlížeče, byla vydána v nové verzi 2.5. Nejedná se už o beta verzi.
Google zveřejnil seznam 1272 projektů (vývojářů) od 185 organizací přijatých do letošního, již jednadvacátého, Google Summer of Code. Plánovaným vylepšením v grafických a multimediálních aplikacích se věnuje článek na Libre Arts.
#include stdio.h
#include wchar.h
#include locale.h
#include curses.h
#include stdlib.h
#include string.h
int uc;
int main(void)
{
wint_t ch;
if ((setlocale(LC_ALL, "") == NULL))
{
fprintf (stderr, "Nelze inicializovat locales.");
exit(1);
}
initscr ();
noecho ();
keypad (stdscr, TRUE);
clear ();
mvprintw (4, 1, " %10i %10s %10s",55,"01234567","0123456");
mvprintw (5, 1, " %10i %10s %10s\n",55,"Žluťásek","šeřeček");
refresh ();
(void) get_wch(&ch);
echo();
endwin();
return 0;
}
... #define A "Žluťásek" #define B "šeřeček" #define LA L"Žluťásek" #define LB L"šeřeček" ... mvprintw (5, 1, " %10i %*ls %*ls",55, 10 + strlen(A) - wcswidth(LA, 20), LA, 10 + strlen(B) - wcswidth(LB, 20), LB); ...Alternativně počkat na někoho, kdo tomu opravdu rozumí.
include stdio.h
#include wchar.h
#include locale.h
#include stdlib.h
int main(void)
{
if ((setlocale(LC_ALL, "") == NULL))
{
fprintf (stderr, "Nelze inicializovat locales.");
exit(1);
}
if(fwide(stdout, 0) == 0) {
if(fwide(stdout, 1) <= 0) {
fprintf(stdout, "could not switch to wide char mode!\n");
exit(1);
}
else {
wprintf(L"switched to wide char mode!\n");
}
}
wprintf(L" %10i %10s %.4s\n",55,"01234567","0123456");
wprintf(L" %10i %10s %.4s\n",55,"Žluťásek","čeřešek");
return 0;
}
To funguje OK, ale existuje neco takoveho i pro ncurses?
Zklamu vás, ale ani wprintf() není dokonalé. Vy totiž nechcete určit počet unicodových znaků, ale počet znaků/bajtů, kolik se vejde do určitého počtu sloupců. A to závisí na konkrétních znacích (například všelijaké zvláštní znaky typu word-joiner, soft-hyphen nezabírají žádný sloupec) a na schopnostech terminálu (například japonské symboly se vypisují přes dva sloupce).
A zklamu vás ještě víc, standardní céčková knihovna žádnou pěknou funkci na to nemá. Ale nabízí drobky, ze kterých se dá požadovaná funkcionalita poskládat.
Řešil jsem to ve svém programu Šigofumi. Začíná to funkcí utf8width().
Nicméně bych se podivoval, kdyby to ncursesw už neřešila.
wchar_t tmp[512]; swprintf(tmp,sizeof(tmp)/sizeof(wchar_t),L" %20i '%20s' %.4s\n",55,"Žluťásek","šeřeček"); mvprintw (6, 1, "%ls",tmp); swprintf(tmp,sizeof(tmp)/sizeof(wchar_t),L" %20i '%20s' %.4s\n",55,"以以以以","以以以以"); mvprintw (6, 1, "%ls",tmp);Česká verze bude fungovat bez problémů, ale ta japonská ne .. Takže pokud nepřijde někdo s něčím lepším, mám jen 2 možnosti
Tiskni
Sdílej: