Byly zveřejněny informace o kritické zranitelnosti CVE-2025-55182 s CVSS 10.0 v React Server Components. Zranitelnost je opravena v Reactu 19.0.1, 19.1.2 a 19.2.1.
Bylo rozhodnuto, že nejnovější Linux 6.18 je jádrem s prodlouženou upstream podporou (LTS). Ta je aktuálně plánována do prosince 2027. LTS jader je aktuálně šest: 5.10, 5.15, 6.1, 6.6, 6.12 a 6.18.
Byla vydána nová stabilní verze 3.23.0, tj. první z nové řady 3.23, minimalistické linuxové distribuce zaměřené na bezpečnost Alpine Linux (Wikipedie) postavené na standardní knihovně jazyka C musl libc a BusyBoxu. Přehled novinek v poznámkách k vydání.
Byla vydána verze 6.0 webového aplikačního frameworku napsaného v Pythonu Django (Wikipedie). Přehled novinek v poznámkách k vydání.
Po více než 7 měsících vývoje od vydání verze 6.8 byla vydána nová verze 6.9 svobodného open source redakčního systému WordPress. Kódové jméno Gene bylo vybráno na počest amerického jazzového klavíristy Gene Harrise (Ray Brown Trio - Summertime).
Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za listopad (YouTube).
Google Chrome 143 byl prohlášen za stabilní. Nejnovější stabilní verze 143.0.7499.40 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 13 bezpečnostních chyb.
Společnost Valve aktualizovala přehled o hardwarovém a softwarovém vybavení uživatelů služby Steam. Podíl uživatelů Linuxu dosáhl 3,2 %. Nejčastěji používané linuxové distribuce jsou Arch Linux, Linux Mint a Ubuntu. Při výběru jenom Linuxu vede SteamOS Holo s 26,42 %. Procesor AMD používá 66,72 % hráčů na Linuxu.
Canonical oznámil (YouTube), že nově nabízí svou podporu Ubuntu Pro také pro instance Ubuntu na WSL (Windows Subsystem for Linux).
Samsung představil svůj nejnovější chytrý telefon Galaxy Z TriFold (YouTube). Skládačka se nerozkládá jednou, ale hned dvakrát, a nabízí displej s úhlopříčkou 10 palců. V České republice nebude tento model dostupný.
Ahoj
Pisu ohledne takove "nevyznamne blbosti", ale zajimalo by me jak to funguje :) Pouzivam BASH a chtel bych se zeptat, jaktoze kdyz pustim binarku ./program ~/souborvhome.txt, tak v programu je hodnota argumentu /home//user/souborvhome.txt, ale kdyz ho pustim jako ./program ./souborvaktualnimadresari.txt, tak v programu dostanu stejnou hodnotu ./souborvaktualnimadresari.txt. Ocekaval bych, ze BASH ji take doplni na /cesta/aktualniho/adresare//souborvaktualnimadresari.txt.
Kdyz teda potom treba funkce fopen chce otevrit soubor a zjisti, ze cesta je zadana ve formatu relativne od aktualniho adresari, tak jak zjisti kde je?
Ptam se proto, ze delam program, ktery ma ve stejne slozce jako spousteci binarka podslozku, kde jsou ulozene pluginy ve forme shared object souboru. A uzivatel muze pri spusteni programu vybrat, ktere pluginy pustit. Predstavoval bych si, ze to zada bud jako plugin.so a program ho bude hledat v tom hlavnim ulozisti, nebo ho zada ve formatu ~/plugin.so cili v jeho home slozce (tu bash doplni na absolutni, takze zde nebude problem), dalsi volba by mela byt ./plugin.so (tady si prave nejsem jisty), takze aktualni adresar, nebo absolutni cesta (coz je taky uplne jasne)...
Diky moc, Tomas
HOME, kterou na začátku nastaví na domácí adresář uživatele, pod nímž běží. Ale když si později změníte HOME, bude vlnka expandovat na novou hodnotu proměnné HOME.
Mno, ale zase
$ echo ~root /root
Takže se to asi nezískává z proměnné HOME. Spíš rovnou z /etc/passwd
Ale řeč byla o expanzi ~, ne ~user. To je dost podstatný rozdíl:
mike@unicorn:~> echo $HOME /home/mike mike@unicorn:~> echo ~ /home/mike mike@unicorn:~> echo ~mike /home/mike mike@unicorn:~> HOME=/tmp mike@unicorn:/home/mike> echo ~ /tmp mike@unicorn:/home/mike> echo ~mike /home/mike
Exportovat ji určitě nemusíte, protože tu expanzi provádí bash sám, ne až to echo (ať už builtin nebo externí). Co máte za verzi bashe? Navíc chování, které jsem demonstroval výše, odpovídá i dokumentaci:
If a word begins with an unquoted tilde character (`~'), all of the
characters preceding the first unquoted slash (or all characters, if
there is no unquoted slash) are considered a tilde-prefix. If none of
the characters in the tilde-prefix are quoted, the characters in the
tilde-prefix following the tilde are treated as a possible login name.
If this login name is the null string, the tilde is replaced with the
value of the shell parameter HOME. If HOME is unset, the home direc-
tory of the user executing the shell is substituted instead. Other-
wise, the tilde-prefix is replaced with the home directory associated
with the specified login name.
(bash 3.2.39)
argv[0] neobsahuje plnou cestu k programu. Pokud program nebude v cestě (tj. spouštěn z adresáře uvedeného v PATH), lze ziskat z nultého parametru cestu k programu nalezením posledního lomítka, a pokud tam žádné není, omezuje se cesta na aktuální adresář. I relativní cesta stačí k nazelení souborů, které se nacházejí v adresáři programu. Podobnou službu udělá funkce dirname (podle normy POSIX).
Horší je, pokud program bude v cestě, pak nultý parametr cestu neobsahuje. Potom nezbývá než cestu prohledat.
Pro Linux existuje snadné a přímočaré řešení: realpath("/proc/self/exe", NULL). Nevýhodou je, že /proc nemusí na jiných systémech tento symbolický odkaz obsahovat. Lze použít i realpath(argv[0], buffer), což funguje stejně v Linuxu, FreeBSD i IRIXu, ale opět nejde o spolehlivou metodu, pokud je program v cestě. Navíc nelze spolehlivě rozhodnout, jak velký má být buffer, obvykle to je PATH_MAX, ale není to všude. Více uvádí manuálová stránka této funkce.
Tiskni
Sdílej: