newforms: Removed Widget.requires_data_list parameter, which was made redundant by Widget.value_from_datadict()

git-svn-id: http://code.djangoproject.com/svn/django/trunk@4235 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
Adrian Holovaty 2006-12-24 03:36:49 +00:00
parent f6fd5827aa
commit 3d9b12b2d8
2 changed files with 8 additions and 6 deletions

View File

@ -234,9 +234,7 @@ class BoundField(StrAndUnicode):
def _data(self): def _data(self):
"Returns the data for this BoundField, or None if it wasn't given." "Returns the data for this BoundField, or None if it wasn't given."
if self.field.widget.requires_data_list and isinstance(self.form.data, MultiValueDict): return self.field.widget.value_from_datadict(self.form.data, self.html_name)
return self.form.data.getlist(self.html_name)
return self.form.data.get(self.html_name, None)
data = property(_data) data = property(_data)
def label_tag(self, contents=None): def label_tag(self, contents=None):

View File

@ -23,13 +23,18 @@ except NameError:
flatatt = lambda attrs: u''.join([u' %s="%s"' % (k, escape(v)) for k, v in attrs.items()]) flatatt = lambda attrs: u''.join([u' %s="%s"' % (k, escape(v)) for k, v in attrs.items()])
class Widget(object): class Widget(object):
requires_data_list = False # Determines whether render()'s 'value' argument should be a list.
is_hidden = False # Determines whether this corresponds to an <input type="hidden">. is_hidden = False # Determines whether this corresponds to an <input type="hidden">.
def __init__(self, attrs=None): def __init__(self, attrs=None):
self.attrs = attrs or {} self.attrs = attrs or {}
def render(self, name, value): def render(self, name, value, attrs=None):
"""
Returns this Widget rendered as HTML, as a Unicode string.
The 'value' given is not guaranteed to be valid input, so subclass
implementations should program defensively.
"""
raise NotImplementedError raise NotImplementedError
def build_attrs(self, extra_attrs=None, **kwargs): def build_attrs(self, extra_attrs=None, **kwargs):
@ -130,7 +135,6 @@ class Select(Widget):
return u'\n'.join(output) return u'\n'.join(output)
class SelectMultiple(Widget): class SelectMultiple(Widget):
requires_data_list = True
def __init__(self, attrs=None, choices=()): def __init__(self, attrs=None, choices=()):
# choices can be any iterable # choices can be any iterable
self.attrs = attrs or {} self.attrs = attrs or {}