Byla vydána beta verze Ubuntu 25.10 s kódovým názvem Questing Quokka. Přehled novinek v poznámkách k vydání. Dle plánu by Ubuntu 25.10 mělo vyjít 9. října 2025.
Bola vydaná nová verzia 4.13 security platformy Wazuh. Prináša nový IT hygiene dashboard, hot reload dekodérov a pravidiel. Podrobnosti v poznámkách k vydaniu.
Americký výrobce čipů Nvidia investuje pět miliard dolarů (přes 100 miliard Kč) do konkurenta Intel, který se v poslední době potýká s vážnými problémy. Firmy to včera oznámily ve společné tiskové zprávě. Dohoda o investici zahrnuje spolupráci při vývoji čipů pro osobní počítače a datová centra. Akcie společnosti Intel na zprávu reagovaly výrazným růstem.
Dlouholetý balíčkář KDE Jonathan Riddell končí. Jeho práci na KDE neon financovala firma Blue Systems, která ale končí (Clemens Tönnies, Jr., dědic jatek Tönnies Holding, ji už nebude sponzorovat), někteří vývojáři KDE se přesunuli k nově založené firmě Techpaladin. Pro Riddella se již nenašlo místo. Následovala debata o organizaci těchto firem, které zahraniční vývojáře nezaměstnávají, nýbrž najímají jako kontraktory (s příslušnými důsledky z pohledu pracovního práva).
V Amsterdamu probíhá Blender Conference 2025. Videozáznamy přednášek lze zhlédnout na YouTube. V úvodní keynote Ton Roosendaal oznámil, že k 1. lednu 2026 skončí jako chairman a CEO Blender Foundation. Tyto role převezme současný COO Blender Foundation Francesco Siddi.
The Document Foundation, organizace zastřešující projekt LibreOffice a další aktivity, zveřejnila výroční zprávu za rok 2024.
Byla vydána nová stabilní verze 7.6 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 140. Přehled novinek i s náhledy v příspěvku na blogu.
Byla vydána verze 1.90.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.
GNUnet (Wikipedie) byl vydán v nové major verzi 0.25.0. Jedná se o framework pro decentralizované peer-to-peer síťování, na kterém je postavena řada aplikací.
Byla vydána nová major verze 7.0 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Nově je postavena je na Debianu 13 (Trixie) a GNOME 48 (Bengaluru). Další novinky v příslušném seznamu.
then()
. Po provedení všech úkonů potřebuju provést ještě další funkci prostřednictvím metody finally()
. Aby ta však přišla ke slovu, je nutné, aby všechny zřetězené sliby byly důsledně vypořádány čili zejména aby bylo ošetřeno jejích odmítnutí (rejection) - a na to právě směruje můj dotaz nebo vlastně dotazy dva.
Jak je z ukázky vidět, splnění slibu je vázáno na určité podmínky (přítomnost prvku v dokumentu a jeho momentální poloha vůči viewportu) a když ty nejsou splněny, slib je odmítnut. Odmítnutí bych mohl zapsat zástupnou funkcí reject()
, jak mám v komentáři, a vše by bylo bez problémů, ale když chci "vyhodit" vlastní výjimku ("throw
"), na řádku 10 mi způsobí, že se mi do konzole vypíše, že výjimka nebyla zachycena ("uncaught
"), a navíc se pak nevykoná funkce v metodě finally()
; na řádku 15 nicméně zapsání výjimky zachyceno je. Proč tedy výjimka na řádku 10 není zachycena, kdežto na řádku 15 je?
Druhý dotaz se týká způsobu konečného vypořádání odmítnutí slibu uvnitř metody catch()
. Samozřejmě se nabízí console.log()
nebo console.error()
, ale já do konzole nic vypisovat nechci (proč by se tam mělo něco vypisovat, když byl slib odmítnut čistě proto, že v dokumentu není přítomen určitý prvek (element), jehož přítomnost je volitelná). Jak mám tedy prostřednictvím metody catch()
vypořádat odmítnutí slibu tak, aby se nikde nic nevypisovalo?
Doufám, že mé dotazy nejsou napsány nesrozumitelně.
...).then((val) => { classReplace(...val); return new Promise(function(resolve, reject) { if (element) { setTimeout(() => { if (element.classList.contains("class1")) { if (element.getBoundingClientRect().top + 500 < screenHeight) { resolve([element, "class1", "class2"]) } else { (řádek 10) throw("element out of viewport") // nebo: reject("element out of viewport") } } }, 800) } else { (řádek 15) throw("element absent") // nebo: reject("element absent") } }) }).then(...) .catch( error => { console.log(error) }).finally(...
() => {
if (element.classList.contains("class1")) {
if (element.getBoundingClientRect().top + 500 < screenHeight) {
resolve([element, "class1", "class2"])
} else {
(řádek 10) throw("element out of viewport") // nebo: reject("element out of viewport")
}
}
Takže jakákoliv výjimka vypadne z téhle funkce, tak vybublá na console, bo ji nikdo nechytá. V době, kdy se tahle funkce pustí, je původní funkce pro Promise už dávno ukončená.
Tiskni
Sdílej: