V Amsterdamu probíhá Blender Conference 2025. Videozáznamy přednášek lze zhlédnout na YouTube. V úvodní keynote Ton Roosendaal oznámil, že k 1. lednu 2026 skončí jako chairman a CEO Blender Foundation. Tyto role převezme současný COO Blender Foundation Francesco Siddi.
The Document Foundation, organizace zastřešující projekt LibreOffice a další aktivity, zveřejnila výroční zprávu za rok 2024.
Byla vydána nová stabilní verze 7.6 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 140. Přehled novinek i s náhledy v příspěvku na blogu.
Byla vydána verze 1.90.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.
GNUnet (Wikipedie) byl vydán v nové major verzi 0.25.0. Jedná se o framework pro decentralizované peer-to-peer síťování, na kterém je postavena řada aplikací.
Byla vydána nová major verze 7.0 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Nově je postavena je na Debianu 13 (Trixie) a GNOME 48 (Bengaluru). Další novinky v příslušném seznamu.
Společnost Meta na dvoudenní konferenci Meta Connect 2025 představuje své novinky. První den byly představeny nové AI brýle: Ray-Ban Meta (Gen 2), sportovní Oakley Meta Vanguard a především Meta Ray-Ban Display s integrovaným displejem a EMG náramkem pro ovládání.
Po půl roce vývoje od vydání verze 48 bylo vydáno GNOME 49 s kódovým názvem Brescia (Mastodon). S přehrávačem videí Showtime místo Totemu a prohlížečem dokumentů Papers místo Evince. Podrobný přehled novinek i s náhledy v poznámkách k vydání a v novinkách pro vývojáře.
Open source softwarový stack ROCm (Wikipedie) pro vývoj AI a HPC na GPU od AMD byl vydán ve verzi 7.0.0. Přidána byla podpora AMD Instinct MI355X a MI350X.
Byla vydána nová verze 258 správce systému a služeb systemd (GitHub).
#include <iostream> #include <vector> #include <algorithm> #include "Rational" using namespace std; int main() { vector<XMath::Rational<int> > cisla; vector<XMath::Rational<int> >::const_iterator ci; cisla.push_back(XMath::Rational<int>(2, 3)); cisla.push_back(XMath::Rational<int>(3, 4)); cisla.push_back(XMath::Rational<int>(1, 2)); cisla.push_back(XMath::Rational<int>(4, 5)); cout << "Čísla na začátku" << endl; for (ci = cisla.begin(); ci != cisla.end(); ++ci) { cout << *ci << endl; } sort(cisla.begin(), cisla.end()); cout << "Čísla na konci" << endl; for (ci = cisla.begin(); ci != cisla.end(); ++ci) { cout << *ci << endl; } return 0; }Sestupné třídění obstará funkce
sort
. Stačí zadat iterátory ukazující na začátek a konec seznamu, třídění se potom provede jakoby zázračně samo. Pokud nejsou použity vestavěné číselné typy, je potřeba napsat přetížené operátory porovnání.
Pro přeložení jsou potřeba dva hlavičkové soubory se šablonami, které jsou k dispozici tady.
Třídit lze i jinak – man qsort
. Často je zbytečné se namáhat s psaním třídicího kódu a postačují funkce z knihovny C nebo STL.
/** * 1. Dedit od konkretnich typu (std::vector<FileInfo*>) se moc nedoporucuje. * Akorat tam podivne redeklarujete stadardni metody - docela bych chtel * videt jejich definice. * * 2. Pokud chcete kontrolu pod g++/libstdc++ pouzijte * * g++ -D _GLIBCXX_CONCEPT_CHECKS -D _GLIBCXX_DEBUG -o file.o file.cc * * a nemusite sasit s at. Plus vam to ohlida spoustu dalsich veci. * * 3. Nasledujici kod jsem netestoval. * */ #include <vector> #include <algorithm> #include "FileInfo.h" bool lt_file_info(const FileInfo* f1, const FileInfo* f2) { if( f1->isDots() != f2->isDots() ) return f1->isDots() < f2->isDots(); if( f1->isDir() != f2->isDir() ) return f1->isDir() < f2->isDir(); // zjistete si, co tahle funkce vraci a podle toho se // zaridte (a co prebira - podle deklarace, kterou jste // uvedl, gchar, ale getName vraci std::string) return g_utf8_collate(f1->getName(), f2->getName()); } void test() { std::vector<FileInfo*> file_list; std::sort(file_list.begin(), file_list.end(), lt_file_info); }
qsort
ze stdlib.h
se taky použít nedá. Asi si budu muset napsat nejakej ten quicksort sám.
tím ukazatelem na fci by nebyl problém, deklaroval bych jí jako static, problém by byl, že bych pak neměl ukazatel this a pak bych stejně nezjistil, dle čeho řadit.Omlouvám se že vám do toho lezu jako člověk co se s C++ rozloučil dávno před STL... ale podle dokumentace ten třetí parametr metody sort není funkce, ale functor (tedy objekt)! Tedy stačí udělat objekt jako potomek
binary_function
, kterů bude třídit podle toho co je potřeba.
Něco je o tom psáno zde, i s příklady.
Pro jine pripady (razeni podle data) samozrejme nadefinujete jinou porovnavaci funkci a budete volat sort s jinou porovnavaci funkci. Taky muzete udelat malou hirearchii trid s virtualnim 'operator<'. Jak je ctena libost. Ale nechapu, proc si chcete vyrabet svuj vlastni sort - tim si akorat pridelate praci a nadefinovani vsech porovnani se stejne nevyhnete.
Tiskni
Sdílej: