From c2b779dc7c4f7669b04dfa9e02cbe15da77ac5f1 Mon Sep 17 00:00:00 2001 From: Ned Batchelder Date: Sat, 28 Nov 2009 14:01:13 -0500 Subject: Read a config file to get some of our configuration. --- coverage/config.py | 45 +++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 45 insertions(+) create mode 100644 coverage/config.py (limited to 'coverage/config.py') diff --git a/coverage/config.py b/coverage/config.py new file mode 100644 index 0000000..ca7bab6 --- /dev/null +++ b/coverage/config.py @@ -0,0 +1,45 @@ +"""Config file for coverage.py""" + +import ConfigParser, os + + +class CoverageConfig(object): + def __init__(self): + # Defaults. + self.cover_pylib = False + self.timid = False + self.branch = False + self.exclude_list = ['# *pragma[: ]*[nN][oO] *[cC][oO][vV][eE][rR]'] + + def from_environment(self, env_var): + # Timidity: for nose users, read an environment variable. This is a + # cheap hack, since the rest of the command line arguments aren't + # recognized, but it solves some users' problems. + env = os.environ.get(env_var, '') + if env: + self.timid = ('--timid' in env) + + def from_args(self, **kwargs): + for k, v in kwargs.items(): + if v is not None: + setattr(self, k, v) + + def from_file(self, *files): + cp = ConfigParser.RawConfigParser() + cp.read(files) + + if cp.has_option('run', 'timid'): + self.timid = cp.getboolean('run', 'timid') + if cp.has_option('run', 'cover_pylib'): + self.cover_pylib = cp.getboolean('run', 'cover_pylib') + if cp.has_option('run', 'branch'): + self.branch = cp.getboolean('run', 'branch') + if cp.has_option('report', 'exclude'): + self.exclude_list = filter(None, cp.get('report', 'exclude').split('\n')) + + +if __name__ == '__main__': + cc = CoverageConfig() + cc.from_file(".coveragerc", ".coverage.ini") + import pdb;pdb.set_trace() + print cc -- cgit v1.2.1 From 9936dd6b9fbeca3179dd554f5c9a8523478868c3 Mon Sep 17 00:00:00 2001 From: Ned Batchelder Date: Sat, 28 Nov 2009 16:59:58 -0500 Subject: Read .coveragerc by default. --- coverage/config.py | 11 +++-------- 1 file changed, 3 insertions(+), 8 deletions(-) (limited to 'coverage/config.py') diff --git a/coverage/config.py b/coverage/config.py index ca7bab6..0596cc0 100644 --- a/coverage/config.py +++ b/coverage/config.py @@ -35,11 +35,6 @@ class CoverageConfig(object): if cp.has_option('run', 'branch'): self.branch = cp.getboolean('run', 'branch') if cp.has_option('report', 'exclude'): - self.exclude_list = filter(None, cp.get('report', 'exclude').split('\n')) - - -if __name__ == '__main__': - cc = CoverageConfig() - cc.from_file(".coveragerc", ".coverage.ini") - import pdb;pdb.set_trace() - print cc + # Exclude is a list of lines, leave out the blank ones. + exclude_list = cp.get('report', 'exclude') + self.exclude_list = filter(None, exclude_list.split('\n')) -- cgit v1.2.1