This is difficult – usually the interface engine is only aware of the current message and cannot act depending on a previous message.
Before suggesting other possibilities, I assume you have examined the three or four A08s and have not found any little item in them that is unique such that only one of them has or does not have that item? And there is no way to modify the HIS to put some little tag in one of those messages that you can use to trigger the CONTINUE logic and kill the rest?
If those two options are not available, then you have to use something outside the message –
Table/File indicator – store information in a file or table that says an A08 has been sent. Use visit/encounter number in the entry to identify the encounter. Check the file for each A08 (expensive) that goes through. If you find that encounter number, it must have gone through before, so KILL the message. If not, put an entry in there and CONTINUE the message.
Cleaning this up later is a necessary chore. Maybe you can clean up the entry when you get an A03. Or you can use a database table to store this encounter A08 flag – but that uses more code to store the value.
Maybe just creating a tiny file whose name is made up of the encounter number would be easier. Use the tcl File Exists command to see if the file exists – if not, CONTINUE the message and write the file (needs no content). If the file exists, KILL the message. That’s probably 4 or 5 lines of code. You still need to cleanup the files later. Maybe a nightly batch script that deletes files older than a day. Or an even easier solution is when you write a new file, instead of Opening the file, Writing one line and Closing the file, you could instead use the File Copy command, and copy some blank template file to this new file name, that’s just one command.
You also have to decide where to put this logic – in the Inbound UPOC, in a pre-translate step or even in the destination thread Outbound UPOC. It depends on performance considerations.
Peter Heggie
PeterHeggie@crouse.org