Fixed #317 -- SlugField now accepts hyphens. Thanks, Sune
git-svn-id: http://code.djangoproject.com/svn/django/trunk@968 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
parent
bf5dce64de
commit
539e53ccf1
|
@ -1,14 +1,13 @@
|
||||||
function URLify(s, num_chars) {
|
function URLify(s, num_chars) {
|
||||||
// changes, e.g., "Petty theft" to "petty_theft"
|
// changes, e.g., "Petty theft" to "petty_theft"
|
||||||
|
|
||||||
// remove all these words from the string before urlifying
|
// remove all these words from the string before urlifying
|
||||||
removelist = ["a", "an", "as", "at", "before", "but", "by", "for", "from",
|
removelist = ["a", "an", "as", "at", "before", "but", "by", "for", "from",
|
||||||
"is", "in", "into", "like", "of", "off", "on", "onto", "per",
|
"is", "in", "into", "like", "of", "off", "on", "onto", "per",
|
||||||
"since", "than", "the", "this", "that", "to", "up", "via",
|
"since", "than", "the", "this", "that", "to", "up", "via",
|
||||||
"with"];
|
"with"];
|
||||||
r = new RegExp('\\b(' + removelist.join('|') + ')\\b', 'gi');
|
r = new RegExp('\\b(' + removelist.join('|') + ')\\b', 'gi');
|
||||||
s = s.replace(r, '');
|
s = s.replace(r, '');
|
||||||
s = s.replace(/[^\w\s]/g, ''); // remove unneeded chars
|
s = s.replace(/[^\w\s-]/g, ''); // remove unneeded chars
|
||||||
s = s.replace(/^\s+|\s+$/g, ''); // trim leading/trailing spaces
|
s = s.replace(/^\s+|\s+$/g, ''); // trim leading/trailing spaces
|
||||||
s = s.replace(/\s+/g, '_'); // convert spaces to underscores
|
s = s.replace(/\s+/g, '_'); // convert spaces to underscores
|
||||||
s = s.toLowerCase(); // convert to lowercase
|
s = s.toLowerCase(); // convert to lowercase
|
||||||
|
|
|
@ -500,7 +500,7 @@ class PositiveSmallIntegerField(IntegerField):
|
||||||
class SlugField(Field):
|
class SlugField(Field):
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
kwargs['maxlength'] = 50
|
kwargs['maxlength'] = 50
|
||||||
kwargs.setdefault('validator_list', []).append(validators.isAlphaNumeric)
|
kwargs.setdefault('validator_list', []).append(validators.isSlug)
|
||||||
# Set db_index=True unless it's been set manually.
|
# Set db_index=True unless it's been set manually.
|
||||||
if not kwargs.has_key('db_index'):
|
if not kwargs.has_key('db_index'):
|
||||||
kwargs['db_index'] = True
|
kwargs['db_index'] = True
|
||||||
|
|
|
@ -21,6 +21,7 @@ email_re = re.compile(r'^[-\w.+]+@\w[\w.-]+$')
|
||||||
integer_re = re.compile(r'^-?\d+$')
|
integer_re = re.compile(r'^-?\d+$')
|
||||||
ip4_re = re.compile(r'^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}$')
|
ip4_re = re.compile(r'^\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}$')
|
||||||
phone_re = re.compile(r'^[A-PR-Y0-9]{3}-[A-PR-Y0-9]{3}-[A-PR-Y0-9]{4}$', re.IGNORECASE)
|
phone_re = re.compile(r'^[A-PR-Y0-9]{3}-[A-PR-Y0-9]{3}-[A-PR-Y0-9]{4}$', re.IGNORECASE)
|
||||||
|
slug_re = re.compile(r'^[-\w]+$')
|
||||||
url_re = re.compile(r'^http://\S+$')
|
url_re = re.compile(r'^http://\S+$')
|
||||||
|
|
||||||
from django.conf.settings import JING_PATH
|
from django.conf.settings import JING_PATH
|
||||||
|
@ -57,7 +58,11 @@ def isAlphaNumeric(field_data, all_data):
|
||||||
|
|
||||||
def isAlphaNumericURL(field_data, all_data):
|
def isAlphaNumericURL(field_data, all_data):
|
||||||
if not alnumurl_re.search(field_data):
|
if not alnumurl_re.search(field_data):
|
||||||
raise ValidationError, "This value must contain only letters, numbers, underscores and slashes."
|
raise ValidationError, "This value must contain only letters, numbers, underscores or slashes."
|
||||||
|
|
||||||
|
def isSlug(field_data, all_data):
|
||||||
|
if not slug_re.search(field_data):
|
||||||
|
raise ValidationError, "This value must contain only letters, numbers, underscores or hyphens."
|
||||||
|
|
||||||
def isLowerCase(field_data, all_data):
|
def isLowerCase(field_data, all_data):
|
||||||
if field_data.lower() != field_data:
|
if field_data.lower() != field_data:
|
||||||
|
|
|
@ -369,8 +369,8 @@ Here are all available field types:
|
||||||
|
|
||||||
``SlugField``
|
``SlugField``
|
||||||
"Slug" is a newspaper term. A slug is a short label for something,
|
"Slug" is a newspaper term. A slug is a short label for something,
|
||||||
containing only letters, numbers and underscores. They're generally used in
|
containing only letters, numbers, underscores or hyphens. They're generally
|
||||||
URLs.
|
used in URLs.
|
||||||
|
|
||||||
Implies ``maxlength=50`` and ``db_index=True``.
|
Implies ``maxlength=50`` and ``db_index=True``.
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue