[Interest] interobject communication model and control flow

Vasily Pupkin shkodindanil.letmework at gmail.com
Tue Aug 20 16:11:29 CEST 2019


 Hi.

I am in the middle of refactoring a library, which I am going to publish
open source.
I found mysefl stuck reconsidering API in terms of interobject
communication.

There is a central class that have several signals, and I try to imagine
what library user could do in corresponding slots:
Should deleting an instance be possible from directly connected slot?
What should happen if one reenters event loop in a directly connected slot?
Should processing continue or lock?

In general, API is asynchronous in sense that methods just set some target
state and use queued connection to do processing from event loop and
signals just mark some events.

Qt itself has nice documentation that, for example, flags some method to be
reentrant or thead safe. But synchronous or asynchronous, event loop
reentry or deletion behavior is rarely described in detailed section. So I
struggle to find a reference implementation.

I wonder:
Does anyone consider these problems designing or using APIs?
Do you expect an object to continue processing even if control flow was
taken into event loop via direct signal slot connection?
What is the correct term or category to define event loop reentry safety?

Will appreciate any comments.
Wishes.

https://doc.qt.io/qt-5/signalsandslots.html
https://doc.qt.io/qt-5/threads-reentrancy.html
https://doc.qt.io/qt-5/qiodevice.html#bytesWritten
https://doc.qt.io/qt-5/qthread.html#finished
https://wiki.qt.io/API_Design_Principles
https://github.com/qt/qtbase/blob/5.12/src/corelib/thread/qthread_win.cpp#L403
https://github.com/qt/qtbase/blob/5.12/src/corelib/thread/qthread_unix.cpp#L400
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.qt-project.org/pipermail/interest/attachments/20190820/0a894cf0/attachment.html>


More information about the Interest mailing list