[Zope-Checkins]
SVN: Zope/trunk/lib/python/AccessControl/requestmethod.
Fix potential bug in requestmethod where you cannot specify
None for a keyword argument where None is not the default
Martijn Pieters
mj at zopatista.com
Fri Apr 20 10:23:43 EDT 2007
Log message for revision 74259:
Fix potential bug in requestmethod where you cannot specify None for a keyword argument where None is not the default
Changed:
U Zope/trunk/lib/python/AccessControl/requestmethod.py
U Zope/trunk/lib/python/AccessControl/requestmethod.txt
-=-
Modified: Zope/trunk/lib/python/AccessControl/requestmethod.py
===================================================================
--- Zope/trunk/lib/python/AccessControl/requestmethod.py 2007-04-20 13:24:43 UTC (rev 74258)
+++ Zope/trunk/lib/python/AccessControl/requestmethod.py 2007-04-20 14:23:43 UTC (rev 74259)
@@ -15,14 +15,16 @@
from zExceptions import Forbidden
from zope.publisher.interfaces.browser import IBrowserRequest
+_default = []
+
def _buildFacade(spec, docstring):
"""Build a facade function, matching the decorated method in signature.
- Note that defaults are replaced by None, and _curried will reconstruct
+ Note that defaults are replaced by _default, and _curried will reconstruct
these to preserve mutable defaults.
"""
- args = inspect.formatargspec(formatvalue=lambda v: '=None', *spec)
+ args = inspect.formatargspec(formatvalue=lambda v: '=_default', *spec)
callargs = inspect.formatargspec(formatvalue=lambda v: '', *spec)
return 'def _facade%s:\n """%s"""\n return _curried%s' % (
args, docstring, callargs)
@@ -60,7 +62,7 @@
if defaults is not None:
args, kwparams = args[:arglen], args[arglen:]
for positional, (key, default) in zip(kwparams, defaults):
- if positional is None:
+ if positional is _default:
kw[key] = default
else:
kw[key] = positional
@@ -68,7 +70,7 @@
return callable(*args, **kw)
# Build a facade, with a reference to our locally-scoped _curried
- facade_globs = dict(_curried=_curried)
+ facade_globs = dict(_curried=_curried, _default=_default)
exec _buildFacade(spec, callable.__doc__) in facade_globs
return facade_globs['_facade']
Modified: Zope/trunk/lib/python/AccessControl/requestmethod.txt
===================================================================
--- Zope/trunk/lib/python/AccessControl/requestmethod.txt 2007-04-20 13:24:43 UTC (rev 74258)
+++ Zope/trunk/lib/python/AccessControl/requestmethod.txt 2007-04-20 14:23:43 UTC (rev 74259)
@@ -57,12 +57,12 @@
>>> import inspect
>>> mutabledefault = dict()
>>> @requestmethod('POST')
- ... def foo(bar, baz=mutabledefault, REQUEST=None, **kw):
- ... return bar, baz is mutabledefault, REQUEST
+ ... def foo(bar, baz=mutabledefault, egg=mutabledefault, REQUEST=None, **kw):
+ ... return bar, baz is mutabledefault, egg is None, REQUEST
>>> inspect.getargspec(foo)[:3]
- (['bar', 'baz', 'REQUEST'], None, 'kw')
- >>> foo('spam')
- ('spam', True, None)
+ (['bar', 'baz', 'egg', 'REQUEST'], None, 'kw')
+ >>> foo('spam', egg=None)
+ ('spam', True, True, None)
The requestmethod decorator factory can be used for any request method, simply
pass in the desired request method::
More information about the Zope-Checkins
mailing list