Ranter
Join devRant
Do all the things like
				++ or -- rants, post your own rants, comment on others' rants and build your customized dev avatar
				Sign Up
			Pipeless API
 
				From the creators of devRant, Pipeless lets you power real-time personalized recommendations and activity feeds using a simple API
				Learn More
			Comments
		- 
				
				All because QThread had a finished signal... But QRunnable has no way of determining when it's done! What the fuck? Why wouldn't a Runnable object have a way to determine completion? That's absolutely retarded.
- 
				
				@Demolishun it's collecting in the middle of the run function. It's being awfully retarded. I have my solution now, I just wanted to rant, not go back and re-open that wound.
 
 I was trying to emit a finished signal at the end of the run function. But it didn't get there before collection unless I printed out the QThread currentId or something similar.
- 
				
				@Demolishun it shows "reliability" factor of forums with new spectrum of confusion added each year. Mail lists square one?
- 
				
				@Demolishun now just to deal with the fact that buttons with a corner radius don't react to click if you click on the border......
 
 Fucking issue after issue.
- 
				
				 kraator4045y"Note that QThreadPool is a low-level class for managing threads, see the Qt Concurrent module for higher level alternatives." kraator4045y"Note that QThreadPool is a low-level class for managing threads, see the Qt Concurrent module for higher level alternatives."
- 
				
				 nekokatt805y@AlgoRythm About the runnable part not knowing when it is finished nekokatt805y@AlgoRythm About the runnable part not knowing when it is finished
 
 Is it probably because it is an interface rather than an actual stateful implementation?
 
 Seems similar to how Java has threads that can wrap runnables, but runnables are just behavioural interfaces.
 
 Might just be talking shit here, I know zero Qt, so if I am just ignore me
- 
				
				@nekokatt You're on the right track, but since their ThreadPool object takes runnables instead of threads, I can't execute something on another thread and return when it's done... which is the worst goddamn async design pattern I have ever fucking heard of......
- 
				
				 nekokatt805ystrange, no clue sorry! nekokatt805ystrange, no clue sorry!
 
 although if it is a runnable, i assume it is a callable object or some kind of class they define. Can you not subclass that and place a threaded event or flag or something on the runnable object?
- 
				
				@Demolishun I can be rather sure because my issue was an early death, but QDeadPool can't die.



Fucking hate Qt.
Spent all morning trying to figure out how their bullshit QThreadPool works with their bullshit QRunnable but after a bunch of bullshit asynchronous testing I figured that my thread object was being collected and deleted before I was done with it, for no reason. Now if the race condition was documented... This wouldn't be an issue. But every google search brought up nada. Eventually I resorted to turning off autoDelete on the runnable, but then I just have a memory leak, obviously.
I couldn't find a way to manually clean up a QRunnable in Python. What the fuck.
I just went back to good old fashioned QThreads... This is why I quit Qt in the first place.
rant