Commit e473e303 authored by Jérome Perrin's avatar Jérome Perrin

ZSQLCatalog: fail loudly searching for dict iterators ( TODO: make this the default ? )

parent c5640e3f
...@@ -33,6 +33,7 @@ from zLOG import LOG ...@@ -33,6 +33,7 @@ from zLOG import LOG
from DateTime import DateTime from DateTime import DateTime
from Products.ZSQLCatalog.interfaces.operator import IOperator from Products.ZSQLCatalog.interfaces.operator import IOperator
from Products.ZSQLCatalog.Utils import sqlquote as escapeString from Products.ZSQLCatalog.Utils import sqlquote as escapeString
from AccessControl.ZopeGuards import SafeIter
from zope.interface.verify import verifyClass from zope.interface.verify import verifyClass
from zope.interface import implementer from zope.interface import implementer
...@@ -51,6 +52,9 @@ def valueDefaultRenderer(value): ...@@ -51,6 +52,9 @@ def valueDefaultRenderer(value):
def valueNoneRenderer(value): def valueNoneRenderer(value):
return 'NULL' return 'NULL'
def valueUnsupportedRenderer(value):
raise TypeError("ZSQCatalog does not support %s (%s)" % (type(value), value))
value_renderer = { value_renderer = {
int: str, int: str,
float: valueFloatRenderer, float: valueFloatRenderer,
...@@ -58,6 +62,10 @@ value_renderer = { ...@@ -58,6 +62,10 @@ value_renderer = {
None.__class__: valueNoneRenderer, None.__class__: valueNoneRenderer,
bool: int, bool: int,
str: escapeString, str: escapeString,
SafeIter: valueUnsupportedRenderer,
type(six.iterkeys({})): valueUnsupportedRenderer,
type(six.iteritems({})): valueUnsupportedRenderer,
type(six.itervalues({})): valueUnsupportedRenderer,
} }
if six.PY2: if six.PY2:
value_renderer[long] = str value_renderer[long] = str
......
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