Administrativa amerického prezidenta Donalda Trumpa by měla dostat zhruba deset miliard dolarů (asi 214 miliard Kč) za zprostředkování dohody o převzetí kontroly nad aktivitami sociální sítě TikTok ve Spojených státech.
Projekt Debian aktualizoval obrazy stabilní větve „Trixie“ (13.4). Shrnuje opravy za poslední dva měsíce, 111 aktualizovaných balíčků a 67 bezpečnostních hlášení. Opravy se týkají mj. chyb v glibc nebo webovém serveru Apache.
Agent umělé inteligence Claude Opus ignoroval uživatelovu odpověď 'ne' na dotaz, zda má implementovat změny kódu, a přesto se pokusil změny provést. Agent si odpověď 'ne' vysvětlil následovně: Uživatel na mou otázku 'Mám to implementovat?' odpověděl 'ne' - ale když se podívám na kontext, myslím, že tím 'ne' odpovídá na to, abych žádal o svolení, tedy myslí 'prostě to udělej, přestaň se ptát'.
Po 8. květnu 2026 už na Instagramu nebudou podporované zprávy opatřené koncovým šifrováním. V chatech, kterých se bude změna týkat, se objeví pokyny o tom, jak si média nebo zprávy z nich stáhnout, pokud si je chcete ponechat.
V lednu byla ve veřejné betě obnovena sociální síť Digg (Wikipedie). Dnes bylo oznámeno její ukončení (Hard Reset). Společnost Digg propouští velkou část týmu a přiznává, že se nepodařilo najít správné místo na trhu. Důvody jsou masivní problém s boty a silná konkurence. Společnost Digg nekončí, malý tým pokračuje v práci na zcela novém přístupu. Cílem je vybudovat platformu, kde lze důvěřovat obsahu i lidem za ním. Od dubna se do Diggu na plný úvazek vrací Kevin Rose, zakladatel Diggu z roku 2004.
MALUS je kontroverzní proprietarní nástroj, který svým zákazníkům umožňuje nechat AI, která dle tvrzení provozovatelů nikdy neviděla původní zdrojový kód, analyzovat dokumentaci, API a veřejná rozhraní jakéhokoliv open-source projektu a následně úplně od píky vygenerovat funkčně ekvivalentní software, ovšem pod libovolnou licencí.
Příspěvek na blogu Ubuntu upozorňuje na několik zranitelností v rozšíření Linuxu o mandatorní řízení přístupu AppArmor. Společně jsou označovány jako CrackArmor. Objevila je společnost Qualys (technické detaily). Neprivilegovaný lokální uživatel se může stát rootem. Chyba existuje od roku 2017. Doporučuje se okamžitá aktualizace. Problém se týká Ubuntu, Debianu nebo SUSE. Red Hat nebo Fedora pro mandatorní řízení přístupu používají SELinux.
Byla vydána nová verze 19 integrovaného vývojového prostředí (IDE) Qt Creator. Podrobný přehled novinek v changelogu.
Bitwig Studio (Wikipedie) bylo vydáno ve verzi 6. Jedná se o proprietární multiplatformní (macOS, Windows, Linux) digitální pracovní stanici pro práci s audiem (DAW).
Společnost Igalia představila novou linuxovou distribuci (framework) s názvem Moonforge. Jedná se o distribuci určenou pro vestavěné systémy. Vychází z projektů Yocto a OpenEmbedded.
V tomto seriálu bych rád nastínil, jak lze vytvořit jednodušší i složitější Plasma applet v jazyce C++ (lze využít i jiné programovací jazyky jako Python, JavaScript, Ruby apod.). K tomu se nám občas budou hodit i nějaké ty znalosti Qt, takže místy budu odkazovat na články o programování v Qt 4 od Davida Watzkeho.
Při vývoji plasmoidů se vám určitě může hodit API dokumentace.
Plasmoidy lze používat (tvořit je můžete, v čem chcete, nemusíte ani v Linuxu) pouze v KDE 4, ale kvůli rychlému vývoji a změnám v API se stává, že starší Plasmoidy v nových verzích KDE nefungují. V tomto seriálu budu používat API z aktuální stabilní řady, tedy KDE 4.3.
Každý applet musí mít minimálně tři soubory: zdrojový kód (.cpp), hlavičkový soubor (.h) a soubor .desktop. Poslední z uvedených obsahuje informace o jménu plasmoidu, jeho typu, verzi, autorovi, licenci atd. a využívá ho KDE pro registraci do seznamu widgetů.
Na začátek vytvoříme jednoduchý applet, který zobrazí aktuální verzi KDE, jež používáte. Není to nijak užitečné, ale ukážeme si na tom, jaké metody musí každý plasmoid implementovat a jak se takový plasmoid překládá a instaluje do systému. Plasmoid nenačítá verzi KDE dynamicky při spuštění, ale verze se do něj zapíše při kompilaci.
kde_version.h
#ifndef KDE_VERSIONH
#define KDE_VERSIONH
//Základní hlavička Plasmy
#include <Plasma/Applet>
//KDE implementace QIcon
#include <KIcon>
class kdeVersionPlasmoid: public Plasma::Applet
{
Q_OBJECT
public:
kdeVersionPlasmoid(QObject *parent, const QVariantList &args);
~kdeVersionPlasmoid() {};
void init();
void paintInterface(QPainter *painter, const QStyleOptionGraphicsItem *option, const QRect& contentsRect);
private:
KIcon p_icon;
QString kdeVer;
};
K_EXPORT_PLASMA_APPLET(kdeVersion, kdeVersionPlasmoid);
#endif
Kromě konstruktoru a destruktoru musí třída appletu mít i metody init() a paintInterface(). V konstruktoru se pouze nastaví výchozí velikost, pozadí atd., další záležitosti jako načítání konfigurace a podobně se provádějí právě v metodě init(). Metoda paintInterface() obstará základní vytvoření grafického rozhraní.
Důležité je také makro K_EXPORT_PLASMA_APPLET, které propojí třídu appletu se souborem .desktop. Prvním parametrem je název appletu v souboru .desktop (viz níže), druhým parametrem je název třídy appletu.
kde_version.cpp
#include <kde_version.h>
#include <Plasma/Theme>
#include <QPainter>
kdeVersionPlasmoid::kdeVersionPlasmoid(QObject *parent, const QVariantList &args): Plasma::Applet(parent, args)
{
// Nastavi ikonu plasmoidu
p_icon = KIcon("kde");
// Automaticky vykreslí výchozí pozadí plasmoidu
setBackgroundHints(DefaultBackground);
}
void kdeVersionPlasmoid::init()
{
// Načte verzi KDE
kdeVer = KDE_VERSION_STRING;
// Pokud nebylo nic načteno, nastaví chybné spuštění
if (kdeVer.isEmpty()) {
setFailedToLaunch(true,tr("Can't detect KDE version"));
}
}
void kdeVersionPlasmoid::paintInterface(QPainter *painter,
const QStyleOptionGraphicsItem *option,
const QRect &contentsRect)
{
Q_UNUSED(option);
// Umístí text na widget
painter->setPen(Qt::white);
painter->drawText(contentsRect,
Qt::AlignCenter | Qt::AlignHCenter,
kdeVer);
painter->restore();
}
#include "kde_version.moc"
Zde stojí za zmínku metoda setBackgroundHints(DefaultBackground), která zajistí, že se pod plasmoidem automaticky vykreslí pozadí. Další zajímavá metoda je setFailedToLaunch(bool failed,QString reason). Pokud z nějakého důvodu nelze applet správně spustit (třeba je poškozený konfigurační soubor nebo nelze získat nějaké informace – jako v našem případě informaci o verzi KDE), informujeme Plasmu, že widget nelze spustit a druhým parametrem předáme stručný popis proč. Applet pak může vypadat například takto:

plasma-kde-version-applet.desktop
[Desktop Entry] Name=KDE Version Comment=KDE Version applet ServiceTypes=Plasma/Applet Type=Service X-KDE-Library=plasma_kde_version_applet X-KDE-PluginInfo-Author=Dan Vratil X-KDE-PluginInfo-Email=vratil@progdansoft.com X-KDE-PluginInfo-Name=plasma_kde_version_applet X-KDE-PluginInfo-Version=0.1 X-KDE-PluginInfo-Website=http://www.abclinuxu.cz X-KDE-PluginInfo-Category=Example X-KDE-PluginInfo-Depends= X-KDE-PluginInfo-License=GPL X-KDE-PluginInfo-EnabledByDefault=true
ServiceTypes a Type určují, o jaký typ plasmoidu se jedná. X-KDE-PluginInfo-Category definuje skupinu, do které daný applet nejlépe zapadá. V našem případě jde o Example (příklad). Seznam všech kategorií naleznete v PluginInfo Guide. Zbylé položky jsou volitelné a jde jen o rozšiřující volby.
Když už máme vše připravené, můžeme plasmoid konečně zkompilovat. Zde se vyplatí použít CMake, protože konfigurace je jednoduchá a usnadní nám dost práce.
# Název projektu
project(kdeVersionPlasmoid)
# Závislosti
find_package(KDE4 REQUIRED)
include(KDE4Defaults)
add_definitions (${QT_DEFINITIONS} ${KDE4_DEFINITIONS})
include_directories(
${CMAKE_SOURCE_DIR}
${CMAKE_BINARY_DIR}
${KDE4_INCLUDES}
)
# Přidá zdrojové kódy
set(kdeVersionPlasmoid_SRCS kde_version.cpp)
# Zaregistruje plugin do KDE
kde4_add_plugin(plasma_kde_version_applet ${kdeVersionPlasmoid_SRCS})
target_link_libraries(plasma_kde_version_applet
${KDE4_PLASMA_LIBS} ${KDE4_KDEUI_LIBS})
# Nainstaluje knihovnu
install(TARGETS plasma_kde_version_applet
DESTINATION ${PLUGIN_INSTALL_DIR})
# Nainstaluje .desktop soubor
install(FILES plasma-kde-version-applet.desktop
DESTINATION ${SERVICES_INSTALL_DIR})
Nyní příkazem cmake vytvoříme Makefile a poté pomocí make a make install applet zkompilujeme a nainstalujeme do systému.
Pozn: CMake standardně nastavuje jako INSTALL_PREFIX složku /usr/local. Některé distribuce jako například Arch Linux mají KDE nainstalované v /usr. Do příkazu CMake se pak musí přidat přepínač -DCMAKE_INSTALL_PREFIX=/usr.
Plasmoid je nyní nainstalovaný v systému. Jenže aby se o něm KDE dozvědělo, potřebuje znovu načíst všechny soubory .desktop, což znamená odhlásit a znovu se přihlásit do KDE. To pro testování není zrovna ideální, proto máme šikovný prográmek plasmoidviewer. Jako parametr zadáme název našeho plasmoidu tak, jak jsme ho pojmenovali v X-KDE-PluginInfo-Name v souboru .desktop.
plasmoidviewer plasma_kde_version_applet

Pokud chcete, aby se náš nový plasmoid objevil ve správci appletů, musíte se buď znovu přihlásit, nebo spustit:
kbuildsycoca4 kquitapp plasma-desktop kstart plasma-desktop
To je dnes vše, příště se podíváme, jak vytvořit nějaký interaktivní plasmoid, a jak je to s plasmoidy v panelu.
Ná konec ještě přikládám archiv se zdrojovými kódy dnešního plasmoidu.
Nástroje: Tisk bez diskuse
Tiskni
Sdílej:
"Brno" nebo "Brno at 12:00".
Teď na tom na tom nemám moc čas dělat, o svátcích přidám nové featurky :)
"from A to B" (taková variace na krunner).http://vlak.cz něco takového poskytuje.
.
Nebo podrobnosti na chaps.cz http://chaps.cz/idos-moznost-vyuziti-odkazu.aspTo je jen předvyplnění formuláře na idos.cz (místo kterého používám vlak.cz), takže nic zajímavého.
Plasmoid je nyní nainstalovaný v systému. Jenže aby se o něm KDE dozvědělo, potřebuje znovu načíst všechny soubory .desktop, což znamená odhlásit a znovu se přihlásit do KDE. To pro testování není zrovna ideálníStačí jen restartovat plasmu
kbuildsycoca4 kquitapp plasma-desktop; sleep 3; plasma-desktopNa kompilaci a instalaci používám:
mkdir build cd build cmake -DCMAKE_INSTALL_PREFIX=`kde4-config --prefix` .. make sudo make install
O plasmoidy v Javě (nebo ještě hůře v .NETu) bych opravdu nestál...
.plasmoid, které není třeba kompilovat, prostě se do plasmy přidají příkazem plasmapkg a lze je ihned používat? Příklad.
<div style="float: right"><input type="button" value="Rozbalit"></div>Proč se to zobrazuje i když dám "Zobrazit kód". V IE8 to funguje a ve WebKitu ne? Hmm.
Mozilla/5.0 (SymbianOS/9.2; U; Series60/3.1 NokiaN82/31.0.016; Profile/MIDP-2.0 Configuration/CLDC-1.1 ) AppleWebKit/413 (KHTML, like Gecko) Safari/413