/usr/share/pyshared/dput/configs/dputcf.py is in python-dput 1.7.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 | # -*- coding: utf-8 -*-
# vim: tabstop=4 expandtab shiftwidth=4 softtabstop=4
# Copyright (c) 2012 dput authors
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
# General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
# 02110-1301, USA.
"""
Old dput config file implementation
"""
import os
import sys
if sys.version_info[0] >= 3:
import configparser
else:
import ConfigParser as configparser
import dput.core
from dput.config import AbstractConfig
from dput.core import logger
from dput.exceptions import DputConfigurationError
class DputCfConfig(AbstractConfig):
"""
dput-old config file implementation. Subclass of a
:class:`dput.config.AbstractConfig`.
"""
def preload(self, configs):
"""
See :meth:`dput.config.AbstractConfig.preload`
"""
parser = configparser.ConfigParser()
if configs is None:
configs = dput.core.DPUT_CONFIG_LOCATIONS
for config in configs:
if not os.access(config, os.R_OK):
logger.debug("Skipping file %s: Not accessible" % (
config
))
continue
try:
logger.trace("Parsing %s" % (config))
parser.readfp(open(config, 'r'))
except IOError as e:
logger.warning("Skipping file %s: %s" % (
config,
e
))
continue
except configparser.ParsingError as e:
raise DputConfigurationError("Error parsing file %s: %s" % (
config,
e
))
self.parser = parser
self.configs = configs
self.defaults = self._translate_strs(self.get_config("DEFAULT"))
self.parser.remove_section("DEFAULT")
def set_replacements(self, replacements):
"""
See :meth:`dput.config.AbstractConfig.set_replacements`
"""
for replacement in replacements:
if self.parser.has_section(replacement):
self.parser.set(replacement,
replacement,
replacements[replacement])
def get_config_blocks(self):
"""
See :meth:`dput.config.AbstractConfig.get_config_blocks`
"""
return self.parser.sections()
def get_defaults(self):
"""
See :meth:`dput.config.AbstractConfig.get_defaults`
"""
return self.defaults
def _translate_strs(self, ret):
trans = {
"1": True,
"0": False
}
ret = self._translate_dict(ret, trans)
return ret
def _translate_bools(self, ret):
trans = {
True: "1",
False: "0"
}
return self._translate_dict(ret, trans)
def _translate_dict(self, ret, trans):
if isinstance(ret, dict):
ret = ret.copy()
elif isinstance(ret, list):
ret = ret[:]
for key in ret:
val = ret[key]
if isinstance(val, dict) or isinstance(val, list):
ret[key] = self._translate_dict(val, trans)
continue
if val in trans:
val = trans[val]
ret[key] = val
return ret
def get_config(self, name, ignore_errors=False):
"""
See :meth:`dput.config.AbstractConfig.get_config`
"""
ret = {}
try:
items = self.parser.items(name)
except configparser.NoSectionError:
return {}
for key, val in items:
ret[key] = val
ret['name'] = name
ret = self._translate_strs(ret)
return ret
|