raylib (Wikipedie), tj. multiplatformní open-source knihovna pro vývoj grafických aplikací a her, byla vydána ve verzi 6.0.
Nové verze AI modelů. Společnost OpenAI představila GPT‑5.5. Společnost DeepSeek představila DeepSeek V4.
Nová čísla časopisů od nakladatelství Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 164 (pdf) a Hello World 29 (pdf).
Bylo oznámeno, že webový prohlížeč Opera GX zaměřený na hráče počítačových her je už také na Flathubu and Snapcraftu.
Akcionáři americké mediální společnosti Warner Bros. Discovery dnes schválili převzetí firmy konkurentem Paramount Skydance za zhruba 110 miliard dolarů (téměř 2,3 bilionu Kč). Firmy se na spojení dohodly v únoru. O část společnosti Warner Bros. Discovery dříve usilovala rovněž streamovací platforma Netflix, se svou nabídkou však neuspěla. Transakci ještě budou schvalovat regulační orgány, a to nejen ve Spojených státech, ale také
… více »Canonical vydal (email, blog, YouTube) Ubuntu 26.04 LTS Resolute Raccoon. Přehled novinek v poznámkách k vydání. Vydány byly také oficiální deriváty Edubuntu, Kubuntu, Lubuntu, Ubuntu Budgie, Ubuntu Cinnamon, Ubuntu Kylin, Ubuntu Studio, Ubuntu Unity a Xubuntu. Jedná se o 11. vydání s dlouhodobou podporou (LTS).
V programovacím jazyce Go naprogramovaná webová aplikace pro spolupráci na zdrojových kódech pomocí gitu Gitea (Wikipedie) byla vydána v nové verzi 1.26.0. Přehled novinek v příspěvku na blogu.
Ve středu 29. dubna 2026 se v pražské kanceláři SUSE v Karlíně uskuteční 7. Mobile Linux Hackday, komunitní setkání zaměřené na Linux na mobilních zařízeních, kernelový vývoj i uživatelský prostor. Akce proběhne od 10:00 do večerních hodin. Hackday je určen všem zájemcům o praktickou práci s Linuxem na telefonech. Zaměří se na vývoj aplikací v userspace, například bankovní aplikace, zpracování obrazu z kamery nebo práci s NFC, i na úpravy
… více »LilyPond (Wikipedie) , tj. multiplatformní svobodný software určený pro sazbu notových zápisů, byl vydán ve verzi 2.26.0. Přehled novinek v aktualizované dokumentaci.
Byla vydána nová verze 11.0.0 otevřeného emulátoru procesorů a virtualizačního nástroje QEMU (Wikipedie). Přispělo 237 vývojářů. Provedeno bylo více než 2 500 commitů. Přehled úprav a nových vlastností v seznamu změn.
Určitě jste už někdy potřebovali napsat kratší návod nebo krátký technický dokument. Technická dokumentace by měla mít na začátku obsah (TOC). Musíme tedy najít takový formát, který umí obsah (TOC) vygenerovat sám, protože udržovat dokument i s obsahem (TOC) je mírně řečeno nešikovné.
Popíšeme si tedy kousek Javascriptu, který umí vygenerovat a zobrazit klikací obsah v HTML. Někdy je totiž použití TeXu nevhodné (čtenář neocení krásné slitky fi, fl, ffi, ffl, vyrovnané mezery ve slově PLAVAT atd. Nehledě k tomu, že na Windows je GSView vzácnost. Stručně řečeno házíme perly sviním). Word nebo Swriter je je trošku jiná kategorie, hodně lidí s nimi nechce mít nic společného a navíc se moc nedá čekat, že příjemce uvidí dokument stejně jako my. (U HTML se to už vůbec nedá čekat, ale s tím se tak nějak počítá).
- <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
- <html>
- <head>
- <META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=iso-8859-1">
- <META NAME="AUTHOR" CONTENT="Tomas Penicka">
- <!-- Based on http://www.quirksmode.org/dom/toc.html, but some changes were made-->
- <script type="text/javascript">
- function getElementsByTagNames(list,obj) {
- if (!obj) var obj = document;
- var tagNames = list.split(',');
- var resultArray = new Array();
- for (var i=0;i<tagNames.length;i++) {
- var tags = obj.getElementsByTagName(tagNames[i]);
- for (var j=0;j<tags.length;j++) {
- resultArray.push(tags[j]);
- }
- }
- var testNode = resultArray[0];
- if (!testNode) return [];
- if (testNode.sourceIndex) {
- resultArray.sort(function (a,b) {
- return a.sourceIndex - b.sourceIndex;
- });
- }
- else if (testNode.compareDocumentPosition) {
- resultArray.sort(function (a,b) {
- return 3 - (a.compareDocumentPosition(b) & 6);
- });
- }
- return resultArray;
- }
- function createTOC() {
- var y = document.createElement('div');
- y.id = 'innertoc';
- var a = y.appendChild(document.createElement('span'));
- a.onclick = showhideTOC;
- a.id = 'contentheader';
- a.innerHTML = 'hide page contents';
- var z = y.appendChild(document.createElement('div'));
- var toBeTOCced = getElementsByTagNames('h2,h3,h4,h5,h6');
- if (toBeTOCced.length < 2) return false;
- for (var i=0;i<toBeTOCced.length;i++) {
- var tmp = document.createElement('a');
- tmp.innerHTML = toBeTOCced[i].innerHTML;
- z.appendChild(tmp);
- tmp.className = 'indent' + toBeTOCced[i].nodeName.substring(1);
- var headerId = toBeTOCced[i].id || 'link' + i;
- tmp.href = '#' + headerId;
- toBeTOCced[i].id = headerId;
- }
- return y;
- }
- var TOCstate = 'block';
- function showhideTOC() {
- TOCstate = (TOCstate == 'none') ? 'block' : 'none';
- var newText = (TOCstate == 'none') ? 'show page contents' : 'hide page contents';
- document.getElementById('contentheader').innerHTML = newText;
- document.getElementById('contentheader').onclick = showhideTOC;
- document.getElementById('innertoc').lastChild.style.display = TOCstate;
- alert();
- }
- </script>
- <style type="text/css">
- #toc a {display: block; margin-top: 2pt; background-color: #EEEEEE;}
- #toc a:hover {background-color: #CCCCFF;}
- .indent2 {margin-left: 0em;}
- .indent3 {margin-left: 2em;}
- .indent4 {margin-left: 4em;}
- .indent5 {margin-left: 6em;}
- .indent6 {margin-left: 8em;}
- </style>
- <title></title>
- </head>
- <body onLoad="document.getElementById('toc').appendChild(createTOC());">
- <!-- The following DIV is exactly the place, where to TOC will be located, don't remove this -->
- <div id="toc"></div>
- </body>
- </html>
Chtěl jsem ještě přidat odkaz na příklad, ale zápisek už jsem uložil. (To byl vtip, ve skutečnosti jsem chtěl přidat k zápisku přílohu dostal jsem chybovou hlášku "přístup odmítnout")
Tiskni
Sdílej:

TeX samozřejmě používám raději, mám plno svých maker pro plain (LaTeX moc nemusím). Někdy je ale lepší sáhnout po tom, co umí i kolegové, aby mohli opravovat chyby apod.
a učinil blokovým elementem. Čisté řešení je použití zanořených seznamů a element a ponechat řádkovým.
Lze to napsat jako cyklus odhadem s 15–20 řádky kódu.