/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/ignores.py

  • Committer: Martin Pool
  • Date: 2010-04-27 07:52:08 UTC
  • mto: This revision was merged to the branch mainline in revision 5192.
  • Revision ID: mbp@sourcefrog.net-20100427075208-nc9uf6jgwlyy5r3k
Add osutils.rename that includes the relevant filenames

Show diffs side-by-side

added added

removed removed

Lines of Context:
17
17
"""Lists of ignore files, etc."""
18
18
 
19
19
import errno
20
 
import os
21
 
from cStringIO import StringIO
22
20
 
23
21
import bzrlib
24
22
from bzrlib import (
178
176
 
179
177
 
180
178
def tree_ignores_add_patterns(tree, name_pattern_list):
181
 
    """Add more ignore patterns to the ignore file in a tree.
182
 
    If ignore file does not exist then it will be created.
183
 
    The ignore file will be automatically added under version control.
 
179
    """Retrieve a list of ignores from the ignore file in a tree.
184
180
 
185
 
    :param tree: Working tree to update the ignore list.
186
 
    :param name_pattern_list: List of ignore patterns.
187
 
    :return: None
 
181
    :param tree: Tree to retrieve the ignore list from.
 
182
    :return:
188
183
    """
189
 
    # read in the existing ignores set
190
184
    ifn = tree.abspath(bzrlib.IGNORE_FILENAME)
191
185
    if tree.has_filename(ifn):
192
 
        f = open(ifn, 'rU')
 
186
        f = open(ifn, 'rt')
193
187
        try:
194
 
            file_contents = f.read()
195
 
            # figure out what kind of line endings are used
196
 
            newline = getattr(f, 'newlines', None)
197
 
            if type(newline) is tuple:
198
 
                newline = newline[0]
199
 
            elif newline is None:
200
 
                newline = os.linesep
 
188
            igns = f.read().decode('utf-8')
201
189
        finally:
202
190
            f.close()
203
191
    else:
204
 
        file_contents = ""
205
 
        newline = os.linesep
206
 
    
207
 
    sio = StringIO(file_contents)
208
 
    try:
209
 
        ignores = parse_ignore_file(sio)
210
 
    finally:
211
 
        sio.close()
212
 
    
213
 
    # write out the updated ignores set
 
192
        igns = ""
 
193
 
 
194
    # TODO: If the file already uses crlf-style termination, maybe
 
195
    # we should use that for the newly added lines?
 
196
 
 
197
    if igns and igns[-1] != '\n':
 
198
        igns += '\n'
 
199
    for name_pattern in name_pattern_list:
 
200
        igns += name_pattern + '\n'
 
201
 
214
202
    f = atomicfile.AtomicFile(ifn, 'wb')
215
203
    try:
216
 
        # write the original contents, preserving original line endings
217
 
        f.write(newline.join(file_contents.split('\n')))
218
 
        if len(file_contents) > 0 and not file_contents.endswith('\n'):
219
 
            f.write(newline)
220
 
        for pattern in name_pattern_list:
221
 
            if not pattern in ignores:
222
 
                f.write(pattern.encode('utf-8'))
223
 
                f.write(newline)
 
204
        f.write(igns.encode('utf-8'))
224
205
        f.commit()
225
206
    finally:
226
207
        f.close()
227
208
 
228
 
    if not tree.path2id(bzrlib.IGNORE_FILENAME):
229
 
        tree.add([bzrlib.IGNORE_FILENAME])
 
209
    if not tree.path2id('.bzrignore'):
 
210
        tree.add(['.bzrignore'])