diff options
author | Ned Batchelder <ned@nedbatchelder.com> | 2011-03-24 22:49:37 -0400 |
---|---|---|
committer | Ned Batchelder <ned@nedbatchelder.com> | 2011-03-24 22:49:37 -0400 |
commit | 01ea68a1088fc1cdbdd586624ac695c5b697edeb (patch) | |
tree | 7b64f69deaeda1fa07c38bfdb64c7c4d8e879eb3 /coverage/misc.py | |
parent | 1f950ca6c4c1da6d5f2f37faeb0217e9ff273b75 (diff) | |
download | python-coveragepy-git-01ea68a1088fc1cdbdd586624ac695c5b697edeb.tar.gz |
Incremental HTML generation. Some cleanup would be good.
Diffstat (limited to 'coverage/misc.py')
-rw-r--r-- | coverage/misc.py | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/coverage/misc.py b/coverage/misc.py index 4218536d..3c02d3eb 100644 --- a/coverage/misc.py +++ b/coverage/misc.py @@ -1,5 +1,9 @@ """Miscellaneous stuff for Coverage.""" +import inspect +from coverage.backward import md5, string_class, to_bytes + + def nice_pair(pair): """Make a nice string representation of a pair of numbers. @@ -68,6 +72,41 @@ def bool_or_none(b): return bool(b) +class Hasher(object): + """Hashes Python data into md5.""" + def __init__(self): + self.md5 = md5() + + def update(self, v): + """Add `v` to the hash, recursively if needed.""" + self.md5.update(to_bytes(str(type(v)))) + if isinstance(v, string_class): + self.md5.update(to_bytes(v)) + elif isinstance(v, (int, float)): + self.update(str(v)) + elif isinstance(v, (tuple, list)): + for e in v: + self.update(e) + elif isinstance(v, dict): + keys = v.keys() + for k in sorted(keys): + self.update(k) + self.update(v[k]) + else: + for k in dir(v): + if k.startswith('__'): + continue + a = getattr(v, k) + if inspect.isroutine(a): + continue + self.update(k) + self.update(a) + + def digest(self): + """Retrieve the digest of the hash.""" + return self.md5.digest() + + class CoverageException(Exception): """An exception specific to Coverage.""" pass |