/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-03-08 00:47:23 UTC
  • Revision ID: tim@ed.am-20140308004723-hkl3s2hobsblf72o
added diff command; moved all command to commands subdir; made stage-revert
handle ongoing deployment automatically (now that initial revno is known); made
verbose level incremental; detect obstructing conflicts in ConflictWalker;
handle files deleted from repo during copy-out (update)

Show diffs side-by-side

added added

removed removed

1
 
# conflict_walker.py
 
1
# conflict.py
2
2
#
3
3
# Copyright (C) 2013 to 2014 Tim Marston <tim@edm.am>
4
4
#
19
19
# along with this program.  If not, see <http://www.gnu.org/licenses/>.
20
20
 
21
21
 
 
22
import filecmp, os
22
23
from walker import Walker
23
24
import stdhome.the as the
24
25
 
37
38
 
38
39
        def __init__( self, ignore_files, affected_files = None ):
39
40
                self.src_dir = the.repo.full_dir
40
 
                self.dst_dir = the.full_fsdir
 
41
                self.dst_dir = the.full_home_dir
41
42
                self.walk_list = affected_files if affected_files is not None else \
42
43
                                                 self.generate_walk_list( the.repo.full_dir )
43
44
 
44
45
                self.ignore_files = ignore_files
45
46
                self.changed = list()
 
47
                self.obstructed = list()
46
48
 
47
49
 
48
50
        def process( self, rel_file, src_file, src_type, dst_file, dst_type ):
52
54
                if dst_type == '_': return False
53
55
 
54
56
                # if entity was copied-in, it's ok to copy out
55
 
                if rel_file in self.ignore_files:
 
57
                elif rel_file in self.ignore_files:
 
58
 
56
59
                        # we recurse only if this is a directory in the home dir, because if
57
60
                        # it isn't copying-out will replace whatever's in the home dir with
58
61
                        # the whole directory from the repo
67
70
                        # anything that directory does/did contain
68
71
                        return False
69
72
 
 
73
                # entity is a file (that wasn't copyied-in)?
 
74
                elif dst_type == 'f':
 
75
 
 
76
                        # only aproblem if its content is different
 
77
                        if not filecmp.cmp( src_file, dst_file ):
 
78
                                self.obstructed.append( rel_file )
 
79
                                return False
 
80
 
 
81
                # entity is a symlink (that wasn't copied-in)?
 
82
                if dst_type == 'l':
 
83
 
 
84
                        # only a problem if the symlink is different
 
85
                        if os.readlink( src_file ) != os.readlink( dst_file ):
 
86
                                self.obstructed.append( rel_file )
 
87
                                return False
 
88
 
70
89
                # nothing to see here
71
90
                return True