3
# Copyright (C) 2013 to 2014 Tim Marston <tim@edm.am>
5
# This file is part of stdhome (hereafter referred to as "this program").
6
# See http://ed.am/dev/stdhome for more information.
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.
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.
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/>.
23
from copy_base import CopyBaseWalker
24
import stdhome.the as the
25
from stdhome.file_matcher import FileMatcher
28
class CopyOutWalker( CopyBaseWalker ):
29
"""The copy-out walker traverses the repo, copying its content to the home
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.
36
Walker destination: home dir
37
Walker traversing: repo (or a provided file list, which may include stuff
38
that no longer exists in the repo
41
def __init__( self, walk_files = None ):
42
CopyBaseWalker.__init__( self )
43
self.src_dir = the.repo.full_dir
44
self.dst_dir = the.full_home_dir
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
51
def print_op( self, rel_file, operation ):
52
operation = re.sub( r'(.)(.)(.)', r'\3\2\1', operation )
53
operation = re.sub( r'\>', r'<', operation )
54
print " %s %s" % ( operation, rel_file )