/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

Viewing changes to bzrlib/rules.py

  • Committer: Andrew Bennetts
  • Date: 2008-08-12 14:53:26 UTC
  • mto: This revision was merged to the branch mainline in revision 3624.
  • Revision ID: andrew.bennetts@canonical.com-20080812145326-yx693x2jc4rcovb7
Move the notes on writing tests out of HACKING into a new file, and improve
them.

Many of the testing notes in the HACKING file were in duplicated in two places
in that file!  This change removes that duplication.  It also adds new sections
on “Where should I put a new test?” and “TestCase and its subclasses”, and
others like “Test feature dependencies” have been expanded.  The whole document
has generally been edited to be a bit more coherent. 

Show diffs side-by-side

added added

removed removed

Lines of Context:
12
12
#
13
13
# You should have received a copy of the GNU General Public License
14
14
# along with this program; if not, write to the Free Software
15
 
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
 
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16
16
 
17
17
"""Rule-based definition of preferences for selected files in selected branches.
18
18
 
21
21
 
22
22
from bzrlib import (
23
23
    config,
24
 
    cmdline,
25
24
    errors,
26
25
    globbing,
27
26
    osutils,
36
35
FILE_PREFS_PREFIX = 'name '
37
36
FILE_PREFS_PREFIX_LEN = len(FILE_PREFS_PREFIX)
38
37
 
39
 
# The object providing default rules
40
 
_per_user_searcher = None
41
 
 
42
38
 
43
39
class _RulesSearcher(object):
44
40
    """An object that provides rule-based preferences."""
77
73
        options = {'encoding': 'utf-8'}
78
74
        self._cfg = configobj.ConfigObj(inifile, options=options)
79
75
        sections = self._cfg.keys()
80
 
        patterns = []
81
 
        self.pattern_to_section = {}
82
 
        for s in sections:
83
 
            if s.startswith(FILE_PREFS_PREFIX):
84
 
                file_patterns = cmdline.split(s[FILE_PREFS_PREFIX_LEN:])
85
 
                patterns.extend(file_patterns)
86
 
                for fp in file_patterns:
87
 
                    self.pattern_to_section[fp] = s
 
76
        patterns = [s[FILE_PREFS_PREFIX_LEN:] for s in sections
 
77
            if s.startswith(FILE_PREFS_PREFIX)]
88
78
        if len(patterns) < len(sections):
89
79
            unknowns = [s for s in sections
90
80
                if not s.startswith(FILE_PREFS_PREFIX)]
102
92
        if pat is None:
103
93
            return ()
104
94
        else:
105
 
            all = self._cfg[self.pattern_to_section[pat]]
 
95
            all = self._cfg[FILE_PREFS_PREFIX + pat]
106
96
            return tuple(all.items())
107
97
 
108
98
    def get_selected_items(self, path, names):
113
103
        if pat is None:
114
104
            return ()
115
105
        else:
116
 
            all = self._cfg[self.pattern_to_section[pat]]
 
106
            all = self._cfg[FILE_PREFS_PREFIX + pat]
117
107
            return tuple((k, all.get(k)) for k in names)
118
108
 
119
109
 
148
138
    return osutils.pathjoin(config.config_dir(), 'rules')
149
139
 
150
140
 
151
 
def reset_rules():
152
 
    global _per_user_searcher
153
 
    _per_user_searcher = _IniBasedRulesSearcher(rules_filename())
154
 
 
155
 
reset_rules()
 
141
# The object providing default rules
 
142
_per_user_searcher = _IniBasedRulesSearcher(rules_filename())