summaryrefslogtreecommitdiff
path: root/coverage/collector.py
diff options
context:
space:
mode:
authorNed Batchelder <ned@nedbatchelder.com>2015-08-01 08:00:02 -0400
committerNed Batchelder <ned@nedbatchelder.com>2015-08-01 08:00:02 -0400
commit7756e176258fb96525f1e90ee4995c65b099b81a (patch)
tree70802f124cea75d5d86cae5b7e0a834bf24b7fe4 /coverage/collector.py
parent0f9869802b1504df0479dd467cd9d1b8ca2de4c6 (diff)
downloadpython-coveragepy-7756e176258fb96525f1e90ee4995c65b099b81a.tar.gz
Implement FileDisposition in C for speed. Final part of fix for #387.
Diffstat (limited to 'coverage/collector.py')
-rw-r--r--coverage/collector.py14
1 files changed, 12 insertions, 2 deletions
diff --git a/coverage/collector.py b/coverage/collector.py
index b8e0841..ae5f6c8 100644
--- a/coverage/collector.py
+++ b/coverage/collector.py
@@ -13,7 +13,7 @@ from coverage.pytracer import PyTracer
try:
# Use the C extension code when we can, for speed.
- from coverage.tracer import CTracer # pylint: disable=no-name-in-module
+ from coverage.tracer import CTracer, CFileDisposition # pylint: disable=no-name-in-module
except ImportError:
# Couldn't import the C extension, maybe it isn't built.
if os.getenv('COVERAGE_TEST_TRACER') == 'c':
@@ -30,6 +30,11 @@ except ImportError:
CTracer = None
+class FileDisposition(object):
+ """A simple value type for recording what to do with a file."""
+ pass
+
+
class Collector(object):
"""Collects trace data.
@@ -124,7 +129,12 @@ class Collector(object):
# trace function.
self._trace_class = CTracer or PyTracer
- self.supports_plugins = self._trace_class is CTracer
+ if self._trace_class is CTracer:
+ self.file_disposition_class = CFileDisposition
+ self.supports_plugins = True
+ else:
+ self.file_disposition_class = FileDisposition
+ self.supports_plugins = False
def __repr__(self):
return "<Collector at 0x%x>" % id(self)