Kaydet (Commit) d1db30b7 authored tarafından Guido van Rossum's avatar Guido van Rossum

Improve error messages for invalid warning arguments; don't raise

exceptions but always print a warning message.
üst 5aff7752
...@@ -167,14 +167,20 @@ def _getcategory(category): ...@@ -167,14 +167,20 @@ def _getcategory(category):
if re.match("^[a-zA-Z0-9_]+$", category): if re.match("^[a-zA-Z0-9_]+$", category):
try: try:
cat = eval(category) cat = eval(category)
except KeyError: except NameError:
raise _OptionError("invalid warning category: %s" % `category`) raise _OptionError("unknown warning category: %s" % `category`)
else: else:
i = category.rfind(".") i = category.rfind(".")
module = category[:i] module = category[:i]
klass = category[i+1:] klass = category[i+1:]
m = __import__(module, None, None, [klass]) try:
cat = getattr(m, klass) m = __import__(module, None, None, [klass])
except ImportError:
raise _OptionError("invalid module name: %s" % `module`)
try:
cat = getattr(m, klass)
except AttributeError:
raise _OptionError("unknown warning category: %s" % `category`)
if (not isinstance(cat, types.ClassType) or if (not isinstance(cat, types.ClassType) or
not issubclass(cat, Warning)): not issubclass(cat, Warning)):
raise _OptionError("invalid warning category: %s" % `category`) raise _OptionError("invalid warning category: %s" % `category`)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment