Co přesně se děje, když se pomocí curlu připojujeme ke google.com? Proč to psát do terminálu, když si to můžeme pustit jako videoklip curl -v https://google.com na YouTube. 😂
Open source platforma Home Assistant (Demo, GitHub, Wikipedie) pro monitorování a řízení inteligentní domácnosti byla vydána ve verzi 2024.11.
Oficiálně byla vydána (Mastodon, 𝕏) první RC verze GIMPu 3.0. Přehled novinek v oznámení o vydání. Podrobně v souboru NEWS na GitLabu.
Hodnota Bitcoinu, decentralizované kryptoměny překonala 75 000 dolarů (1 770 157 korun).
Byla vydána nová verze 8.11.0 řádkového nástroje a knihovny pro přenos dat po různých protokolech curl. S oficiální podporou WebSocket. Opravena byla bezpečnostní chyba CVE-2024-9681.
Baví vás elektronika, informační technologie, bastlení nebo obecně technika? Pak i tento měsíc je tady pro Vás Virtuální Bastlírna - online setkání hospodského typu všech nadšenců do techniky, organizované projektem MacGyver strahovského studentského klubu SiliconHill.
Pokud by se diskuze náhodou zadrhla, mají Strahováci nachystaná i výplňová témata. Například co se stalo za katastrofy poslední měsíc? Voyager 1 musel kvůli poruše … více »Bylo publikováno RFC 9669 - BPF Instruction Set Architecture (ISA) specifikující instrukční sadu jaderného subsystému eBPF (Wikipedie).
Ondsel, tj. vylepšený FreeCAD, po dvou letech skončil. Cílem Ondselu bylo vylepšit UX/UI FreeCADu a nabízet jej komerčně. Od začátku věděli, že konkurovat komerčním CADům bude těžké. Bylo to ale těžší, než si mysleli. Proprietární CADy se vyučují na školách a jsou hluboce zakořeněny v průmyslu. Většina vylepšení od Ondselu se dostane do FreeCADu.
Desktopové prostředí LXQt (Lightweight Qt Desktop Environment, Wikipedie) vzniklé sloučením projektů Razor-qt a LXDE bylo vydáno ve verzi 2.1.0. Přehled novinek v poznámkách k vydání.
Aplikace LocalSend, tj. multiplatformní open source alternativa k AirDropu, tj. bezpečné sdílení souborů a zpráv s okolními zařízeními přes lokální síť, bez potřeby připojení k internetu, byla vydána ve verzi 1.16, aktuálně 1.16.1. Instalovat lze také z Flathubu a Snapcraftu.
class Gatherer(QThread): def __init__(self, parentThread, controller): QThread.__init__(self, QThread.currentThread()) self.controller=controller def run(self): self.stopMe=0 while (self.stopMe==0): print '.' time.sleep(1) print 'xx' def stop(self): self.stopMe=1 QThread.wait(self)jedine co to vypise v konzoli je jedna '.', a potom to 'zamrzne'. 'xx' to vypise az potom, ako sa nieco udeje v tom dockwidgete (napr. sa stlaci nejake tlacidlo - predpokladam ze hocikedy, ked sa vola 'handler' nejakeho signalu). Neviete niekto, kde by mohol byt problem? Ked ten thread spustim priamo:
g=Gatherer() g.run() time.sleep(10) g.stop()tak to samozrejme funguje... Najzaujimavejsie na tom vsetkom je, ze toto: http://trac.reprojected.com/qgisplugins/browser/trunk/threading_demo funguje uplne spolahlivo - pritom jediny rozdiel je, ze tam to vlakno este vytvara nejake signaly a ze miesto dockwidgetu sa tam zobrazuje okno... Jedina moznost co ma napada je, ze to vlakno nebezi preto, ze by, pokial nie su spravy od Qt, nebezal ten python interpreter (co by ale bolo divne, ked clovek od neho chcel vlakno...). any ideas?
self.timer = QTimer() QObject.connect(self.timer, SIGNAL("timeout()"), self.runStatus) self.timer.start(10) ... def runStatus(self): self.thread.msleep(1) returnak by mi niekto bol schopny logicky objasnit, preco je toto nutne, aby vlakna fungovali (a preco to nie je v ziadnej dokumentacii), bol by som velmi vdacny
t=Gatherer(); t.start()
...
sranda je, ze nasledujuci workaround to "zfunkcni", a ja vobec netusim preco by mal (ako je mi jasne co to robi, a preco by to mohlo fungovat - ale nechapem, preco je nutne toto spravit, aby fungovali vlakna.. by clovek povedal, ze vlakna su od toho, ze funguju same - nie ze si clovek musi preempciu dokodit sam :)))
def someSignalHandler(self): self.t=Gatherer() self.t.start() self.timer = QTimer() QObject.connect(self.timer, SIGNAL("timeout()"), self.runStatus) self.timer.start(10) def runStatus(self): self.gatherer.msleep(1) return
Tiskni Sdílej: