Eric Lengyel dobrovolně uvolnil jako volné dílo svůj patentovaný algoritmus Slug. Algoritmus vykresluje text a vektorovou grafiku na GPU přímo z dat Bézierových křivek, aniž by využíval texturové mapy obsahující jakékoli předem vypočítané nebo uložené obrázky a počítá přesné pokrytí pro ostré a škálovatelné zobrazení písma, referenční ukázka implementace v HLSL shaderech je na GitHubu. Slug je volným dílem od 17. března letošního
… více »Sashiko (GitHub) je open source automatizovaný systém pro revizi kódu linuxového jádra. Monitoruje veřejné mailing listy a hodnotí navrhované změny pomocí umělé inteligence. Výpočetní zdroje a LLM tokeny poskytuje Google.
Cambalache, tj. RAD (rapid application development) nástroj pro GTK 4 a GTK 3, dospěl po pěti letech vývoje do verze 1.0. Instalovat jej lze i z Flathubu.
KiCad (Wikipedie), sada svobodných softwarových nástrojů pro počítačový návrh elektronických zařízení (EDA), byl vydán v nové major verzi 10.0.0 (𝕏). Přehled novinek v příspěvku na blogu.
Letošní Turingovou cenu (2025 ACM A.M. Turing Award, Nobelova cena informatiky) získali Charles H. Bennett a Gilles Brassard za základní přínosy do oboru kvantové informatiky, které převrátily pojetí bezpečné neprolomitelné komunikace a výpočetní techniky. Jejich protokol BB84 z roku 1984 umožnil fyzikálně zaručený bezpečný přenos šifrovacích klíčů, zatímco jejich práce o kvantové teleportaci položila teoretické základy pro budoucí kvantový internet. Jejich práce spojila fyziku s informatikou a ovlivnila celou generaci vědců.
Firefox 149 dostupný od 24. března přinese bezplatnou vestavěnou VPN s 50 GB přenesených dat měsíčně (s CZ a SK se zatím nepočítá) a zobrazení dvou webových stránek vedle sebe v jednom panelu (split view). Firefox Labs 149 umožní přidat poznámky k panelům (tab notes, videoukázka).
Byla vydána nová stabilní verze 7.9 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 146. Přehled novinek i s náhledy v příspěvku na blogu.
Dle plánu byla vydána Opera GX pro Linux. Ke stažení je .deb i .rpm. V plánu je flatpak. Opera GX je webový prohlížeč zaměřený na hráče počítačových her.
GNUnet (Wikipedie) byl vydán v nové major verzi 0.27.0. Jedná se o framework pro decentralizované peer-to-peer síťování, na kterém je postavena řada aplikací.
Byly publikovány informace (technické detaily) o bezpečnostním problému Snapu. Jedná se o CVE-2026-3888. Neprivilegovaný lokální uživatel může s využitím snap-confine a systemd-tmpfiles získat práva roota.
Snazim se v jednom Qt projektu vylepsit system callbacku. Callback v sobe ma pointer na objekt, na kterym se ma provest a nazev funkce, ktera se ma spustit. Pouzivam QMetaObject::invokeMethod a tim padem je to zavisle na MOC a funkce musi byt bud slot nebo Q_INVOKABLE.
Dostal jsem napad, jak se toho zbavit.
Kod je zde
#include <typeinfo>
#include <typeindex>
class functor
{
public:
template <typename A, typename... Ts> inline functor(A *o, void (A::*f)(Ts... args))
{
avec.insert(avec.end(), {typeid(Ts)...});
obj = o;
func = reinterpret_cast< void (functor::*)() >(f);
}
template <typename... Ts> inline void operator()(Ts... args)
{
std::vector<std::type_index> vec; // argumenty volani
vec.insert(vec.end(), {typeid(Ts)...});
if(avec == vec)
{
void (functor::*f)(Ts ...) = reinterpret_cast<void (functor::*)(Ts ...)>(func);
(reinterpret_cast<functor*>(obj)->*f)(args ...);
}
else
qDebug() << "functor invoked with bad arguments";
}
private:
void (functor::*func)();
void *obj;
std::vector<std::type_index> avec; // argumenty callbacku
};
Pouziti je jednoduchy, viz priklad. Vyhoda oproti jinym podobnym vecem je v tom, ze kontrola typu argumentu se deje v runtime a tim padem muzou mit vsechny callbacky jeden typ (i kdyz volaji funkce s ruznyma argumentama).
base *t = new base(); functor f(t, &base::torture); // vytvorim callback f(); // zavolam ho
Rad bych od vas dostal nazor, jestli je to dobry napad, nebo neni, a proc (pripadne jestli nekde neumiraji kotatka kdyz delam reinterpret_cast).
Tiskni
Sdílej:
A *o na *functor, možná to jen nechápu...
struct { size_t a; size_t b; };
Nejspíš by se i našel způsob, jak během compile-time zjistit, jestli ten member func pointer není větší...
operator (), protože tam se to castuje na jiný typ, než který byl uložený, a každý může mít jinak velké member pointery.
#ifndef NDEBUG ... #endif)
at je hází úmyslně, neházející verze je operator [].
GCC má debug verzi STL, která asserty obsahuje.
typeid(void(Ts...)) nebo neco podobneho.
template <typename ReturnT, typename... ParamTs>
class Callback
{
protected:
struct Iface
{
virtual ~Iface() {}
virtual ReturnT operator ()(ParamTs... params) = 0;
};
template <typename Type>
struct Impl
: public Iface
{
using Func = ReturnT (Type::*)(ParamTs...);
Impl(Type &obj, Func func)
: obj(obj)
, func(func)
{}
virtual ~Impl() {}
virtual ReturnT operator ()(ParamTs... params)
{
return std::forward<ReturnT>(obj.*func(std::forward<ParamTs...>(params)));
}
Type &obj;
Func func;
};
Iface& iface()
{
return *reinterpret_cast<Iface*>(buf);
}
size_t buf[4];
public:
template <typename Type>
Callback(Type &obj,
typename Impl<Type>::Func func)
{
// Místo static_assert lze upravit, aby to použilo new
static_assert(sizeof(Impl<Type>) <= sizeof(buf), "Buffer not large enough to capture callback");
new (buf) Impl<Type>(obj, func);
}
~Callback()
{
iface().~Iface();
}
ReturnT operator ()(ParamTs... params)
{
return std::forward<ReturnT>(iface()(std::forward<ParamTs...>(params)));
}
};
Callback callback(t, &Type::getValueForInput);
int value = callback(input);
std::forward na návratové hodnoty je zbytečný, navíc nebude fungovat s void.
virtual ReturnT operator ()(ParamTs... params) a virtual ~Impl() v Impl by bylo lepší označit override.
Callback templatová třída, pak se rovnou může použít std::function, ne?
operator ()) by šlo zabalit přes reinterpret_cast, protože není polymorfní (takže je to jen pointer na funkci, kde první parametr je this), ale nebude to ověřovat typy parametrů.
Ten reinterpret_cast v původní implementaci nebude fungovat, pokud bude castovat z polymorfní třídy na nepolymorfní či obráceně, a nejspíš ani pokud bude mezi různými stromy polymorfních tříd, protože u virtuálních metod je to typicky implementováno jako index do vtable, nikoliv pointer.
class functor
{
protected:
struct iface { virtual ~iface(){}; };
template <typename... Ts> struct args : public iface
{
virtual void call(Ts...) = 0;
};
template <typename A, typename... Ts> struct impl : public args<Ts...>
{
A* obj;
void (A::*func)(Ts...);
impl(A* o, void (A::*f)(Ts...)) : obj(o), func(f) {}
void call(Ts... args)
{
(obj->*func)(args...);
}
};
size_t i[4];
public:
template<typename A, typename... Ts> functor(A* o, void (A::*f)(Ts...))
{
static_assert(sizeof(impl<A, Ts...>) <= sizeof(i), "Buffer not large enough to capture callback");
new (i) impl<A, Ts...>(o,f);
}
template<typename... Ts> void operator()(Ts... params)
{
args<Ts...> *a = dynamic_cast<args<Ts...>*>(reinterpret_cast<iface*>(i));
if(a) a->call(params...);
else qDebug() << "bad parameters";
}
};