/stdhome

To get this branch, use:
bzr branch http://bzr.ed.am/stdhome

« back to all changes in this revision

Viewing changes to lib/stdhome/walker/conflict.py

  • Committer: Tim Marston
  • Date: 2014-04-04 22:28:49 UTC
  • Revision ID: tim@ed.am-20140404222849-32apy1i949qaq2na
walker now passes Walker.File objects to process(), which includes file name,
type and the type of file it points to when it's a symlink

Show diffs side-by-side

added added

removed removed

47
47
                self.obstructed = list()
48
48
 
49
49
 
50
 
        def process( self, rel_file, src_file, src_type, dst_file, dst_type ):
 
50
        def process( self, rel_file, src, dst ):
51
51
 
52
52
                # if entity is missing in home dir, it's ok to copy out (and there's no
53
53
                # need to recurse)
54
 
                if dst_type == '_': return False
 
54
                if dst.type == '_': return False
55
55
 
56
56
                # if entity was copied-in, it's ok to copy out
57
57
                elif rel_file in self.ignore_files:
59
59
                        # we recurse only if this is a directory in the home dir, because if
60
60
                        # it isn't copying-out will replace whatever's in the home dir with
61
61
                        # the whole directory from the repo
62
 
                        return dst_type == 'd'
 
62
                        return dst.type == 'd'
63
63
 
64
64
                # entity has changed type?
65
 
                elif src_type != dst_type:
66
 
                        self.changed.append( "%s (now %s)" % (
67
 
                                rel_file, self.name_of_type( src_type ) ) )
 
65
                elif src.get_type_name() != dst.get_type_name():
 
66
                        self.changed.append( "%s (%s => %s)" % (
 
67
                                rel_file, src.get_type_name(), dst.get_type_name() ) )
68
68
 
69
69
                        # if an entity has changed to/from a directory, we don't care about
70
70
                        # anything that directory does/did contain
71
71
                        return False
72
72
 
73
73
                # entity is a file (that wasn't copyied-in)?
74
 
                elif dst_type == 'f':
 
74
                elif dst.type == 'f':
75
75
 
76
 
                        # only aproblem if its content is different
77
 
                        if not filecmp.cmp( src_file, dst_file ):
 
76
                        # only a problem if its content is different
 
77
                        if not filecmp.cmp( src.file, dst.file ):
78
78
                                self.obstructed.append( rel_file )
79
79
                                return False
80
80
 
81
81
                # entity is a symlink (that wasn't copied-in)?
82
 
                if dst_type == 'l':
 
82
                if dst.type == 'l':
83
83
 
84
84
                        # only a problem if the symlink is different
85
 
                        if os.readlink( src_file ) != os.readlink( dst_file ):
 
85
                        if os.readlink( src.file ) != os.readlink( dst.file ):
86
86
                                self.obstructed.append( rel_file )
87
87
                                return False
88
88