Kit je nový maskot webového prohlížeče Firefox.
Mastodon (Wikipedie) - sociální síť, která není na prodej - byl vydán ve verzi 4.5. Přehled novinek s náhledy v oznámení na blogu.
Německo zvažuje, že zaplatí místním telekomunikačním operátorům včetně Deutsche Telekom, aby nahradili zařízení od čínské firmy Huawei. Náklady na výměnu by mohly přesáhnout dvě miliardy eur (bezmála 49 miliard Kč). Jeden scénář počítá s tím, že vláda na tento záměr použije prostředky určené na obranu či infrastrukturu.
Po dvaceti letech skončil leader japonské SUMO (SUpport.MOzilla.org) komunity Marsf. Důvodem bylo nasazení sumobota, který nedodržuje nastavené postupy a hrubě zasahuje do překladů i archivů. Marsf zároveň zakázal použití svých příspěvků a dat k učení sumobota a AI a požádal o vyřazení svých dat ze všech učebních dat.
Úřad pro ochranu hospodářské soutěže zahajuje sektorové šetření v oblasti mobilních telekomunikačních služeb poskytovaných domácnostem v České republice. Z poznatků získaných na základě prvotní analýzy provedené ve spolupráci s Českým telekomunikačním úřadem (ČTÚ) ÚOHS zjistil, že vzájemné vztahy mezi operátory je zapotřebí detailněji prověřit kvůli možné nefunkčnosti některých aspektů konkurence na trzích, na nichž roste tržní podíl klíčových hráčů a naopak klesá význam nezávislých virtuálních operátorů.
Různé audity bezpečnostních systémů pařížského muzea Louvre odhalily závažné problémy v oblasti kybernetické bezpečnosti a tyto problémy přetrvávaly déle než deset let. Jeden z těchto auditů, který v roce 2014 provedla francouzská národní agentura pro kybernetickou bezpečnost, například ukázal, že heslo do kamerového systému muzea bylo „Louvre“. 😀
Z upstreamu GNOME Mutter byl zcela odstraněn backend X11. GNOME 50 tedy poběží už pouze nad Waylandem. Aplikace pro X11 budou využívat XWayland.
Byl publikován plán na odstranění XSLT z webových prohlížečů Chrome a Chromium. S odstraněním XSLT souhlasí také vývojáři Firefoxu a WebKit. Důvodem jsou bezpečnostní rizika a klesající využití v moderním webovém vývoji.
Desktopové prostředí LXQt (Lightweight Qt Desktop Environment, Wikipedie) vzniklé sloučením projektů Razor-qt a LXDE bylo vydáno ve verzi 2.3.0. Přehled novinek v poznámkách k vydání.
Organizace Open Container Initiative (OCI) (Wikipedie), projekt nadace Linux Foundation, vydala Runtime Specification 1.3 (pdf), tj. novou verzi specifikace kontejnerového běhového prostředí. Hlavní novinkou je podpora FreeBSD.
valgrind --tool=callgrindVysledny soubor pak otevres v KCachegrind
.
Existuje docela slušný emulátor. A kdybys do toho šel, tak se hlásím jako tester 
car::car(input *i, std::vector<_edge_> e, const char* filename, bool automatic) {
dalsi "nepeknou konstrukci" je opetovne inicializovani jiz inicializovaneho objektu dynamicky alokovanym objektem. Ano zni to hrozne a hrozne to je:
std::vector<_btRaycastVehicle_*> m_vehicle = *(new std::vector<_btRaycastVehicle_*>); ///< Physical implementation of car transformationTato konstrukce je rozhazena po mrte mistech v kodu... Dalsi problem v implementaci je s pouzitim "interfacu"
/**
* @brief The model interface
*/
class model {
public:
/**
* @brief model destructor
*/
virtual ~model() {}
int cutX, cutY; ///< Size of SS Culling
std::vector<_edge_> *edges; ///< All standalone edges of model
std::vector<_model3d_> models; ///< All parts of model
float minx, miny, minz, maxx, maxy, maxz; ///< Extremes of current model
float width, aplitude, height, size; ///< Dimensions of current model
};
1. toto neni interface, nejsou tam zadne definice metod, coz bych u interfacu cekal 2. trida obsahuje dynamicky alokovanou promenou edges, ale v destruktoru neni dealokovana, ani potomek teto tridy (modelo4s) neprovadi dealokaci. 3. k zamysleni: Musi to byt opravdu dynamicky alokovana promena? :)Ostatni interfacy krome tohoto vypadaji lepe (ale i tak obsahuji porad nejake member attributy) Dalsi mega ulet je, ze konstruktor tridy inicializuje globalni promene... Tak toto me opravdu dostalo. rekl bych ze je to zoufaly pokus o vytvoreni Singletonu?
bulletConfig bcfg = *(new bulletConfig()); ///< Configuration of physical engine
btDynamicsWorld* m_dynamicsWorld; ///< Physical implementation of scene
btDefaultCollisionConfiguration* m_collisionConfiguration;
btCollisionDispatcher* m_dispatcher;
btBroadphaseInterface* m_overlappingPairCache;
btConstraintSolver* m_constraintSolver;
....
/**
* @brief Construct physical model
* @param m is 3D model for physical model
*/
bullet::bullet(model *m) {
/// Get configuration
std::vector<_char_*> atributes = getList("BULLETCFG");
bcfg.brakeAspect = getConfig("brakeAspect", atributes);
bcfg.engineMaxSpeed = getConfig("engineMaxSpeed", atributes);
bcfg.engineSpeedMultiply = getConfig("engineSpeedMultiply", atributes);
bcfg.gasAspect = getConfig("gasAspect", atributes);
bcfg.gravitation = getConfig("gravitation", atributes);
bcfg.overSpeedBraking = getConfig("overSpeedBraking", atributes);
bcfg.rollInfluence = getConfig("rollInfluence", atributes);
bcfg.skinFriction = getConfig("skinFriction", atributes);
bcfg.speedDecrease = getConfig("speedDecrease", atributes);
bcfg.steeringAspect = getConfig("steeringAspect", atributes);
bcfg.steeringSpeedDependency = getConfig("steeringSpeedDependency", atributes);
bcfg.suspensionCompression = getConfig("suspensionCompression", atributes);
bcfg.suspensionDamping = getConfig("suspensionDamping", atributes);
bcfg.suspensionStiffness = getConfig("suspensionStiffness", atributes);
bcfg.underSpeedBraking = getConfig("underSpeedBraking", atributes);
bcfg.vehicleMassAspect = getConfig("vehicleMassAspect", atributes);
bcfg.vehicleStep = getConfig("vehicleStep", atributes);
bcfg.wheelFriction = getConfig("wheelFriction", atributes);
bcfg.worldLimit = getConfig("worldLimit", atributes);
bcfg.worldStep = getConfig("worldStep", atributes);
bcfg.worldSubStep = getConfig("worldSubStep", atributes);
locked = true;
m_collisionConfiguration = new btDefaultCollisionConfiguration();
m_dispatcher = new btCollisionDispatcher(m_collisionConfiguration);
btVector3 worldMin(-bcfg.worldLimit,-bcfg.worldLimit,-bcfg.worldLimit);
btVector3 worldMax(bcfg.worldLimit,bcfg.worldLimit,bcfg.worldLimit);
m_overlappingPairCache = new btAxisSweep3(worldMin,worldMax);
m_constraintSolver = new btSequentialImpulseConstraintSolver();
m_dynamicsWorld = new btDiscreteDynamicsWorld(m_dispatcher,m_overlappingPairCache,m_constraintSolver,m_collisionConfiguration);
m_dynamicsWorld->setGravity(btVector3(0,-bcfg.gravitation,0));
/// Create scene
addModel(m);
}
Ale ted i neco pozitivniho. Autor si s aplikaci dal opravdu hodne prace a pozitivne hodnotim, ze i pres to mracno chyb se aplikaci podari spustit.
Doporucil bych:
void renderSubModel(model* mod, model3d m);
(geometrie celého 3D světa se během vykreslování každého snímku kopírovala).
Objahoba diplomky je naštěstí až za půl roku :D spíš teď do Vánoc chci stihnout upgrade, abych neprošvih vánoční nával stahování aplikací :)
Tiskni
Sdílej: