~bzr-pqm/bzr/bzr.dev

1836.1.12 by John Arbash Meinel
Move ignores into a file of their own, make DEFAULT_IGNORE a deprecated list. Create deprecated_list in symbol versioning.
1
# Copyright (C) 2005, 2006 Canonical Development Ltd
2
#
3
# This program is free software; you can redistribute it and/or modify
4
# it under the terms of the GNU General Public License as published by
5
# the Free Software Foundation; either version 2 of the License, or
6
# (at your option) any later version.
7
#
8
# This program is distributed in the hope that it will be useful,
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11
# GNU General Public License for more details.
12
#
13
# You should have received a copy of the GNU General Public License
14
# along with this program; if not, write to the Free Software
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16
17
"""Lists of ignore files, etc."""
18
1836.1.13 by John Arbash Meinel
Adding functions for getting user ignores.
19
import errno
20
21
from bzrlib import config
22
1836.1.12 by John Arbash Meinel
Move ignores into a file of their own, make DEFAULT_IGNORE a deprecated list. Create deprecated_list in symbol versioning.
23
# This was the full ignore list for bzr 0.8
24
# please keep these sorted (in C locale order) to aid merging
25
OLD_DEFAULTS = [
26
    '#*#',
27
    '*$',
28
    '*,v',
29
    '*.BAK',
30
    '*.a',
31
    '*.bak',
32
    '*.elc',
33
    '*.exe',
34
    '*.la',
35
    '*.lo',
36
    '*.o',
37
    '*.obj',
38
    '*.orig',
39
    '*.py[oc]',
40
    '*.so',
41
    '*.tmp',
42
    '*~',
43
    '.#*',
44
    '.*.sw[nop]',
45
    '.*.tmp',
46
    # Our setup tests dump .python-eggs in the bzr source tree root
47
    './.python-eggs',
48
    '.DS_Store',
49
    '.arch-ids',
50
    '.arch-inventory',
51
    '.bzr.log',
52
    '.del-*',
53
    '.git',
54
    '.hg',
55
    '.jamdeps'
56
    '.libs',
57
    '.make.state',
58
    '.sconsign*',
59
    '.svn',
60
    '.sw[nop]',    # vim editing nameless file
61
    '.tmp*',
62
    'BitKeeper',
63
    'CVS',
64
    'CVS.adm',
65
    'RCS',
66
    'SCCS',
67
    'TAGS',
68
    '_darcs',
69
    'aclocal.m4',
70
    'autom4te*',
71
    'config.h',
72
    'config.h.in',
73
    'config.log',
74
    'config.status',
75
    'config.sub',
76
    'stamp-h',
77
    'stamp-h.in',
78
    'stamp-h1',
79
    '{arch}',
80
]
81
82
83
# ~/.bazaar/ignore will be filled out using
84
# this ignore list, if it does not exist
85
# please keep these sorted (in C locale order) to aid merging
86
USER_DEFAULTS = [
87
    '*.a',
88
    '*.o',
89
    '*.py[co]',
90
    '*.so',
91
    '*.sw[nop]',
92
    '*~',
93
    '.#*',
94
    '[#]*#',
95
]
1836.1.13 by John Arbash Meinel
Adding functions for getting user ignores.
96
97
98
def parse_ignore_file(f):
99
    """Read in all of the lines in the file and turn it into an ignore list"""
1836.1.30 by John Arbash Meinel
Change ignore functions to use sets instead of lists.
100
    ignored = set()
1836.1.13 by John Arbash Meinel
Adding functions for getting user ignores.
101
    for line in f.read().decode('utf8').split('\n'):
102
        line = line.rstrip('\r\n')
103
        if not line or line.startswith('#'):
104
            continue
1836.1.30 by John Arbash Meinel
Change ignore functions to use sets instead of lists.
105
        ignored.add(line)
1836.1.13 by John Arbash Meinel
Adding functions for getting user ignores.
106
    return ignored
107
108
109
def get_user_ignores():
110
    """Get the list of user ignored files, possibly creating it."""
111
    path = config.user_ignore_config_filename()
1836.1.30 by John Arbash Meinel
Change ignore functions to use sets instead of lists.
112
    patterns = set(USER_DEFAULTS)
1836.1.13 by John Arbash Meinel
Adding functions for getting user ignores.
113
    try:
114
        f = open(path, 'rb')
115
    except (IOError, OSError), e:
1836.1.25 by John Arbash Meinel
cleanups suggested by Martin.
116
        # open() shouldn't return an IOError without errno, but just in case
117
        err = getattr(e, 'errno', None)
118
        if err not in (errno.ENOENT,):
1836.1.13 by John Arbash Meinel
Adding functions for getting user ignores.
119
            raise
120
        # Create the ignore file, and just return the default
1836.1.15 by John Arbash Meinel
Updated WorkingTree to use the new user-level ignores.
121
        # We want to ignore if we can't write to the file
122
        # since get_* should be a safe operation
123
        try:
1836.1.31 by John Arbash Meinel
Make set_user_ignores a private function, and update the doc string to recommend it isn't used.
124
            _set_user_ignores(USER_DEFAULTS)
1836.1.15 by John Arbash Meinel
Updated WorkingTree to use the new user-level ignores.
125
        except (IOError, OSError), e:
126
            if e.errno not in (errno.EPERM,):
127
                raise
1836.1.13 by John Arbash Meinel
Adding functions for getting user ignores.
128
        return patterns
129
130
    try:
131
        return parse_ignore_file(f)
132
    finally:
133
        f.close()
1836.1.14 by John Arbash Meinel
Adding a helper function that will only add patterns if they are missing.
134
135
1836.1.31 by John Arbash Meinel
Make set_user_ignores a private function, and update the doc string to recommend it isn't used.
136
def _set_user_ignores(patterns):
1836.1.15 by John Arbash Meinel
Updated WorkingTree to use the new user-level ignores.
137
    """Fill out the user ignore file with the given patterns
138
139
    This may raise an error if it doesn't have permission to
140
    write to the user ignore file.
1836.1.31 by John Arbash Meinel
Make set_user_ignores a private function, and update the doc string to recommend it isn't used.
141
    This is mostly used for testing, since it would be
142
    bad form to rewrite a user's ignore list.
143
    bzrlib only writes this file if it does not exist.
1836.1.15 by John Arbash Meinel
Updated WorkingTree to use the new user-level ignores.
144
    """
145
    ignore_path = config.user_ignore_config_filename()
146
    config.ensure_config_dir_exists()
147
148
    # Create an empty file
149
    f = open(ignore_path, 'wb')
150
    try:
151
        for pattern in patterns:
152
            f.write(pattern.encode('utf8') + '\n')
153
    finally:
154
        f.close()
155
156
1836.1.14 by John Arbash Meinel
Adding a helper function that will only add patterns if they are missing.
157
def add_unique_user_ignores(new_ignores):
158
    """Add entries to the user's ignore list if not present.
159
160
    :param new_ignores: A list of ignore patterns
161
    :return: The list of ignores that were added
162
    """
1836.1.30 by John Arbash Meinel
Change ignore functions to use sets instead of lists.
163
    ignored = get_user_ignores()
1836.1.14 by John Arbash Meinel
Adding a helper function that will only add patterns if they are missing.
164
    to_add = []
165
    for ignore in new_ignores:
166
        if ignore not in ignored:
167
            ignored.add(ignore)
168
            to_add.append(ignore)
169
170
    if not to_add:
171
        return []
172
173
    f = open(config.user_ignore_config_filename(), 'ab')
174
    try:
175
        for pattern in to_add:
176
            f.write(pattern.encode('utf8') + '\n')
177
    finally:
178
        f.close()
179
180
    return to_add
1836.1.28 by John Arbash Meinel
Add a function for adding runtime ignores.
181
182
183
_runtime_ignores = set()
184
185
186
def add_runtime_ignores(ignores):
187
    """Add some ignore patterns that only exists in memory.
188
189
    This is used by some plugins that want bzr to ignore files,
190
    but don't want to change a users ignore list.
1711.2.105 by John Arbash Meinel
Updated doc
191
    (Such as a conversion script that needs to ignore temporary files,
192
    but does not want to modify the project's ignore list.)
1836.1.28 by John Arbash Meinel
Add a function for adding runtime ignores.
193
194
    :param ignores: A list or generator of ignore patterns.
195
    :return: None
196
    """
197
    global _runtime_ignores
198
    _runtime_ignores.update(set(ignores))
199
200
201
def get_runtime_ignores():
202
    """Get the current set of runtime ignores."""
203
    return _runtime_ignores