Google oznámil, že Quick Share na Androidu funguje s AirDropem na iOS. Zatím na telefonech Pixel 10. Uživatelé tak mohou snadno přenášet soubory z telefonů s Androidem na iPhony a obráceně.
Byla vydána nová verze 8.5 (8.5.0) skriptovacího jazyka PHP používaného zejména k vývoji dynamických webových stránek. Přináší řadu novinek a vylepšení (URI Extension, Pipe Operator, Clone With, …). Vydána byla také příručka pro přechod z předchozích verzí.
Evropská komise zahájila tři vyšetřování týkající se cloudových platforem Amazon Web Services (AWS) a Microsoft Azure. Evropská exekutiva, která plní také funkci unijního antimonopolního orgánu, chce mimo jiné určit, zda jsou americké společnosti Microsoft a Amazon v cloudových službách takzvanými gatekeepery, tedy hráči, kteří významně ovlivňují provoz internetu a musí dle nařízení o digitálních trzích (DMA) na společném trhu
… více »Společnost Meta Platforms vyhrála ostře sledovaný spor o akvizici sítě pro sdílení fotografií Instagram a komunikační aplikace WhatsApp. Podle amerického soudu firma jejich převzetím neporušila antimonopolní zákon, protože si tak nemonopolizovala trh sociálních sítí. Žalobu na Metu podala před pěti lety americká Federální obchodní komise (FTC). FTC argumentovala, že Meta, tehdy známá jako Facebook, koupila tyto dvě společnosti v letech 2012 a 2014 proto, aby s nimi nemusela soutěžit.
Home Assistant včera představil svůj nejnovější oficiální hardware: Home Assistant Connect ZBT-2 pro připojení zařízení na sítích Zigbee nebo Thread.
Byla vydána verze 9.1 open source virtualizační platformy Proxmox VE (Proxmox Virtual Environment, Wikipedie) založené na Debianu. Přehled novinek v poznámkách k vydání a informačním videu.
Byl aktualizován seznam 500 nejvýkonnějších superpočítačů na světě TOP500. Nejvýkonnějším superpočítačem zůstává El Capitan od HPE (Cray) s výkonem 1,809 exaFLOPS. Druhý Frontier má výkon 1,353 exaFLOPS. Třetí Aurora má výkon 1,012 exaFLOPS. Nejvýkonnější superpočítač v Evropě JUPITER Booster s výkonem 1,000 exaFLOPS je na čtvrtém místě. Nejvýkonnější český superpočítač C24 klesl na 192. místo. Karolina, GPU partition klesla na 224. místo a Karolina, CPU partition na 450. místo. Další přehledy a statistiky na stránkách projektu.
Microsoft představil Azure Cobalt 200, tj. svůj vlastní SoC (System-on-Chip) postavený na ARM a optimalizovaný pro cloud.
Co způsobilo včerejší nejhorší výpadek Cloudflare od roku 2019? Nebyl to kybernetický útok. Vše začalo změnou oprávnění v jednom z databázových systémů a pokračovalo vygenerováním problém způsobujícího konfiguračního souboru a jeho distribucí na všechny počítače Cloudflare. Podrobně v příspěvku na blogu Cloudflare.
Byla vydána (Mastodon, 𝕏) první RC verze GIMPu 3.2. Přehled novinek v oznámení o vydání. Podrobně v souboru NEWS na GitLabu.
program-<verze>.tar.bz2, abych mohl napsat ebuildy? Teda ne že by to bez toho nešlo, ale snad chápeš - stahovalo by to ve všech verzích ebuildu furt ze stejný URL ... to není dobrý.
inotify-syscalls.h? Nikde to nemám
Tedy kromě
/300GB/distfiles/svn-src/amarok/amarok/src/inotify/inotify-syscalls.h
Ale to je můj balík vytvořený ze souborů (inotify.h a inotify-syscalls.h) stažených odsud. Upřímně řečeno, nechápu, proč to dodnes není v GNU LIBC
# g++ inotify-cxx.cpp -I. ./inotify-syscalls.h: In function ‘int inotify_init()’: ./inotify-syscalls.h:46: error: ‘int inotify_init()’ was declared ‘extern’ and later ‘static’ /usr/include/gentoo-multilib/amd64/sys/inotify.h:80: error: previous declaration of ‘int inotify_init()’ ./inotify-syscalls.h: At global scope: ./inotify-syscalls.h:51: error: ‘__u32’ has not been declared ./inotify-syscalls.h:56: error: ‘__u32’ has not been declaredDneska mám den... ale fakt v README nic není a Makefile tam taky není...
In file included from inotify-cxx.cpp:27: inotify-cxx.h:35: error: stray ‘##’ in program inotify-cxx.h:35: error: expected constructor, destructor, or type conversion before ‘<’ token inotify-cxx.h:136: error: ‘InotifyWatch’ has not been declared inotify-cxx.h:235: error: ISO C++ forbids declaration of ‘InotifyWatch’ with no type inotify-cxx.h:235: error: ‘InotifyWatch’ declared as an ‘inline’ field inotify-cxx.h:235: error: expected ‘;’ before ‘*’ token inotify-cxx.h:245: error: expected `;' before ‘static’ inotify-cxx.h:264: error: ISO C++ forbids declaration of ‘InotifyWatch’ with no type inotify-cxx.h:264: error: expected ‘;’ before ‘*’ token inotify-cxx.h: In constructor ‘InotifyEvent::InotifyEvent()’: inotify-cxx.h:125: error: ‘m_pWatch’ was not declared in this scope inotify-cxx.h: In constructor ‘InotifyEvent::InotifyEvent(const inotify_event*, int*)’: inotify-cxx.h:145: error: ‘m_pWatch’ was not declared in this scope inotify-cxx.h:148: error: ‘m_pWatch’ was not declared in this scope inotify-cxx.cpp: In member function ‘int32_t InotifyEvent::GetDescriptor() const’: inotify-cxx.cpp:40: error: ‘m_pWatch’ was not declared in this scope inotify-cxx.cpp: In member function ‘void Inotify::WaitForEvents(bool)’: inotify-cxx.cpp:261: error: no matching function for call to ‘InotifyEvent::InotifyEvent(inotify_event*&, InotifyWatch*&)’ inotify-cxx.h:136: note: candidates are: InotifyEvent::InotifyEvent(const inotify_event*, int*) inotify-cxx.h:121: note: InotifyEvent::InotifyEvent() inotify-cxx.h:115: note: InotifyEvent::InotifyEvent(const InotifyEvent&)
g++ -shared -o libinotifycxx.so inotify-cxx.cppproběhne to hladce. Jak vypadá ten tvůj inotify.h? Není v něm už totéž, co je jinak v inotify-syscalls.h? Jinak ještě technická poznámka: inotify-cxx není určeno k samostatné kompilaci. Lze z toho samozřejmě udělat malou knihovnu, ale počítal jsem především s přímým použitím (jako třeba v programu incron).
Btw. už jsi někdy slyšel o céčkové konstrukci switch ?
Hezkej wrappřík. Pár řádků kódu a jakou to udělá radostPrávě
Protože jsem nedávno takovou věc potřeboval a nikde jsem ji nenašel, bylo to nejjednodušší cesta.
Btw. už jsi někdy slyšel o céčkové konstrukci switch ?Tyhle řeči mám nejradši
Máš na mysli metody GetMaskByName() a DumpTypes()? Pak určitě víš, že std::string jaksi ve switchi nejde použít. A ve druhém případě to nejde použít proto, že se pracuje s bitovými maskami a ne s hodnotami.
U toho prvního případu jsem spíš uvažoval o použití std::map, ale nemá to příliš smysl - v celkovém výkonu by se to projevilo naprosto minimálně.
Ale ne, že by to nešlo - např. mapováním výčtového typu, ale to by asi bylo z bláta do louže.
nedari se mi zaregistrovat do bug tracking systemuV čem je problém? Teď jsem to zkoušel, funguje to.
mohl by v distribucnim archivu byt na nejvyssi urovni adresar incron-verze a az v nem samotny program?Ano, mohl, měl by, a chtěl jsem to tak udělat. Jen na to pokaždé zapomenu
Ale upravím to.
muj useradd nezna parametr -M, takze make install selze. co by to melo delat?Parametr zakáže vytvořit domovský adresář. Možná to není standardní věc, i když to v manuálu není zmíněno.
proc se vlastne vyrabi ten incron uzivatel, kdyz pak demon bezi pod rootem?Démon s tímto uživatelem nepracuje. Ten je jen pro manipulační program (incrontab). Vlastníkem tabulek je právě uživatel incron. Program incrontab má nastaveno SUID, takže uživatel získá přístup ke své tabulce. Editace ale probíhá na dočasné kopii, před spuštěním editoru se efektivní práva přepnou na reálného uživatele, aby uživatel neměl přístup k cizím tabulkám. U klasického cronu (program crontab) je to podobné, ale crontab běží pod rootem. Toto jsem nechtěl připustit, proto vytvářím speciálního uživatele.
je mozne monitorovat adresar i s podadresari?inotify toto bohužel neumožňuje. Je to dáno tím, že se monitoruje inode, takže to, co se děje někde níž, už nelze zachytit. Na úrovni incronu by to šlo emulovat sledováním každého podadresáře zvlášť, ovšem na základě jediného pravidla. Problém je ovšem s tím, že když bude sledovaných adresářů moc, narazí to na limit prostředků.
pokud pouziji pravidlo s IN_CREATE a nasledne znovu zedituji tabulku, tak incrond tise zemre. bez jakekoliv hlasky do logu/konzole.Na tohle se podívám, asi jde o nějakou chybu.
Parametr zakáže vytvořit domovský adresář. Možná to není standardní věc, i když to v manuálu není zmíněno.
useradd (z shadow 4.0.18.1) v Gentoo standardně nevytváří domovský adresář, jen s -m:
-m, --create-home create home directory for the new user account
CREATE_HOME yesTakže se adresáře standardně vytvářejí. V Gentoo je to možná jinak.
root amd64 ~ # grep 'CREATE_HOME' /etc/login.defs root amd64 ~ #Ué. Takže asi default
nedari se mi zaregistrovat do bug tracking systemu V čem je problém? Teď jsem to zkoušel, funguje to.nejspis v seznamu - nedosel mi potvrzovaci mejl. druha registrace s centrem uz prosla.
je mozne monitorovat adresar i s podadresari? inotify toto bohužel neumožňuje. Je to dáno tím, že se monitoruje inode, takže to, co se děje někde níž, už nelze zachytit. Na úrovni incronu by to šlo emulovat sledováním každého podadresáře zvlášť, ovšem na základě jediného pravidla. Problém je ovšem s tím, že když bude sledovaných adresářů moc, narazí to na limit prostředků.jen pro prehled: jake jsou ty limity?
pokud pouziji pravidlo s IN_CREATE a nasledne znovu zedituji tabulku, tak incrond tise zemre. bez jakekoliv hlasky do logu/konzole.male doplneni: IN_ACCESS a IN_MODIFY mi funguji, zbytek jsem nezkoumal. pokud do tabulky napisu uple blaboly, tak to projde - zadna hlaska/zadny pad.
nejspis v seznamu - nedosel mi potvrzovaci mejl. druha registrace s centrem uz prosla.Ano, skutečně. Podle logu to skončilo timeoutem. Ale stejně se to podařilo později předat serveru Seznamu.
jen pro prehled: jake jsou ty limity?Je to podle nastavení v /proc/sys/fs/inotify (resp. přes sysctl). Hodnota max_user_instances (default 128) říká, kolik file descriptorů smí uživatel max. otevřít. A hodnota max_user_watches potom, kolik watchů smí být na každém deskriptoru (default 8192). Takže celkové maximum je součinem těchto hodnot. Zase až tak málo to není, ale samozřejmě to žere paměť.
male doplneni: IN_ACCESS a IN_MODIFY mi funguji, zbytek jsem nezkoumal. pokud do tabulky napisu uple blaboly, tak to projde - zadna hlaska/zadny pad.Žádný obsah tabulky by neměl vyvolat pád. Co se týká formátu, když se nepodaří ani základní parsing (získání 3 součástí), řádek se ignoruje. Pokud je něco blbě v masce, ignoruje se příslušná nesmyslná část.
Tiskni
Sdílej: