import itertools
try:
+ # pylint: disable-msg=F0401
import functools
except ImportError:
functools = None
+try:
+ # pylint: disable-msg=F0401
+ import roman
+except ImportError:
+ roman = None
+
# compat.md5_hash and compat.sha1_hash can be called to generate and md5 and a
# sha1 hashing modules, under python 2.4, 2.5 and 2.6, even though some changes
# modules (hmac, for example) which have changed their behavior as well from
# one version to the other.
try:
+ # pylint: disable-msg=F0401
# Yes, we're not using the imports in this module.
# pylint: disable-msg=W0611
from hashlib import md5 as md5_hash
sha1_hash = sha.new
-def all(seq, pred=bool): # pylint: disable-msg=W0622
- """Returns True if pred(x) is True for every element in the iterable.
-
- Please note that this function provides a C{pred} parameter which isn't
- available in the version included in Python 2.5 and above.
+def _all(seq):
+ """Returns True if all elements in the iterable are True.
"""
- for _ in itertools.ifilterfalse(pred, seq):
+ for _ in itertools.ifilterfalse(bool, seq):
return False
return True
-
-def any(seq, pred=bool): # pylint: disable-msg=W0622
- """Returns True if pred(x) is True for at least one element in the iterable.
-
- Please note that this function provides a C{pred} parameter which isn't
- available in the version included in Python 2.5 and above.
+def _any(seq):
+ """Returns True if any element of the iterable are True.
"""
- for _ in itertools.ifilter(pred, seq):
+ for _ in itertools.ifilter(bool, seq):
return True
return False
+try:
+ # pylint: disable-msg=E0601
+ # pylint: disable-msg=W0622
+ all = all
+except NameError:
+ all = _all
+
+try:
+ # pylint: disable-msg=E0601
+ # pylint: disable-msg=W0622
+ any = any
+except NameError:
+ any = _any
def partition(seq, pred=bool): # pylint: disable-msg=W0622
"""Partition a list in two, based on the given predicate.
partial = _partial
else:
partial = functools.partial
+
+
+def TryToRoman(val, convert=True):
+ """Try to convert a value to roman numerals
+
+ If the roman module could be loaded convert the given value to a roman
+ numeral. Gracefully fail back to leaving the value untouched.
+
+ @type val: integer
+ @param val: value to convert
+ @type convert: boolean
+ @param convert: if False, don't try conversion at all
+ @rtype: string or typeof(val)
+ @return: roman numeral for val, or val if conversion didn't succeed
+
+ """
+ if roman is not None and convert:
+ try:
+ return roman.toRoman(val)
+ except roman.RomanError:
+ return val
+ else:
+ return val
+