/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: 2014-04-05 22:27:09 UTC
  • Revision ID: tim@ed.am-20140405222709-4mp50aiu184blnf1
fixed file_matcher

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# copy_out.py
 
2
#
 
3
# Copyright (C) 2013 to 2014 Tim Marston <tim@edm.am>
 
4
#
 
5
# This file is part of stdhome (hereafter referred to as "this program").
 
6
# See http://ed.am/dev/stdhome for more information.
 
7
#
 
8
# This program is free software: you can redistribute it and/or modify
 
9
# it under the terms of the GNU General Public License as published by
 
10
# the Free Software Foundation, either version 3 of the License, or
 
11
# (at your option) any later version.
 
12
#
 
13
# This program is distributed in the hope that it will be useful,
 
14
# but WITHOUT ANY WARRANTY; without even the implied warranty of
 
15
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
16
# GNU General Public License for more details.
 
17
#
 
18
# You should have received a copy of the GNU General Public License
 
19
# along with this program.  If not, see <http://www.gnu.org/licenses/>.
 
20
 
 
21
 
 
22
import re
 
23
from copy_base import CopyBaseWalker
 
24
import stdhome.the as the
 
25
 
 
26
 
 
27
class CopyOutWalker( CopyBaseWalker ):
 
28
        """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.
 
33
 
 
34
        Walker source:       repo
 
35
        Walker destination:  home dir
 
36
        Walker traversing:   repo (or a provided file list, which may include stuff
 
37
                                                        that no longer exists in the repo
 
38
        """
 
39
 
 
40
        def __init__( self, updated_files = None ):
 
41
                self.src_dir = the.repo.full_dir
 
42
                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_op( self, rel_file, operation ):
 
48
                operation = re.sub( r'(.)(.)(.)', r'\3\2\1', operation )
 
49
                operation = re.sub( r'\>', r'<', operation )
 
50
                print "  %s %s" % ( operation, rel_file )