Canonical pro své zákazníky, předplatitele Ubuntu Pro, prodloužil podporu Ubuntu LTS z 12 let na 15 let (Legacy add-on). Týká se verzí od 14.04 (Trusty Tahr).
Homebrew (Wikipedie), správce balíčků pro macOS a od verze 2.0.0 také pro Linux, byl vydán ve verzi 5.0.0. Nově je oficiálně podporován Linux ARM64/AArch64. Na stránce Homebrew Formulae lze procházet seznamem balíčků. K dispozici jsou také různé statistiky.
Byla vydána verze 10 dnes již multiplatformního open source frameworku .NET (Wikipedie). Přehled novinek v příspěvku na blogu Microsoftu. Další informace v poznámkách k vydání na GitHubu nebo v přednáškách na právě probíhající konferenci .NET Conf 2025.
Rodina hardwaru služby Steam se začátkem roku 2026 rozroste. Steam Deck doplní nový Steam Controller, herní PC Steam Machine se SteamOS s KDE Plasmou a bezdrátový VR headset s vlastními ovladači Steam Frame.
Amazon Web Services (AWS) oznámil (en) výstavbu Fastnetu – strategického transatlantického optického kabelu, který propojí americký stát Maryland s irským hrabstvím Cork a zajistí rychlý a spolehlivý přenos cloudových služeb a AI přes Atlantik. Fastnet je odpovědí na rostoucí poptávku po rychlém a spolehlivém přenosu dat mezi kontinenty. Systém byl navržen s ohledem na rostoucí provoz související s rozvojem umělé inteligence a
… více »Evropská komise zkoumá možnosti, jak přinutit členské státy Evropské unie, aby ze svých telekomunikačních sítí postupně vyloučily čínské dodavatele Huawei a ZTE. Místopředsedkyně EK Henna Virkkunenová chce změnit doporučení nepoužívat rizikové dodavatele při budování mobilních sítí z roku 2020 v právně závazný požadavek.
sudo-rs, tj. sudo a su přepsané do programovacího jazyka Rust, již obsaženo v Ubuntu 25.10, bylo vydáno ve verzi 0.2.10. Opraveny jsou 2 bezpečnostní chyby.
Kaspersky pro Linux je nově k dispozici také pro domácí uživatele.
Společnost Avalonia UI oznámila, že pracuje na .NET MAUI pro Linux a webový prohlížeč. Vyzkoušet lze demo v prohlížeči. Když bude backend stabilní, bude vydán jako open source pod licencí MIT.
Byl vydán Mozilla Firefox 145.0. Přehled novinek v poznámkách k vydání a poznámkách k vydání pro vývojáře. Ukončena byla podpora 32bitového Firefoxu pro Linux. Přidána byla podpora Matrosky. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 145 bude brzy k dispozici také na Flathubu a Snapcraftu.
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";
}
};
Tiskni
Sdílej: