Všem čtenářkám a čtenářům AbcLinuxu krásné Vánoce.
Byla vydána nová verze 7.0 linuxové distribuce Parrot OS (Wikipedie). S kódovým názvem Echo. Jedná se o linuxovou distribuci založenou na Debianu a zaměřenou na penetrační testování, digitální forenzní analýzu, reverzní inženýrství, hacking, anonymitu nebo kryptografii. Přehled novinek v příspěvku na blogu.
Vývojáři postmarketOS vydali verzi 25.12 tohoto před osmi lety představeného operačního systému pro chytré telefony vycházejícího z optimalizovaného a nakonfigurovaného Alpine Linuxu s vlastními balíčky. Přehled novinek v příspěvku na blogu. Na výběr jsou 4 uživatelská rozhraní: GNOME Shell on Mobile, KDE Plasma Mobile, Phosh a Sxmo.
Byla vydána nová verze 0.41.0 multimediálního přehrávače mpv (Wikipedie) vycházejícího z přehrávačů MPlayer a mplayer2. Přehled novinek, změn a oprav na GitHubu. Požadován je FFmpeg 6.1 nebo novější a také libplacebo 6.338.2 nebo novější.
Byla vydána nová verze 5.5 (novinky) skriptovacího jazyka Lua (Wikipedie). Po pěti a půl letech od vydání verze 5.4.
Byla vydána nová verze 5.4.0 programu na úpravu digitálních fotografií darktable (Wikipedie). Z novinek lze vypíchnout vylepšenou podporu Waylandu. Nejnovější darktable by měl na Waylandu fungovat stejně dobře jako na X11.
Byla vydána beta verze Linux Mintu 22.3 s kódovým jménem Zena. Podrobnosti v přehledu novinek a poznámkách k vydání. Vypíchnout lze, že nástroj Systémová hlášení (System Reports) získal mnoho nových funkcí a byl přejmenován na Informace o systému (System Information). Linux Mint 22.3 bude podporován do roku 2029.
GNU Project Debugger aneb GDB byl vydán ve verzi 17.1. Podrobný přehled novinek v souboru NEWS.
Josef Průša oznámil zveřejnění kompletních CAD souborů rámů tiskáren Prusa CORE One a CORE One L. Nejsou vydány pod obecnou veřejnou licenci GNU ani Creative Commons ale pod novou licencí OCL neboli Open Community License. Ta nepovoluje prodávat kompletní tiskárny či remixy založené na těchto zdrojích.
Nový CEO Mozilla Corporation Anthony Enzor-DeMeo tento týden prohlásil, že by se Firefox měl vyvinout v moderní AI prohlížeč. Po bouřlivých diskusích na redditu ujistil, že v nastavení Firefoxu bude existovat volba pro zakázání všech AI funkcí.
Cupiditate sit voluptatibus architecto minus voluptatem quia et in. Facere repellendus natus ullam sunt eius non. Tempore inventore et nihil alias. Possimus sequi voluptates repellat odio quia suscipit dolores. Et nihil nihil dolore nemo harum qui quidem excepturi. Sit ut ipsa eum.
Tiskni
Sdílej:
má sice skvěle imlementováno OOP, ale obsahuje nechutný příkaz switchNechápu, jaký je v tom rozpor. Naopak, rubí switch by bez rubího OOP nefungoval, protože jeho podstatou je porovnávat zadaný objekt s alternativami pomocí metody
=== (objektové! přetížitelné! přizpůsobitelné!
), přičemž standardní třídy (číslo, interval, řetězec, regexp, třída...) mají velmi smyslupnou výchozí implementaci (je rovný číselně, je v intervalu, shodný řetězec, matchuje, je instancí...). Někdy se to hodi. A když se to nehodí, tak to prostě nepoužiju. Nikdo nikoho nenutí to používat. A komu vadí postcondition cyklus? To jako mám (když to občas potřebuju) psát <blok> ; while(<podmínka>) <blok> jako blbec?
Scheme je šíleně minimalistické, kdo potřebuje unless a until, tak si je dodělá, a kdo potřebuje when a while, tak je ani nemá.
ale hrozně se váže na EmacsVýborná pohádka na dobrou noc. Dík, hned se mi bude líp spát. Ne, opravdu k programování ve scheme nepotrebujes Emacs
.
je v praxi špatně použitelný....a proto v něm kamarád programuje špičkové realtimové měřicí přístroje.
(Vidím, že už si, krucinál, fakt budu muset najít čas na psaní a osvětu.
Nicméně se mi s jarem vrací energie.
)
Nějak nevím, nechce se mi učit nic, k čemu není dostupná čitelná dokumentace.Je opravdu řeč o Scheme?
)...spousta věcí.
Kromě toho, na draftu R6RS je vidět, že ten jazyk pomalu opouští sféru "čistě akademické hračičky" - standardizované hashovací tabulky a systém modulů rozhodně nejsou ve výukovém jazyku vyloženě zapotřebí. Svědčí o tom i roztrhnutí specifikace na vyčerpávající popis jazyka (cca. 80 stránek) a základní knihovny (cca. 60, jestli se nepletu). Pořád ještě to zůstává příjemně malé a přitom mocné. (Autor Gauche se také veřejně zavázal, že implementuje R6RS, jakmile bude schváleno, v co nejkratší době - některé jiné implementace se rozhodly zůstat u R5RS, přeci jen ne každému změny v R6RS sednou.)
Jen nevím, jak moc by bylo košér psát díly stylem "write-as-you-learn" - jsem paranoik a bojím se toho, že bych se pak za to sám styděl.
Asi by to bylo cílené na konkrétní implementaci, s tím, že R5RS a SRFI si každý může přečíst sám, kdežto Gauche má 600stránkový manuál (BTW, velmi pěkně udělaný) samo o sobě. Nicméně něco napsat budu muset, šířím osvětu i jinde a budu potřebovat ukázky tak jako tak.
U unless a until mě štve jen jejich naprosto zbytečná existenceUff, nechci vidět, jak byste se tvářil na jazyky, které mají cyklus s podmínkou uprostřed!
virgin=1;
while(condition||virgin){
blok;
virgin=0;
}
Může mi někdo z "odpíračů SWITCHe" říct, jak implementujete konečný automaty/lexikální analyzátory (pomocí řídící struktury) bez switche? Ten kód hemžící se if-ama musí bejt děsně sexy... (Na to, že by to někdo řešil "objektově" nějakym polymorfizmem se ani neodvažuju pomyslet)
if (blablabla):
pass
elif (blablabla):
pass
...
else:
pass
fakt genialny napad, nedefinovat v jazyku switch
Když budu chtít, tak si ho tak napíšu a hotovo.
myslim ze vacsina aspon trochu normalnych tvorcov prekladacov to tak so switchom spravi - tam sa to priam samo ponuka... ale ako take nieco clovek spravi s if-elif-else, to fakt netusim :o)
# pro vycet 0..n
switch1 = ( fce1, fce2, fce3, fce4 )
# obecna verze pomoci slovniku
switch = {'hodnota1' : fce1, 'hodnota2' : fce2}
# vlastni switch
switch[x](argumenty)
Výhoda je, že jsou tyto konstrukce modifikovatelné za běhu programu, což hromada ifů, nebo case ... switch není
*nenormální dokonce tak moc, že oba PEPy týkající se přidání switche - #0275 i #3103 byly zamítnuty ...
** starší verze Javy dělaly hash řetězce pomocí prvních 15 znaků. Potom do ní někdo nacpal klíče v podobě URL, kde bylo prvních 15 znaků stejných, takže místo hash mapy dostal jenom implementačně složitější lineární seznam
ale ako take nieco clovek spravi s if-elif-else, to fakt netusim :o)Hmm, na to stačí jednoduché makro s lokální datovou strukturou, do které se napchají jednotlivé alternativy a při rozhodování se z ní jen vytáhne blok kódu a zavolá...syntakticky dietní, sémanticky výkonné.
Samozřejmě, někteří začnou kvůli takové blbosti hned přepisovat parser.
Když má jazyk bloky, switch ve specifikaci jazyka nepotřebuje.