Can anyone provide more info on this?
Is this the Dynamic vs Static registration issue of User Events?
Is there a known bug?
It does not sound very nice that LabVIEW would not process events in the order they are received !!
I disagree - I guess I am one of those touters
I have found I can write cleaner code using a QSM.
As LabVIEW is a dataflow language it can get complicated if I have to share data between parallel processes, so I try to avoid this (where possible) if I don't have to.
It can be beneficial if a single loop is used, as it means I share its state within the loop, making use of passing by-value - just the way LabVIEW likes it.
I don't want to sound like a nuthugger either but this is why I find the JKI State Machine a very elegant solution, esp wrt Macros in this case.
I do agree through that as soon as you start queuing states in the QSM it can start to get tricky - but pre-buffering (i.e. Macros) states then running through them is very handy, clean and easy to debug.
Also it does not affect the UI experience as you can disable the cursor if it has to think for a while or crunch some heavy stuff if you are responding to User Interface Events as well.
You can also communicate with the QSM through an Event Structure, allowing external messages in (although I recommend creating an API so that you have a controlled interface).
There is more work in setting up Event messaging but sometimes it is nice to have Static Data defined for events rather than say e.g. a Queue with an enum and variant for the data.
(You could implement messaging using LVOOP, but that would most likely be more work)
Of course every design pattern has its limitations and if you need to separate the UI from the Engine or run a Control thread then you will require a more complex pattern but I have found that I usually just have multiple JKI State Machines.
I even like to use this as the framework for a process in an Active Object.
Anyways, I find for what I do, 80% of my use cases can use a QSM and not have to worry.
And if I need to expand I create more QSMs (on the project I am currently working on, it was decided to separate the UI from the Engine and it was quite painless).
I find I don't use Queues that much for messaging any more but rather for buffering up data etc...
Even though Events were not designed to replace queues for messaging and you can't flush, preview etc... there seem a logical evolution and I find very easy to work with.
E.g. having all messages (User Events and User Interface Events) coming through the one interface (Event Structure) helps me to share the statefullness and make use of by-value as mentioned above.
I.e. I don't have to poll another queue for messages and listen to the User Interface.
This is just how I currently like to do things.
I used to always startup a GUI using multiple loops, namely QSM-PC (Event) but I found this complicated this fast.
Plus using Queues (enum/variant) meant I had extra data types per loop to create and maintain - JKI State Machine is string based and so there are no data-types needed and therefore e.g. the State Manager (for checking if an error occurs and going to the Error Handler state etc...) can be reused. That is why I like it better than the Expression Flow QSM-PC example.
Nowdays I am like, why make things more complicated if they do not have to be...