Od úterý 28. dubna musí nově uváděné notebooky v Evropské unii podporovat nabíjení přes USB-C. Jednotná nabíječka byla schválena Evropským parlamentem v říjnu 2022.
Byly publikovány informace o kritické zranitelnosti CVE-2026-31431 pojmenované Copy Fail v Linuxu, konkrétně v kryptografii (AF_ALG). Běžný uživatel může získat práva roota (lokální eskalaci práv). Na všech distribucích Linuxu vydaných od roku 2017. Pomocí 732bajtového skriptu. V upstreamu je již opraveno. Zranitelnost byla nalezena pomocí AI Xint Code.
Textový editor Zed dospěl do verze 1.0. Představení v příspěvku na blogu.
Vývojáři svobodného 3D softwaru Blender představili (𝕏, Mastodon, Bluesky) nejnovějšího firemního sponzora Blenderu. Je ním společnost Anthropic stojící za AI Claude a úroveň sponzoringu je Patron, tj. minimálně 240 tisíc eur ročně. Anthropic oznámil sponzorství v tiskové zprávě Claude for Creative Work.
VNC server wayvnc pro Wayland kompozitory postavené nad wlroots - ne GNOME, KDE nebo Weston - byl vydán ve verzi 0.10.0. Vydána byla také verze 1.0.0 související knihovny neatvnc.
Bylo oznámeno vydání Fedora Linuxu 44. Ve finální verzi vychází šest oficiálních edic: Fedora Workstation a Fedora KDE Plasma Desktop pro desktopové, Fedora Server pro serverové, Fedora IoT pro internet věcí, Fedora Cloud pro cloudové nasazení a Fedora CoreOS pro ty, kteří preferují neměnné systémy. Vedle nich jsou k dispozici také další atomické desktopy, spiny a laby. Podrobný přehled novinek v samostatných článcích na stránkách
… více »David Malcolm se na blogu vývojářů Red Hatu rozepsal o vybraných novinkách v GCC 16, jež by mělo vyjít v nejbližších dnech. Vypíchnuta jsou vylepšení čitelnosti chybových zpráv v C++, aktualizovaný SARIF (Static Analysis Results Interchange Format) výstup a nová volba experimental-html v HTML výstupu.
Byla vydána verze R14.1.6 desktopového prostředí Trinity Desktop Environment (TDE, fork KDE 3.5, Wikipedie). Přehled novinek v poznámkách k vydání, podrobnosti v seznamu změn.
Jon Seager z Canonicalu včera na Ubuntu Community Hubu popsal budoucnost AI v Ubuntu. Dnes upřesnil: AI nástroje budou k dispozici jako Snap balíčky, vždy je může uživatel odinstalovat. Ve výchozím nastavení budou všechny AI nástroje používat lokální AI modely.
Nový ovladač Steam Controller jde do prodeje 4. května. Cena je 99 eur.
/neco_1/AAA/*.aaa /neco_1/BBB/*.bbb /neco_2/AAA/*.aaa /neco_2/BBB/*.bbb ... /neco_N/AAA/*.aaa /neco_N/BBB/*.bbbTzn. každý adresář (říkejme mu třeba hlavní) obsahuje vždy dva 'vedlejší' poadresáře (vždy AAA a BBB) a ty pak vlastní data. Potřeboval bych tento strom připojit (zpřístupnit) tak, abych efektivně viděl toto:
/neco_1a/neco_1b/*.aaa /neco_2a/neco_2b/*.aaa ... /neco_Na/neco_Nb/*.aaaTj. 'hlavní' adresář už nebude obsahovat oba podadresáře, ale přímo obsah jednoho z nich. Nějak netuším co vlastně hledat. Určitě by se to dalo řešit odkazy, ale to by bylo strašné práce. Navíc by se hodilo, pokud by to živě reagovalo na změnu v tom původním stromě. Varianta by byla napsat skript, který by ty linky vytvořil a spouštět ho pokaždé, když dojde ke změně, ale možná existuje nějaké 'systémové' řešení. Díky.
Tvůj dotaz nedává smysl. Buď konkrétnější.Toho jsem se trochu bál. Moc nevím, jak to popsat lépe. Zkus si to představit jako např. hudební kolekci se soubory v různém formátu. Cesta './neco_X/' přestavuje cestu k hudebnímu albu a podadresáře 'AAA', resp. 'BBB' pak obsahují tytéž skladby v různých formátech ('aaa' a 'bbb'). A ty to chceš připojit tak, že koncový uživatel uvidí jen jeden z těch formátů (tzn './neco_X/*.aaa'), např. proto, že jeho přehrávač podporuje jen formát 'aaa', zatímco přehrávač jiného uživatele podporuje pouze formát 'bbb' (tomu to zase připojíš jinam, aby viděl jen formát 'bbb'). Ten příklad je asi dost kostrbatá konstrukce, ale snad to půjde takhle pochopit. Ale je to jen pro ilustraci, konkrétní problém by byl asi složitý na vysvětlení. Symlinky s inotify mám v záloze, zajímalo mně, jestli už něco takového neexistuje. FUSE mě taky napadlo, ale to by asi bylo zbytečně moc komplikované (nemám s tím zatím žádné zkušenosti). Změna na aplikační úrovni je taky možnost, ale do toho se mi moc nechce, protože tak jak je to generováno je to přehledné a logicky umístěné a dobře se to spravuje. A na opačném konci bych zase chtěl uživatele odstínit od pro něho nepotřebných dat (je to součást jakého si veřejného API). Ale zas bych pak nemusel dělat tohle harakiri se symlinkama, hmmm...
/neco_1a/neco_1b/*.aaa /neco_2a/neco_2b/*.aaaTohle stoji za vysvetleni, uz ten prvni radek je nejasny. Myslim ze by pomohl skutecny priklad treba to 1b v prvnim radku je klicove.
/foo/bar/aaa/*.aaa /foo/bar/bbb/*.bbbvypadat (pro parametr aaa) takhle:
/foo/bar/*.aaaa pro parametr 'bbb' takhle:
/foo/bar/*.bbb
FUSE mě taky napadlo, ale to by asi bylo zbytečně moc komplikované (nemám s tím zatím žádné zkušenosti).Ještě se dá přes LD_PRELOAD hookovat funkce fopen a podobné a patchovat cesty za běhu
A na opačném konci bych zase chtěl uživatele odstínit od pro něho nepotřebných dat (je to součást jakého si veřejného API).A proč nemůže server prezentovat uživatelům jednu strukturu a na storage používat jinou?
<?php
/*
* Licence: CC0
*
* Notice: In name of file/dir doesn't can char '/'.
*/
define("ORIGINAL_DATA", "/dev/shm/original");
define("SYM_DATA", "/dev/shm/symbols");
// create testing data
function path_add_root($path)
{
return ORIGINAL_DATA."/$path";
}
$dirs=array(
'2020-01-01/export/',
'2020-01-01/raw/',
'2020-01-02/export/',
'2020-01-02/raw/',
'2020-01-03/export/',
'2020-01-03/raw/',
'2020-01-04/export/',
'2020-01-04/raw/'
);
// vytvaram testovacie data
$path_dirs=array_map("path_add_root", $dirs);
system("rm -r ".ORIGINAL_DATA." ".SYM_DATA);
mkdir(ORIGINAL_DATA);// or die("Nevytvoril sa ".ORIGINAL_DATA);
system("mkdir -p ".implode(" ", $path_dirs));
foreach($path_dirs as $path)
{
if(strpos($path, "raw") !== false)
$name="r";
else
$name="e";
touch($path."$name.data");
touch($path."$name.data");
touch($path."$name.data");
}
// "main()" program
function create_sym_links($path, $path_sym)
{
// get full path list
$files=array();
$list_1=scandir($path);
foreach($list_1 as $item_1)
if(strcmp("$item_1",".") != 0 && strcmp("$item_1","..") != 0)
{
$list_2=scandir("$path/$item_1");
foreach($list_2 as $item_2)
if(strcmp("$item_2",".") != 0 && strcmp("$item_2","..") != 0)
array_push($files, "$item_1/$item_2");
}
foreach($files as $file)
{
$sym_dir=str_replace("/", "_", $file);
symlink("$path/$file","$path_sym/$sym_dir");
}
}
mkdir(SYM_DATA) or die("Nevytvoril sa ".SYM_DATA);
create_sym_links(ORIGINAL_DATA, SYM_DATA);
Tiskni
Sdílej: