mirror of
https://github.com/netbox-community/netbox.git
synced 2025-08-17 04:58:16 -06:00
Simplify range detection
This commit is contained in:
parent
665ea402f6
commit
ad1298428f
@ -51,37 +51,43 @@ def parse_alphanumeric_range(string):
|
|||||||
'0-3,a-d' => [0, 1, 2, 3, a, b, c, d]
|
'0-3,a-d' => [0, 1, 2, 3, a, b, c, d]
|
||||||
"""
|
"""
|
||||||
values = []
|
values = []
|
||||||
for dash_range in string.split(','):
|
for value in string.split(','):
|
||||||
|
if '-' not in value:
|
||||||
|
# Item is not a range
|
||||||
|
values.append(value)
|
||||||
|
continue
|
||||||
|
|
||||||
|
# Find the range's beginning & end values
|
||||||
try:
|
try:
|
||||||
begin, end = dash_range.split('-')
|
begin, end = value.split('-')
|
||||||
vals = begin + end
|
vals = begin + end
|
||||||
# Break out of loop if there's an invalid pattern to return an error
|
# Break out of loop if there's an invalid pattern to return an error
|
||||||
if (not (vals.isdigit() or vals.isalpha())) or (vals.isalpha() and not (vals.isupper() or vals.islower())):
|
if (not (vals.isdigit() or vals.isalpha())) or (vals.isalpha() and not (vals.isupper() or vals.islower())):
|
||||||
return []
|
return []
|
||||||
except ValueError:
|
except ValueError:
|
||||||
begin, end = dash_range, dash_range
|
raise forms.ValidationError(_('Range "{value}" is invalid.').format(value=value))
|
||||||
|
|
||||||
# Value-based
|
# Numeric range
|
||||||
if begin == end:
|
if begin.isdigit() and end.isdigit():
|
||||||
values.append(begin)
|
|
||||||
# Numeric range-based
|
|
||||||
elif begin.isdigit() and end.isdigit():
|
|
||||||
if int(begin) >= int(end):
|
if int(begin) >= int(end):
|
||||||
raise forms.ValidationError(_('Range "{value}" is invalid.').format(value=dash_range))
|
raise forms.ValidationError(
|
||||||
|
_('Invalid range: Ending value ({end}) must be greater than beginning value ({begin}).').format(
|
||||||
|
begin=begin, end=end
|
||||||
|
)
|
||||||
|
)
|
||||||
for n in list(range(int(begin), int(end) + 1)):
|
for n in list(range(int(begin), int(end) + 1)):
|
||||||
values.append(n)
|
values.append(n)
|
||||||
# Range-based
|
|
||||||
|
# Alphanumeric range
|
||||||
else:
|
else:
|
||||||
# Not a valid range (more than a single character)
|
# Not a valid range (more than a single character)
|
||||||
if not len(begin) == len(end) == 1:
|
if not len(begin) == len(end) == 1:
|
||||||
raise forms.ValidationError(_('Range "{value}" is invalid.').format(value=dash_range))
|
raise forms.ValidationError(_('Range "{value}" is invalid.').format(value=value))
|
||||||
|
|
||||||
if ord(begin) >= ord(end):
|
if ord(begin) >= ord(end):
|
||||||
raise forms.ValidationError(_('Range "{value}" is invalid.').format(value=dash_range))
|
raise forms.ValidationError(_('Range "{value}" is invalid.').format(value=value))
|
||||||
|
|
||||||
for n in list(range(ord(begin), ord(end) + 1)):
|
for n in list(range(ord(begin), ord(end) + 1)):
|
||||||
values.append(chr(n))
|
values.append(chr(n))
|
||||||
|
|
||||||
return values
|
return values
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user