From 3f506b8c7c48fd444690c0eea83f2af4e8445ce5 Mon Sep 17 00:00:00 2001 From: Ted Ross Date: Thu, 3 Feb 2011 02:42:40 +0000 Subject: Add detection of negative numbers to the method-argument evaluator. Note: This logic is getting a bit hairy, it should be replaced with a regular expression match. git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk@1066725 13f79535-47bb-0310-9956-ffa450edef68 --- qpid/tools/src/py/qmf-tool | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) (limited to 'qpid/tools') diff --git a/qpid/tools/src/py/qmf-tool b/qpid/tools/src/py/qmf-tool index c01900ac62..3ea327b29a 100755 --- a/qpid/tools/src/py/qmf-tool +++ b/qpid/tools/src/py/qmf-tool @@ -310,8 +310,11 @@ class QmfData: ## If the argument is a map, list, boolean, integer, or floating (one decimal point), ## run it through the Python evaluator so it is converted to the correct type. ## - if arg[0] == '{' or arg[0] == '[' or arg == "True" or arg == "False" \ - or (arg.count('.') < 2 and arg.replace('.','').isdigit()): + ## TODO: use a regex for this instead of this convoluted logic + if arg[0] == '{' or arg[0] == '[' or arg == "True" or arg == "False" or \ + ((arg.count('.') < 2 and (arg.count('-') == 0 or \ + (arg.count('-') == 1 and arg[0] == '-')) and \ + arg.replace('.','').replace('-','').isdigit())): args.append(eval(arg)) else: args.append(arg) -- cgit v1.2.1