/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-18 14:42:00 UTC
  • Revision ID: tim@ed.am-20140418144200-ksbr3l58p2v3jhy2
fixed bugs in command.expand_files, where results could be not unique, nor
sorted, and make sure the last component of the files is not resolved if it is a
symlink

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
from stdhome.file_matcher import FileMatcher
 
26
 
 
27
 
 
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.
 
34
 
 
35
        Walker source:       repo
 
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
 
39
 
 
40
        """
 
41
 
 
42
        def __init__( self, walk_files = None ):
 
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( the.repo.full_dir )
 
47
 
 
48
                self.accept_list = FileMatcher( the.config_file, 'symlink' )
 
49
 
 
50
 
 
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 )