Offpunk byl vydán ve verzi 3.0. Jedná se o webový prohlížeč běžící v terminálu a podporující také protokoly Gemini, Gopher a RSS. Přibyl nástroj xkcdpunk pro zobrazení XKCD v terminálu.
Promethee je projekt, který implementuje UEFI (Unified Extensible Firmware Interface) bindingy pro JavaScript. Z bootovacího média načítá a spouští soubor 'script.js', který může používat UEFI služby. Cílem je vytvořit zavaděč, který lze přizpůsobit pomocí HTML/CSS/JS. Repozitář se zdrojovými kódy je na Codebergu.
Zpráva Justičního výboru Sněmovny reprezentantů upozorňuje na cenzurní kampaň Evropské komise, mířenou proti svobodě projevu na sociálních sítích. V dokumentu se uvádí, že se Evropská komise během posledních šesti let účastnila více než 100 uzavřených jednání, během nichž po platformách požadovala úpravy pravidel moderování obsahu, přičemž toto úsilí Komise zahrnovalo i cenzuru politických názorů a pravdivých informací. Výbor zdůrazňuje, že tento přístup Bruselu ohrožuje ústavou zaručená práva Američanů na svobodu projevu.
Linus Torvalds vydal jádro Linux 6.19. Podrobný výčet změn je ke zhlédnutí na stránce Kernel Newbies, stručné výběry v LWN (část první, druhá).
Do prodeje jde tichá bezdrátová herní myš Logitech PRO X2 SUPERSTRIKE s analogovými spínači s haptickou odezvou (HITS, Haptic Inductive Trigger System). Cena je 4 459 Kč.
Microsoft na GitHubu zveřejnil zdrojový kód projektu LiteBox, jedná se o 'knihovní operační systém' (library OS) zaměřený na bezpečnost, využívající systémovou architekturu LVBS k ochraně jádra před útoky z uživatelského prostoru. LiteBox je napsán v Rustu a uvolněný pod licencí MIT. Projekt je teprve v rané fázi vývoje.
BreezyBox je open-source shell a virtuální terminál pro populární jednočip ESP32. Nabízí základní unixové příkazy, sledování aktuálního pracovního adresáře (CWD), jednoduchý instalátor a spouštěč aplikací v podobě ELF binárních souborů, zabudovaný HTTP server nebo třeba ovládání WiFi - ukázka použití coby 'malého osobního počítače'. Ačkoliv je BreezyBox inspirovaný BusyBoxem, oproti němu má tento projekt několik externích závislostí, zejména na ESP-IDF SDK. BreezyBox je dostupný pod licencí MIT.
Byl představen cross-assembler xa.sh, napsaný čistě v Bourne shell skriptu. Tento nástroj umožňuje zpracovávat assemblerový kód pro Intel 8080, přičemž je možné snadno přidat podporu i pro další architektury, například 6502 a 6809. Skript využívá pouze různé běžné unixové příkazy jako jsou awk, sed nebo printf. Skript si lze stáhnout z GitHubového repozitáře projektu.
Byla představena nová verze modelu Claude Opus 4.6 od společnosti Anthropic. Jako demonstraci možností Anthropic využil 16 agentů Claude Opus 4.6 k vytvoření kompilátoru jazyka C, napsaného v programovacím jazyce Rust. Claude pracoval téměř autonomně, projekt trval zhruba dva týdny a náklady činily přibližně 20 000 dolarů. Výsledkem je fungující kompilátor o 100 000 řádcích kódu, jehož zdrojový kód je volně dostupný na GitHubu pod licencí Creative Commons.
Kultovní britský seriál The IT Crowd (Ajťáci) oslavil dvacáté výročí svého prvního vysílání. Sitcom o dvou sociálně nemotorných pracovnících a jejich nadřízené zaujal diváky svým humorem a ikonickými hláškami. Seriál, který debutoval v roce 2006, si i po dvou dekádách udržuje silnou fanouškovskou základnu a pravidelně se objevuje v seznamech nejlepších komedií své doby. Nedávné zatčení autora seriálu Grahama Linehana za hatecrime však vyvolává otázku, jestli by tento sitcom v současné Velké Británii vůbec vznikl.
Ahoj,
zabývám se návrhem webové aplikace (obecně) a sháním nějaké povídání o návrhových vzorech týkajících se umisťování více věcí na jednu (obvykle HTML) stránku.
Klasické MVC je fajn, ale v podstatě řeší jen onu centrální komponentu, jako je třeba ta na zobrazení dotazu, který právě čtete.
Mě však právě zajímají různé způsoby, jak na stránku elegantně dostat i další věci, jako třeba výpis zpráviček nalevo, menu nahoře, anketu, reklamy, vyhledávací políčko a další věci.
Nevíte tedy o nějakých zajímavých článcích, návrhových vzorech a podobných věcech toho se týkajících (třeba i jen vzdáleně)?
ps: Jde mi o posbírání zajímavých materiálů pro další studium, nikoliv o jedno správné řešení.
. Pokusím se zjednodušeně shrnout podstatu:
V Nette autor používá trochu jinou terminologii - místo MVC používá MVP (Model View Presenter). Kromě Controlleru hrají v Nette důležitou roli komponenty (Control = vykreslitelná komponenta v terminologii Nette). Komponenta - např. nějaká anketa - je napojená na controller, lze ji vykreslit v šabloně, a může přijímat tzv. signály, což jsou odkazy ve tvaru:
"/cesta/v/aplikaci/k/action?do=NAZEV_KOMPONENTY-NAZEV_SIGNALU&NAZEV_KOMPONENTY-NejakyParametr=hodnota"Signál může být např. přičtění hlasu v anketě. Trik je v tom, že konkrétní controller má mechanismus k vyhledání komponenty. Komponenta je představována třídou, jejíž instanci vrací metoda controlleru nazvaná "getComponentNAZEV_KOMPONENTY". Zároveň se tím řeší vytvoření instance komponenty přesně v okamžiku, kdy je poprvé potřeba. Pokud chci stejnou komponentu používat třeba ve všech controllerech, tak je jednoduše podědím od společného předka. Signály od komponent se obsluhují úplně na začátku, ještě před provedením Action. Navíc komponenty jsou uspořádány do stromové struktury, tj. komponenta může obecně obsahovat potomky. V Nette je to elegantně doplněné systémem šablon, kde v příslušné šabloně stačí uvést:
{widget menu $treba_nejaky_parametr}
Šablona má přístup ke controlleru, umí si načíst komponentu "menu" a zavolat na ní metodu render($muze_mit_parametry). V šablonách jde pak snadno generovat odkazy na signály (s tím ?do= na konci).
Obsluha signálů je řešena tak, že komponenta má metodu "handleNAZEV_SIGNALU(...parametry...)".
Podle mě je to celkem elegantní řešení. Zatím jsem do toho úplně neproniknul, ale je tam pár problémů - třeba pokud je potřeba jednu komponentu umístit na stránku vícekrát.
V Nette je nad tím postavena ještě podpora pro AJAX - po přijetí signálu pomocí AJAXu se prohlížeči může poslat vyrenderované HTML změněných komponent - tím lze jednoduše řešit treba to hlasování v anketě na stránce...
Pokud to můžu srovnat třeba se Zend Frameworkem pro PHP, tak tam tohle asi nemá obecné řešení. Viděl jsem řešení, kdy takovéhle komponenty byly realizované jako speciální Controller a Action, pak se v rámci jednoho requestu volaly různé Action, výstup šablony se vždy uložil zvlášť pod nějakým označením, a v hlavní šabloně se to vykreslilo na správná místa.
Propojení komponent se asi obvykle řeší v Controlleru. Konktrétně v tomhle případě je stejně potřeba získat data pro ten seznam z modelu a předat mu je - no a v tomhle okamžiku se na základě těch dat (počet záznamů) a konfigurace (po kolika stránkovat) nastaví stránkovač. Př.:
class NejakyController extends BaseController {
function renderNejakaAction()
{
$model = new NejakyModel();
$data = $model->getData();
$this->getComponentStrankovac->setup($model->count(), POCET_ZAZNAMU_NA_STRANKU);
$model->limitPage($this->getComponentStrankovac->getCurrentPage());
$this->getComponentVypis()->data = $model->getData();
// nebo v Nette lze pouzit:
// $this['vypis']->data = ...;
}
// funkce se schvalne jmenuje 'create...', Controller volani 'getComponent...'
// automaticky prevede na tuto funkci a navrch zajisti propojeni instance
// komponenty s Controllerem. Komponenta pak muze vyuzit Controller ke
// generovani odkazu apod.
function createComponentStrankovac()
{
return new Strankovac();
}
//
function createComponentVypis()
{
return new Vypis();
}
}
Jiná možnost je, že se data pro ten seznam načítají z modelu přímo v té komponentě "seznam", pak stránkování jde udělat jako sub-komponentu toho seznamu a opět v okamžiku načtení dat se počet stránek nastaví té sub-komponentě. Tohle nijak neomezuje možnosti vykreslení v šabloně - lze samostatně vykreslit seznam a stránkování přesně jak je potřeba. Jedna komponenta obecně nemusí být vykreslena v jednom bloku v šabloně, jde spíš o "logickou" část stránky.
Je možné také řešení, kdy obě komponenty budou připojeny ke controlleru, a třeba ta komponenta na stránkování se zevnitř dostane k seznamu:$pocetStran = $this->getController()->getComponentSeznam()->getPageCount();
Tím se ale podle mě omezí znovupoužitelnost té komponenty, protože pevně předpokládá existenci "seznam" v Controlleru. Co když budu mít těch seznamů na stránce víc?
Tiskni
Sdílej: