KiCad je nově k dispozici také jako balíček ve formátu AppImage. Stačí jej stáhnout, nastavit právo na spouštění a spustit [Mastodon, 𝕏].
Šenčenská firma Seeed Studio představila projekt levného robotického ramena reBot Arm B601, primárně coby pomůcky pro studenty a výzkumníky. Paže má 6 stupňů volnosti, dosah 650 mm a nosnost 1,5 kilogramu, podporované platformy mají být ROS1, ROS2, LeRobot, Pinocchio a Isaac Sim, krom toho bude k dispozici vlastní SDK napsané v Pythonu. Kompletní seznam součástek, videonávody a nejspíš i cena budou zveřejněny až koncem tohoto měsíce.
… více »Byla vydána nová verze 36.0, tj. první stabilní verze nové řady 36, svobodného multimediálního centra MythTV (Wikipedie). Přehled novinek a vylepšení v poznámkách k vydání.
Byl vydán LineageOS 23.2 (Mastodon). LineageOS (Wikipedie) je svobodný operační systém pro chytré telefony, tablety a set-top boxy založený na Androidu. Jedná se o nástupce CyanogenModu.
Od března budou mít uživatelé Discordu bez ověření věku pouze minimální práva vhodná pro teenagery.
Evropská komise (EK) předběžně shledala čínskou sociální síť pro sdílení krátkých videí TikTok návykovým designem v rozporu s unijním nařízením o digitálních službách (DSA). Komise, která je exekutivním orgánem Evropské unie a má rozsáhlé pravomoci, o tom informovala v tiskovém sdělení. TikTok v reakci uvedl, že EK o platformě vykreslila podle něj zcela nepravdivý obraz, a proto se bude bránit.… více »
Offpunk byl vydán ve verzi 3.0. Jedná se o webový prohlížeč běžící v terminálu a podporující také protokoly Gemini, Gopher a RSS. Přibyl nástroj xkcdpunk pro zobrazení XKCD v terminálu.
Promethee je projekt, který implementuje UEFI (Unified Extensible Firmware Interface) bindingy pro JavaScript. Z bootovacího média načítá a spouští soubor 'script.js', který může používat UEFI služby. Cílem je vytvořit zavaděč, který lze přizpůsobit pomocí HTML/CSS/JS. Repozitář se zdrojovými kódy je na Codebergu.
Zpráva Justičního výboru Sněmovny reprezentantů upozorňuje na cenzurní kampaň Evropské komise, mířenou proti svobodě projevu na sociálních sítích. V dokumentu se uvádí, že se Evropská komise během posledních šesti let účastnila více než 100 uzavřených jednání, během nichž po platformách požadovala úpravy pravidel moderování obsahu, přičemž toto úsilí Komise zahrnovalo i cenzuru politických názorů a pravdivých informací. Výbor zdůrazňuje, že tento přístup Bruselu ohrožuje ústavou zaručená práva Američanů na svobodu projevu.
Linus Torvalds vydal jádro Linux 6.19. Podrobný výčet změn je ke zhlédnutí na stránce Kernel Newbies, stručné výběry v LWN (část první, druhá).
-felide-constructors, resp. -fno-elide-constructors, při -O2 zapnuto, při -O0 asi vypnuto. U Visual C++ se to jmenuje NRVO (named return value optimization), googli NRVO - dostaneš odkazy na hezké články, a při debug buildu (=neoptimalizovaném) je vypnuta, a při release buildu (=/O1 nebo /O2) je zapnutá. Btw. taky mě to překvapilo, když jsem si s tím po příslušné přednášce z C++ hrál. Takže přelož s -fno-elide-constructors a vypíše ti to to, co čekáš.
vim ~/.emacs
V C++ ABI je popsáno, že návratová hodnota do určité velikosti (tuším 4 bajty) se předává v registru, jinak volající kód nechá na zásobníku místo pro uložení návratové hodnoty; takže volaná funkce s tím muže počítat a výsledek ukládat rovnou do místa pro návratový kód určený. Kdybys měl v tmpPokus() dvě instance a nějakou podmínkou (předem nevyoptimalizovatelnou) se rozhodoval, kterou vrátit, pak by se kopírovací konstruktor zavolal. (Pozn. to C++ ABI jsem někde vygooglil, už nevím pro jakou platformu to konkrétně bylo, na některých platformách záleží na překladači; tipuju ale, že pro x86/x64 to platit bude.)
Pokud nechceš, aby při předání parametru metodě print() nebyl volán kopírovací konstruktor, zkus parametr předávat referencí: void print(const pokus &p) { ... }. To const tam teda být nemusí, ale mělo by, pokud je to možné (je to dobrý zvyk).
návratová hodnota do určité velikosti (tuším 4 bajty) se předává v registruJen pokud to není typ s uživatelským copy-constructorem nebo destruktorem. Pro takový by to nešlo implementovat.
pokus ob(tmpPokus());
alebo
pokus ob = tmpPokus();
Pls. preco sa pri navrate z funkcie pokus tmpPokus() nezavola kopirovaci konstruktor pokus::pokus(const pokus &p) ? Dakujemsom mal na mysli volanie
pokus ob = tmpPokus()ob : konkretne vyraz ob = tmpPokus(); kde ob je uz zinicializovany objekt...sorry za omyl
Tiskni
Sdílej: