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

  • Committer: Tim Marston
  • Date: 2016-02-16 00:26:53 UTC
  • Revision ID: tim@ed.am-20160216002653-oa8dgponknyislg3
added home directory change reporting to CopyOutWalker; added --quiet option to
update, resolve, revert and init commands; replace use of re.match with
re.search for clarity (and fixed related bug in FileMatcher); added BzrVcs.run
command output when verbose >= 2

Show diffs side-by-side

added added

removed removed

19
19
# along with this program.  If not, see <http://www.gnu.org/licenses/>.
20
20
 
21
21
 
22
 
import filecmp, os, shutil
 
22
import re
23
23
from copy_base import CopyBaseWalker
24
24
import stdhome.the as the
 
25
from stdhome.file_matcher import FileMatcher
25
26
 
26
27
 
27
28
class CopyOutWalker( CopyBaseWalker ):
28
29
        """The copy-out walker traverses the repo, copying its content to the home
29
 
        directory.  It is run *after* checking for conflicts that might occur during
30
 
        copy-out, so any conflicts that exist can be assumed to be unimportant and
31
 
        disposable.  In other words, this will happily overwrite stuff in the home
32
 
        directory, without regard to its content.
 
30
        directory.  During an update, it is run *after* checking for conflicts that
 
31
        might occur during copy-out, so any conflicts that exist can be assumed to
 
32
        be unimportant and disposable.  In other words, this will happily overwrite
 
33
        stuff in the home directory, without regard to its content.
33
34
 
34
35
        Walker source:       repo
35
36
        Walker destination:  home dir
37
38
                                                        that no longer exists in the repo
38
39
        """
39
40
 
40
 
        def __init__( self, updated_files = None ):
 
41
        def __init__( self, walk_files = None, quiet = False ):
 
42
                CopyBaseWalker.__init__( self )
41
43
                self.src_dir = the.repo.full_dir
42
44
                self.dst_dir = the.full_home_dir
43
 
                self.walk_list = updated_files if updated_files is not None else \
44
 
                                                 self.generate_walk_list( the.repo.full_dir )
45
 
 
46
 
 
47
 
        def print_cp( self, rel_file, src_type, dst_type, operation = '<' ):
48
 
                if( the.verbose <= 1 ): return
49
 
                print "  %s%s%s %s" % ( dst_type, operation, src_type, rel_file )
 
45
                self.walk_list = walk_files if walk_files is not None else \
 
46
                                                 self.generate_walk_list()
 
47
                self.check_dst_symlinks = True
 
48
                self.check_dst_ignores = True
 
49
                self.quiet = quiet
 
50
 
 
51
 
 
52
        def print_op( self, rel_file, src, op, dst ):
 
53
 
 
54
                # report changes
 
55
                if not self.quiet and the.verbose < 2 and op == '*':
 
56
                        if dst == '_':
 
57
                                print " N  %s" % ( rel_file )
 
58
                        elif src == '_':
 
59
                                print " D  %s" % ( rel_file )
 
60
                        elif src == dst:
 
61
                                print " M  %s" % ( rel_file )
 
62
                        else:
 
63
                                print " K  %s" % ( rel_file )
 
64
 
 
65
                # verbose reporting
 
66
                if the.verbose >= 2:
 
67
                        if op == '*': op = '<'
 
68
                        print "  %s%s%s %s" % ( src, op, dst, rel_file )