diff options
author | Lorry Tar Creator <lorry-tar-importer@baserock.org> | 2014-02-21 04:46:49 +0000 |
---|---|---|
committer | <> | 2014-08-04 21:38:17 +0000 |
commit | f3765db04b903b3671733e07cf1541a51966dd14 (patch) | |
tree | defcc3c47d9b8bd78b97dcc04ee779a758d37b1c /demo3/repeating_thread.py | |
download | posix-ipc-tarball-master.tar.gz |
Imported from /home/lorry/working-area/delta_python-packages_posix-ipc-tarball/posix_ipc-0.9.8.tar.gz.HEADposix_ipc-0.9.8master
Diffstat (limited to 'demo3/repeating_thread.py')
-rw-r--r-- | demo3/repeating_thread.py | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/demo3/repeating_thread.py b/demo3/repeating_thread.py new file mode 100644 index 0000000..e456428 --- /dev/null +++ b/demo3/repeating_thread.py @@ -0,0 +1,40 @@ +# Python modules +import time + +# 3rd party modules +import posix_ipc + +# Utils for this demo +import utils + + +def process_notification(mq): + message, priority = mq.receive() + + print ("Ding! Message with priority %d received: %s" % (priority, message)) + + # Re-register for notifications + mq.request_notification( (process_notification, mq) ) + + + +# Create the message queue. +mq = posix_ipc.MessageQueue(utils.QUEUE_NAME, posix_ipc.O_CREX) + +# Request notifications +mq.request_notification( (process_notification, mq) ) + +# Get user input and send it to the queue. +s = "42" +while s: + print ("\nEnter a message. A blank message will end the demo:") + s = utils.get_input() + if s: + mq.send(s) + +print ("Destroying the message queue.") +mq.close() +# I could call simply mq.unlink() here but in order to demonstrate +# unlinking at the module level I'll do it that way. +posix_ipc.unlink_message_queue(utils.QUEUE_NAME) + |