~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/workingtree.py

  • Committer: Wouter van Heyst
  • Date: 2006-07-13 18:18:00 UTC
  • mfrom: (1863 +trunk)
  • mto: This revision was merged to the branch mainline in revision 1867.
  • Revision ID: larstiq@larstiq.dyndns.org-20060713181800-4e8c4f9326597d7f
[merge] bzr.dev 1863

Show diffs side-by-side

added added

removed removed

Lines of Context:
51
51
from time import time
52
52
import warnings
53
53
 
 
54
from bzrlib import bzrdir, errors, osutils, urlutils
54
55
from bzrlib.atomicfile import AtomicFile
55
56
from bzrlib.conflicts import Conflict, ConflictList, CONFLICT_SUFFIXES
56
 
import bzrlib.bzrdir as bzrdir
57
57
from bzrlib.decorators import needs_read_lock, needs_write_lock
58
 
import bzrlib.errors as errors
59
58
from bzrlib.errors import (BzrCheckError,
60
59
                           BzrError,
61
60
                           ConflictFormatError,
103
102
from bzrlib.trace import mutter, note
104
103
from bzrlib.transport import get_transport
105
104
from bzrlib.transport.local import LocalTransport
106
 
import bzrlib.urlutils as urlutils
107
105
import bzrlib.ui
108
106
import bzrlib.xml5
109
107
 
356
354
        :return: The WorkingTree that contains 'path', and the rest of path
357
355
        """
358
356
        if path is None:
359
 
            path = os.getcwdu()
 
357
            path = osutils.getcwd()
360
358
        control, relpath = bzrdir.BzrDir.open_containing(path)
361
359
 
362
360
        return control.open_workingtree(), relpath
768
766
                elif self.is_ignored(fp[1:]):
769
767
                    c = 'I'
770
768
                else:
771
 
                    c = '?'
 
769
                    # we may not have found this file, because of a unicode issue
 
770
                    f_norm, can_access = osutils.normalized_filename(f)
 
771
                    if f == f_norm or not can_access:
 
772
                        # No change, so treat this file normally
 
773
                        c = '?'
 
774
                    else:
 
775
                        # this file can be accessed by a normalized path
 
776
                        # check again if it is versioned
 
777
                        # these lines are repeated here for performance
 
778
                        f = f_norm
 
779
                        fp = from_dir_relpath + '/' + f
 
780
                        fap = from_dir_abspath + '/' + f
 
781
                        f_ie = inv.get_child(from_dir_id, f)
 
782
                        if f_ie:
 
783
                            c = 'V'
 
784
                        elif self.is_ignored(fp[1:]):
 
785
                            c = 'I'
 
786
                        else:
 
787
                            c = '?'
772
788
 
773
789
                fk = file_kind(fap)
774
790
 
1000
1016
 
1001
1017
            fl = []
1002
1018
            for subf in os.listdir(dirabs):
1003
 
                if (subf != '.bzr'
1004
 
                    and (subf not in dir_entry.children)):
1005
 
                    fl.append(subf)
 
1019
                if subf == '.bzr':
 
1020
                    continue
 
1021
                if subf not in dir_entry.children:
 
1022
                    subf_norm, can_access = osutils.normalized_filename(subf)
 
1023
                    if subf_norm != subf and can_access:
 
1024
                        if subf_norm not in dir_entry.children:
 
1025
                            fl.append(subf_norm)
 
1026
                    else:
 
1027
                        fl.append(subf)
1006
1028
            
1007
1029
            fl.sort()
1008
1030
            for subf in fl:
1079
1101
        if hasattr(self, '_ignorelist'):
1080
1102
            return self._ignorelist
1081
1103
 
1082
 
        l = bzrlib.DEFAULT_IGNORE[:]
 
1104
        l = []
1083
1105
        if self.has_filename(bzrlib.IGNORE_FILENAME):
1084
1106
            f = self.get_file_byname(bzrlib.IGNORE_FILENAME)
1085
1107
            l.extend([line.rstrip("\n\r").decode('utf-8') 
1432
1454
    def set_conflicts(self, arg):
1433
1455
        raise UnsupportedOperation(self.set_conflicts, self)
1434
1456
 
 
1457
    def add_conflicts(self, arg):
 
1458
        raise UnsupportedOperation(self.add_conflicts, self)
 
1459
 
1435
1460
    @needs_read_lock
1436
1461
    def conflicts(self):
1437
1462
        conflicts = ConflictList()
1497
1522
        self._put_rio('conflicts', conflicts.to_stanzas(), 
1498
1523
                      CONFLICT_HEADER_1)
1499
1524
 
 
1525
    @needs_write_lock
 
1526
    def add_conflicts(self, new_conflicts):
 
1527
        conflict_set = set(self.conflicts())
 
1528
        conflict_set.update(set(list(new_conflicts)))
 
1529
        self.set_conflicts(ConflictList(sorted(conflict_set,
 
1530
                                               key=Conflict.sort_key)))
 
1531
 
1500
1532
    @needs_read_lock
1501
1533
    def conflicts(self):
1502
1534
        try: