diff options
author | Rafael H. Schloming <rhs@apache.org> | 2010-02-13 13:02:06 +0000 |
---|---|---|
committer | Rafael H. Schloming <rhs@apache.org> | 2010-02-13 13:02:06 +0000 |
commit | cd50c6ac6cb31df04c6b68731155cd75c37abced (patch) | |
tree | cf42f43f9b343d19fc6d186caefe3ac4a851ecd8 | |
parent | 68008d8656a1dc3e96bedc40a93c9c2389c10f2c (diff) | |
download | qpid-python-cd50c6ac6cb31df04c6b68731155cd75c37abced.tar.gz |
added count and print formatting options to drain
git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk/qpid@909810 13f79535-47bb-0310-9956-ffa450edef68
-rwxr-xr-x | python/examples/api/drain | 26 |
1 files changed, 22 insertions, 4 deletions
diff --git a/python/examples/api/drain b/python/examples/api/drain index ef1f050c8c..a852d29de7 100755 --- a/python/examples/api/drain +++ b/python/examples/api/drain @@ -27,6 +27,10 @@ parser = optparse.OptionParser(usage="usage: %prog [options] ADDRESS ...", description="Drain messages from the supplied address.") parser.add_option("-b", "--broker", default="localhost", help="connect to specified BROKER (default %default)") +parser.add_option("-c", "--count", type=int, + help="number of messages to drain") +parser.add_option("-f", "--forever", action="store_true", + help="ignore timeout and wait forever") parser.add_option("-r", "--reconnect", action="store_true", help="enable auto reconnect") parser.add_option("-d", "--reconnect-delay", type=float, default=3, @@ -35,8 +39,8 @@ parser.add_option("-l", "--reconnect-limit", type=int, help="maximum number of reconnect attempts") parser.add_option("-t", "--timeout", type=float, default=0, help="timeout in seconds to wait before exiting (default %default)") -parser.add_option("-f", "--forever", action="store_true", - help="ignore timeout and wait forever") +parser.add_option("-p", "--print", dest="format", default="%(M)s", + help="format string for printing messages (default %default)") parser.add_option("-v", dest="verbose", action="store_true", help="enable logging") @@ -57,6 +61,17 @@ if opts.forever: else: timeout = opts.timeout +class Formatter: + + def __init__(self, message): + self.message = message + self.environ = {"M": self.message, + "P": self.message.properties, + "C": self.message.content} + + def __getitem__(self, st): + return eval(st, self.environ) + # XXX: should make URL default the port for us conn = Connection.open(url.host, url.port or AMQP_PORT, username=url.user, @@ -67,9 +82,12 @@ conn = Connection.open(url.host, url.port or AMQP_PORT, ssn = conn.session() rcv = ssn.receiver(addr) -while True: +count = 0 +while not opts.count or count < opts.count: try: - print rcv.fetch(timeout=timeout) + msg = rcv.fetch(timeout=timeout) + print opts.format % Formatter(msg) + count += 1 ssn.acknowledge() except Empty: break |