ASUS má v nabídce komplexní řešení pro vývoj a nasazení AI: kompaktní stolní AI superpočítač ASUS Ascent GX10 poháněný superčipem NVIDIA GB10 Grace Blackwell a platformou NVIDIA DGX Spark. S operačním systémem NVIDIA DGX založeném na Ubuntu.
Desktopové prostredie Trinity Desktop vyšlo vo verzii R14.1.5. Je tu opravená chyba v tqt komponente spôsobujúca 100% vyťaženie cpu, dlaždice pre viac monitorov a nemenej dôležité su dizajnové zmeny v podobe ikon, pozadí atď. Pridaná bola podpora distribúcií Debian Trixie, Ubuntu Questing, RHEL 10 a OpenSUSE Leap 16.
Grafická aplikace Easy Effects (Flathub), původně PulseEffects, umožňující snadno povolovat a zakazovat různé audio efekty v aplikacích používajících multimediální server PipeWire, byla vydána ve verzi 8.0.0. Místo GTK 4 je nově postavená nad Qt, QML a Kirigami.
Na YouTube lze zhlédnout Godot Engine – 2025 Showreel s ukázkami toho nejlepšího letos vytvořeného v multiplatformním open source herním enginu Godot.
Blíží se konec roku a tím i všemožná vyhlášení slov roku 2025. Dle Collins English Dictionary je slovem roku vibe coding, dle Dictionary.com je to 6-7, …
Cloudflare Radar: podíl Linuxu na desktopu dosáhl v listopadu 6,2 %.
Chcete vědět, co se odehrálo ve světě techniky za poslední měsíc? Nebo si popovídat o tom, co zrovna bastlíte? Pak doražte na listopadovou Virtuální Bastlírnu s mikrofonem a kamerou, nalijte si něco k pití a ponořte se s strahovskými bastlíři do diskuze u virtuálního piva o technice i všem možném okolo. Mezi nejvýznamnější novinky patří Průšovo oznámení Core One L, zavedení RFID na filamentech, tisk silikonu nebo nový slicer. Dozvíte se ale i
… více »Vývojáři OpenMW (Wikipedie) oznámili vydání verze 0.50.0 této svobodné implementace enginu pro hru The Elder Scrolls III: Morrowind. Přehled novinek i s náhledy obrazovek v oznámení o vydání.
Komunita kolem Linux Containers po roce vývoje představila (YouTube) neměnný operační systém IncusOS speciálně navržený pro běh Incusu, tj. komunitního forku nástroje pro správu kontejnerů LXD. IncusOS poskytuje atomické aktualizace prostřednictvím mechanismu A/B aktualizací s využitím samostatných oddílů a vynucuje zabezpečení bootování pomocí UEFI Secure Bootu a modulu TPM 2.0. Postaven je na Debianu 13.
Mozilla začne od ledna poskytovat komerční podporu Firefoxu pro firmy. Jedná se o podporu nad rámec stávající podpory, která je k dispozici pro všechny zdarma.
#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: