summaryrefslogtreecommitdiff
path: root/django/newforms
diff options
context:
space:
mode:
authorMalcolm Tredinnick <malcolm.tredinnick@gmail.com>2007-07-13 12:03:20 +0000
committerMalcolm Tredinnick <malcolm.tredinnick@gmail.com>2007-07-13 12:03:20 +0000
commite4bcfc272c4ae6fa5c5b5ffa6fef06fa0cdfd4be (patch)
tree3ff6fe4774ee50e544081dcecc45d4f94da33887 /django/newforms
parent0145e71cebccb4729e00a31b04db5591614d04d0 (diff)
Fixed #4861 -- Removed some duplicated logic from the newforms RegexField by
making it a subclass of CharField. Thanks, Collin Grady. git-svn-id: http://code.djangoproject.com/svn/django/trunk@5684 bcc190cf-cafb-0310-a4f2-bffc1f526a37
Diffstat (limited to 'django/newforms')
-rw-r--r--django/newforms/fields.py14
1 files changed, 3 insertions, 11 deletions
diff --git a/django/newforms/fields.py b/django/newforms/fields.py
index e4982e1464..e5556f5898 100644
--- a/django/newforms/fields.py
+++ b/django/newforms/fields.py
@@ -298,18 +298,17 @@ class DateTimeField(Field):
continue
raise ValidationError(ugettext(u'Enter a valid date/time.'))
-class RegexField(Field):
+class RegexField(CharField):
def __init__(self, regex, max_length=None, min_length=None, error_message=None, *args, **kwargs):
"""
regex can be either a string or a compiled regular expression object.
error_message is an optional error message to use, if
'Enter a valid value' is too generic for you.
"""
- super(RegexField, self).__init__(*args, **kwargs)
+ super(RegexField, self).__init__(max_length, min_length, *args, **kwargs)
if isinstance(regex, basestring):
regex = re.compile(regex)
self.regex = regex
- self.max_length, self.min_length = max_length, min_length
self.error_message = error_message or ugettext(u'Enter a valid value.')
def clean(self, value):
@@ -317,16 +316,9 @@ class RegexField(Field):
Validates that the input matches the regular expression. Returns a
Unicode object.
"""
- super(RegexField, self).clean(value)
- if value in EMPTY_VALUES:
- value = u''
- value = smart_unicode(value)
+ value = super(RegexField, self).clean(value)
if value == u'':
return value
- if self.max_length is not None and len(value) > self.max_length:
- raise ValidationError(ugettext(u'Ensure this value has at most %d characters.') % self.max_length)
- if self.min_length is not None and len(value) < self.min_length:
- raise ValidationError(ugettext(u'Ensure this value has at least %d characters.') % self.min_length)
if not self.regex.search(value):
raise ValidationError(self.error_message)
return value