Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Integration into main-loop application #19

Open
chhitz opened this issue Feb 6, 2016 · 8 comments
Open

Integration into main-loop application #19

chhitz opened this issue Feb 6, 2016 · 8 comments

Comments

@chhitz
Copy link

chhitz commented Feb 6, 2016

Looking at the (completely undocumented) header files and sample code ones comes to the conclusion that the blocking Client::run() method has to called for the library to function.

I'd like to integrate Flic buttons into an existing main-loop based application. For this a blocking run() method is not ideal as I would need an extra thread to run it.

For this kine of applications, I suggest adding a poll() method to the Client class. A call to poll() would dispatch the ready handlers/callbacks without blocking. I could then call this method in the existing main-loop without an additional thread.

@fabianbergmark
Copy link
Contributor

This might be a good idea. However, I don't see the problem with requiring users to create a separate thread. Are you using this on a very constrained platform?

@chhitz
Copy link
Author

chhitz commented Feb 7, 2016

I'm looking at this from more of a design side. Using the same main-loop for the whole application makes lock and mutexes unnecessary which simplifies development (and debugging).

Am I assuming right that all the callbacks are executed in the context of the thread that executes run()?

@fabianbergmark
Copy link
Contributor

The run method is simply a loop around a blocking network read to receive events from the daemon. Do you mean you want the poll method to do a non-blocking read, and if a case a event was received dispatch that? Or do you want the read-loop to be run in an internal thread, and poll to dispatch any received events. I think the first alternative might be dangerous as running poll to seldom would cause a buildup. The gain with the second alternative is only the simplicity of a single threaded application. If more people think this is a good idea I will implement it.

@Emill
Copy link
Contributor

Emill commented Feb 7, 2016

Maybe it would be nice if the socket fd was exposed so one could select on
it. And then a non-blocking function "handleEvents" or something that can
be called if the fd has data.

2016-02-07 14:57 GMT+01:00 Fabian Bergmark [email protected]:

The run method is simply a loop around a blocking network read to receive
events from the daemon. Do you mean you want the poll method to do a
non-blocking read, and if a case a event was received dispatch that? Or do
you want the read-loop to be run in an internal thread, and poll to
dispatch any received events. I think the first alternative might be
dangerous as running poll to seldom would cause a buildup. The gain with
the second alternative is only the simplicity of a single threaded
application. If more people think this is a good idea I will implement it.


Reply to this email directly or view it on GitHub
#19 (comment)
.

@chhitz
Copy link
Author

chhitz commented Feb 7, 2016

A third option would be to implement the connection to the daemon also in a non-blocking, asynchronous way (for example using Asio).

@fabianbergmark
Copy link
Contributor

Keep in mind that the solutions have to be compatible with SWIG, so working with sockets directly sounds scary. If the only concern is on which thread the event callbacks are executed, using a single mutex to get the same single-threaded flow isn't to much of a hassle in my opinion, but I do agree that the blocking run function isn't very pretty.

@NikolasE
Copy link

I also would like to have a non-blocking function. With this, it would be easier to integrate into other systems that wait for other (e.g. TCP-based) connections.

@fabianbergmark
Copy link
Contributor

But a providing a non-blocking poll function that you could call in a select loop would affect delay if you don't use a very low timeout. I could expose the socket as an integer value but would that be usable from Java/Python?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants