09-28-2020 12:52 PM
I am in the process of converting a LabWindows 2017 app over to use Async Timers. It has been going well, so far, but then I hit a snag.
The existing Timer callbacks will call functions that pop up dialog boxes to report system errors. Now they cannot, due to error -128:
(return value == -129 [0xffffffffffffff7f]). This panel operation can be performed (if a top-level panel) only in the thread in which the panel was created, or (if a child panel) only in the thread in which the top-level parent panel was created.
Before I go to rearchitect this large program, I wondered if there was some other way to acess these panels from the Async Timer thread?
09-28-2020 02:13 PM
At the end of some of our timer callbacks we would call some function like this:
Function ();
That function could end up trying to access PANEL gui elements. Some help file reading led me to this:
PostDeferredCall ((DeferredCallbackPtr)Function , NULL);
This allows that function to be called later by the main thread. Or so it seems. It seems to work.
Is this safe?
09-28-2020 10:36 PM
Yes, PostDeferredCall will handle the operation over to the main thread, which also runs your main() function.
Alternatively you can load/unload your panels from the async timer thread.
Load them when async timer callback runs for the first time, and unload when the timer is discarded.
Async timers have an input parameter that tells you how many times the callback has fired. You can use it to detect the first time.
Also, you can implement an EVENT_DISCARD in the timer callback, which tells you when the timer is discarded.
Hope this helps.
09-30-2020 07:40 AM
I have used an alternative method with ordinary threaded functions: use PostDeferredCallToThread () to call a function that is to be executed in a specific thread. Call CmtGetCurrentThreadID () in the threaded function to retrieve the thread ID to use. I have not tried it with async timers, but you may want to try it.
09-30-2020 09:53 AM
Roberto -- does this imply one can make an idle thread, and just dispatch functions there when needed using PostDeferredCallToThread ()? As long as the functions are thread-safe, I suppose?
09-30-2020 04:51 PM - edited 09-30-2020 04:51 PM
I never tried such a framework but I don't see a reason why it should not work, provided the idle thread function processes events.