/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: Robert Collins
  • Date: 2010-06-25 20:34:05 UTC
  • mto: This revision was merged to the branch mainline in revision 5324.
  • Revision ID: robertc@robertcollins.net-20100625203405-c74lxd3enklhaqf9
``bzrlib.osutils.get_terminal_encoding`` will now only mutter its
selection when explicitly requested; this avoids many duplicate calls
being logged when helpers, wrappers and older code that manually calls
it are executed it is now logged deliberately by the ui setup code.
(Robert Collins)

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
20
22
 
21
23
import bzrlib
22
24
from bzrlib import (
181
183
    The ignore file will be automatically added under version control.
182
184
 
183
185
    :param tree: Working tree to update the ignore list.
 
186
    :param name_pattern_list: List of ignore patterns.
 
187
    :return: None
184
188
    """
 
189
    # read in the existing ignores set
185
190
    ifn = tree.abspath(bzrlib.IGNORE_FILENAME)
186
191
    if tree.has_filename(ifn):
187
 
        f = open(ifn, 'rt')
 
192
        f = open(ifn, 'rU')
188
193
        try:
189
 
            igns = f.read().decode('utf-8')
 
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
190
201
        finally:
191
202
            f.close()
192
203
    else:
193
 
        igns = ""
194
 
 
195
 
    # TODO: If the file already uses crlf-style termination, maybe
196
 
    # we should use that for the newly added lines?
197
 
 
198
 
    if igns and igns[-1] != '\n':
199
 
        igns += '\n'
200
 
    for name_pattern in name_pattern_list:
201
 
        igns += name_pattern + '\n'
202
 
 
 
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
203
214
    f = atomicfile.AtomicFile(ifn, 'wb')
204
215
    try:
205
 
        f.write(igns.encode('utf-8'))
 
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)
206
224
        f.commit()
207
225
    finally:
208
226
        f.close()