Společnost Espressif (ESP8266, ESP32, …) získala většinový podíl ve společnosti M5Stack, čímž posiluje ekosystém AIoT.
Byla vydána nová stabilní verze 3.5 svobodného multiplatformního softwaru pro editování a nahrávání zvukových souborů Audacity (Wikipedie). Přehled novinek také na YouTube. Nově lze využívat cloud (audio.com). Ke stažení je oficiální AppImage. Zatím starší verze Audacity lze instalovat také z Flathubu a Snapcraftu.
50 let operačního systému CP/M, článek na webu Computer History Museum věnovaný operačnímu systému CP/M. Gary Kildall z Digital Research jej vytvořil v roce 1974.
Byl zveřejněn program a spuštěna registrace na letošní konferenci Prague PostgreSQL Developer Day, která se koná 4. a 5. června. Na programu jsou 4 workshopy a 8 přednášek na různá témata o PostgreSQL, od konfigurace a zálohování po využití pro AI a vector search. Stejně jako v předchozích letech se konference koná v prostorách FIT ČVUT v Praze.
Po 48 letech Zilog končí s výrobou 8bitového mikroprocesoru Zilog Z80 (Z84C00 Z80). Mikroprocesor byl uveden na trh v červenci 1976. Poslední objednávky jsou přijímány do 14. června [pdf].
Ještě letos vyjde Kingdom Come: Deliverance II (YouTube), pokračování počítačové hry Kingdom Come: Deliverance (Wikipedie, ProtonDB Gold).
Thunderbird 128, příští major verze naplánovaná na červenec, přijde s nativní podporou Exchange napsanou v Rustu.
Byly vyhlášeny výsledky letošní volby vedoucího projektu Debian (DPL, Wikipedie). Novým vedoucím je Andreas Tille.
Po osmi měsících vývoje byla vydána nová verze 0.12.0 programovacího jazyka Zig (GitHub, Wikipedie). Přispělo 268 vývojářů. Přehled novinek v poznámkách k vydání.
Poslední měsíc byl plný zajímavých akcí, o kterých Vám bastlíři z projektu MacGyver mohou povědět, protože se na ně sami vydali. Kde všude byli, ptáte se? Objevili se na Installfestu, Arduino Day, Hackaday Europe a tajném srazu bastlířů z Twitteru. A z každé akce pro vás mají zajímavé poznatky.
… více »$role = RoleManager::getRoleById(x); // kde x je ID role $user->addRole($role);nebo
$user->addRole(x); // kde x je ID rolea jaké z toho plynou budoucí výhody/nevýhody?
Není problém, aby tam byly obě metody, ovšem asi by se tím zkomplikovaly závislosti, protože by vás to asi svádělo k tomu, že budete ve třídě User používat RoleManager (a to si pak rovnou rozmyslete, jestli jedete podle ActiveRecord vzoru nebo jinak).Prošel jsem si PropelORM a tohle ale přesně dělá. Respektive dělá to oklikou. Tj. něco jako bych měl objekt RoleCollection a ten by se sám plnil, tj. v něm by se používalo RoleManager.
Prošel jsem si PropelORM a tohle ale přesně dělá.Ano, však PropelORM je taky podle ActiveRecord vzoru - záznamy ukládají samy sebe. Ve Vašem návrhu máte ale na ukládání Manager. Rozhodněte se pro jeden přístup a ten dodržujte. To jsem měl na mysli. Je spousta nuancí, jak komponenty skládat - pamatujte na to, že budete potřebovat nejen základní CRUD operace, ale i uživatelsky definované dotazy, stránkování a podmínky. Pak už je docela těžké, aby byly závislosti přehledné a jednotlivé komponenty třeba i nahraditelné. Dobrá otázka dále například je, zde mají být záznamy snadno automaticky serializovatelné třeba do XML nebo do JSON - a do jaké hloubky má serializace probíhat. A odlišujte, jak vypadá váš systém uvnitř a jak vypadá pro použití programátorem. Interně mohou záznamy používat nějaký Manager, ale zvenčí se třeba používají jako ActiveRecord.
... $user = new User( $userData ); $user->addresses = new ModelRelation( $this->_addressesMapper, 'getAddressesByUserId', array( $id ) ); ...V čem je horší přístup, kdyby místo výše uvedeného bylo použito toto?
... $user = new User( $userData ); $user->addresses = new UserAddressList(); ...Samozřejmě ta instance UserAddressList by se dělala přímo v User automaticky při prvním dotazu typu getAddresses(). UserAddressList by byla speciálně třída pro tuto funkci a ta by si sama získávala instanci Managera.
Tiskni Sdílej: