53
57
self._to_file.write('adding %s\n' % _quote(path))
60
def skip_file(self, tree, path, kind, stat_value = None):
61
"""Test whether the given file should be skipped or not.
63
The default action never skips. Note this is only called during
66
:param tree: The tree we are working in
67
:param path: The path being added
68
:param kind: The kind of object being added.
69
:param stat: Stat result for this file, if available already
70
:return bool. True if the file should be skipped (not added)
75
class AddWithSkipLargeAction(AddAction):
76
"""A class that can decide to skip a file if it's considered too large"""
80
def skip_file(self, tree, path, kind, stat_value = None):
83
opt_name = 'add.maximum_file_size'
84
if self._maxSize is None:
85
config = tree.get_config_stack()
86
self._maxSize = config.get(opt_name)
87
if stat_value is None:
88
file_size = os.path.getsize(path);
90
file_size = stat_value.st_size;
91
if self._maxSize > 0 and file_size > self._maxSize:
92
ui.ui_factory.show_warning(gettext(
93
"skipping {0} (larger than {1} of {2} bytes)").format(
94
path, opt_name, self._maxSize))
57
99
class AddFromBaseAction(AddAction):
58
100
"""This class will try to extract file ids from another tree."""
89
131
if self.base_tree.has_id(parent_ie.file_id):
90
base_parent_ie = self.base_tree.inventory[parent_ie.file_id]
132
# FIXME: Handle nested trees
133
base_parent_ie = self.base_tree.root_inventory[parent_ie.file_id]
91
134
base_child_ie = base_parent_ie.children.get(
92
135
osutils.basename(path))
93
136
if base_child_ie is not None: