Desktopové prostředí KDE Plasma bylo vydáno ve verzi 6.5 (Mastodon). Přehled novinek i s videi a se snímky obrazovek v oficiálním oznámení. Podrobný přehled v seznamu změn.
Rodina jednodeskových počítačů Orange Pi se rozrostla (𝕏) o Orange Pi 6 Plus.
Na Humble Bundle běží akce Humble Tech Book Bundle: All Things Raspberry Pi by Raspberry Pi Press. Se slevou lze koupit elektronické knihy od nakladatelství Raspberry Pi Press a podpořit Raspberry Pi Press, Raspberry Pi Foundation North America nebo Humble.
Přidaný režim autonomního řízení vozidel Tesla Mad Max je dostupný pro vybrané zákazníky v programu EAP (Early Access Program). Nový režim je na silnici agresivnější, častěji mění pruhy a ne vždy dodržuje rychlostní limity. Agentura JPP spekuluje, že v Česku by se mohl nový režim namísto Mad Max jmenovat Mad Turek...
Byla vydána nová verze 9.18 z Debianu vycházející linuxové distribuce DietPi pro (nejenom) jednodeskové počítače. Nově také pro NanoPi R3S, R3S LTS, R76S a M5. Přehled novinek v poznámkách k vydání.
bat, tj. vylepšený cat se zvýrazňováním syntaxe a integrací s gitem, byl vydán ve verzi 0.26.0.
Byla vydána první verze 0.0.1 [Mastodon] multipatformního renderovacího jádra webového prohlížeče Servo (Wikipedie). Vývoj Serva započal v roce 2012 v Mozilla Corporation. V roce 2020 bylo Servo předáno nadaci Linux Foundation. Servo je napsané v programovacím jazyce Rust.
Cloudovou službu Amazon Web Services (AWS) americké firmy Amazon dnes postihl globální výpadek. Omezil dostupnost řady aplikací a webů, například populární platformu Snapchat nebo aplikaci s prvky umělé inteligence (AI) Perplexity. Podle webu Downdetector hlásily problémy také uživatelé obchodu Amazon, streamovací platformy PrimeVideo nebo platební služby PayPal.
GNU Octave lze nově používat ve webovém prohlížeči v JupyterLite s jádrem Xeus-Octave.
Od 3. do 16. listopadu proběhnou Dny AI 2025. V úterý 11. listopadu proběhne Open source AI day v Red Hatu v Brně.
string_t
a string_traits
do vlastniho jmenneho prostoru. Pritom a.cpp jde zkompilovat (gcc) bez problemu, ale b.cpp skonci s chybou:
/usr/lib/gcc/3.4.4/include/c++/bits/stl_function.h: In member function `bool std::less<_Tp>::operator()(const _Tp&, const _Tp&) const [with _Tp = xxx::string_t]': b.cpp:54: instantiated from here /usr/lib/gcc/3.4.4/include/c++/bits/stl_function.h:227: error: no match for 'operator<' in '__x < __y'Zajimavy je ze yyy::less funguje ale std::less ne. Pritom jsem yyy::less vytvoril jako kopii std::less... a.cpp:
#include <boost/mpl/bool.hpp> #include <boost/utility/enable_if.hpp> #include <functional> namespace yyy { template<typename _Tp> struct less : public std::binary_function<_Tp, _Tp, bool> { bool operator()(const _Tp& __x, const _Tp& __y) const { return __x < __y; } }; } struct string_t { }; template <typename string_type_> struct string_traits; template <> struct string_traits<string_t> { typedef string_t string_type; }; template <typename A, typename B> struct both_exist: public boost::mpl::true_ {}; template <typename T, typename U> inline typename boost::enable_if < both_exist < typename string_traits<T>::string_type, typename string_traits<U>::string_type >, bool >::type operator < (const T &str1, const U &str2) { } int main() { yyy::less<string_t> cmp; std::less<string_t> cmp1; string_t a; string_t b; cmp(a, b); cmp1(a, b); }b.cpp:
#include <boost/mpl/bool.hpp> #include <boost/utility/enable_if.hpp> #include <functional> namespace yyy { template<typename _Tp> struct less : public std::binary_function<_Tp, _Tp, bool> { bool operator()(const _Tp& __x, const _Tp& __y) const { return __x < __y; } }; } namespace xxx { struct string_t { }; template <typename string_type_> struct string_traits; template <> struct string_traits<string_t> { typedef string_t string_type; }; } template <typename A, typename B> struct both_exist: public boost::mpl::true_ {}; template <typename T, typename U> inline typename boost::enable_if < both_exist < typename xxx::string_traits<T>::string_type, typename xxx::string_traits<U>::string_type >, bool >::type operator < (const T &str1, const U &str2) { } int main() { yyy::less<xxx::string_t> cmp; std::less<xxx::string_t> cmp1; xxx::string_t a; xxx::string_t b; cmp(a, b); cmp1(a, b); }
Řešení dotazu:
namespace yyy { class x; inline bool operator < (x const &a, x const &b) { } }a dela me to stejnou chybu i s yyy::less. Takze zrejme ten muj "operator <" neni pristupny v zadnym namespace kde uz existuje jiny "operator <". Nejak to nechapu... chapal bych kdyby to muj operator prekrylo vzdycky, ale proc to dela jenom kdyz je string_t a string_traits v xxx ??
operator <
presunu do xxx
tak to funguje.
Problem je (see http://en.wikipedia.org/wiki/Argument_dependent_name_lookup), ze napr pri pouziti yyy::less
, gcc nejdriv najde yyy::operator<
, potom prohleda namespacy asociovany s argumentama a najde xxx::operator<
, a root namespace uz neprohledava...
Tak nevim. Je tohle vlastnost nebo chyba ? A je teda mozny udelat operator <
, ktery by fungoval na vsechny string tridy co maji string_traits
, at uz jsou v jakymkoli jmennym prostoru ?
Co by "univerzalni" operator<
mel delat? To je problem kazde implementace stringu, aby mela i svoji definici porovnani, ktera bude ve stejnem namespacu, takze vsechno bude fungovat, jak ma.
Tiskni
Sdílej: