Commit 0541c073 authored by Christopher Petrilli's avatar Christopher Petrilli

Added support for the 'op' attribute which lets you control which

comparison operator is used for comparison.  Patch from Hugh
(hugh@embertech.com).
parent 0bc58a79
...@@ -127,7 +127,7 @@ ...@@ -127,7 +127,7 @@
'and' or 'or' tag, otherwise, no text is inserted. 'and' or 'or' tag, otherwise, no text is inserted.
''' '''
__rcs_id__='$Id: sqltest.py,v 1.10 1999/08/26 17:59:36 jim Exp $' __rcs_id__='$Id: sqltest.py,v 1.11 1999/09/22 17:57:57 petrilli Exp $'
############################################################################ ############################################################################
# Copyright # Copyright
...@@ -137,7 +137,7 @@ __rcs_id__='$Id: sqltest.py,v 1.10 1999/08/26 17:59:36 jim Exp $' ...@@ -137,7 +137,7 @@ __rcs_id__='$Id: sqltest.py,v 1.10 1999/08/26 17:59:36 jim Exp $'
# rights reserved. # rights reserved.
# #
############################################################################ ############################################################################
__version__='$Revision: 1.10 $'[11:-2] __version__='$Revision: 1.11 $'[11:-2]
import sys import sys
from DocumentTemplate.DT_Util import ParseError, parse_params, name_param from DocumentTemplate.DT_Util import ParseError, parse_params, name_param
...@@ -152,19 +152,27 @@ class SQLTest: ...@@ -152,19 +152,27 @@ class SQLTest:
def __init__(self, args): def __init__(self, args):
args = parse_params(args, name='', type=None, column=None, args = parse_params(args, name='', type=None, column=None,
multiple=1, optional=1) multiple=1, optional=1, op=None)
self.__name__ = name_param(args,'sqlvar') self.__name__ = name_param(args,'sqlvar')
has_key=args.has_key has_key=args.has_key
if not has_key('type'): if not has_key('type'):
raise ParseError, ('the type attribute is required', 'dtvar') raise ParseError, ('the type attribute is required', 'sqltest')
self.type=t=args['type'] self.type=t=args['type']
if not valid_type(t): if not valid_type(t):
raise ParseError, ('invalid type, %s' % t, 'dtvar') raise ParseError, ('invalid type, %s' % t, 'sqltest')
if has_key('optional'): self.optional=args['optional'] if has_key('optional'): self.optional=args['optional']
if has_key('multiple'): self.multiple=args['multiple'] if has_key('multiple'): self.multiple=args['multiple']
if has_key('column'): self.column=args['column'] if has_key('column'): self.column=args['column']
else: self.column=self.__name__ else: self.column=self.__name__
# Deal with optional operator specification
op = '=' # Default
if has_key('op'):
op = args['op']
# Try to get it from the chart, otherwise use the one provided
op = comparison_operators.get(op, op)
self.op = op
def render(self, md): def render(self, md):
name=self.__name__ name=self.__name__
t=self.type t=self.type
...@@ -215,8 +223,12 @@ class SQLTest: ...@@ -215,8 +223,12 @@ class SQLTest:
if len(vs) > 1: if len(vs) > 1:
vs=join(map(str,vs),', ') vs=join(map(str,vs),', ')
return "%s in (%s)" % (self.column,vs) return "%s in (%s)" % (self.column,vs)
return "%s=%s" % (self.column,vs[0]) return "%s %s %s" % (self.column, self.op, vs[0])
__call__=render __call__=render
valid_type={'int':1, 'float':1, 'string':1, 'nb': 1}.has_key valid_type={'int':1, 'float':1, 'string':1, 'nb': 1}.has_key
comparison_operators = { 'eq': '=', 'ne': '<>',
'lt': '<', 'le': '<=', 'lte': '<=',
'gt': '>', 'ge': '>=', 'gte': '>=' }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment