1
0
Fork 0
mirror of https://github.com/borgbackup/borg.git synced 2024-12-25 09:19:31 +00:00

Added new option "--do-not-cross-mountpoints"

This commit is contained in:
Jonas Borgström 2012-02-04 17:32:46 +01:00
parent b755a4f2b9
commit c4e022a7fc

View file

@ -88,7 +88,15 @@ def do_create(self, args):
except IOError:
pass
for path in args.paths:
self._process(archive, cache, args.patterns, skip_inodes, path)
if args.dontcross:
try:
restrict_dev = os.lstat(path).st_dev
except OSError, e:
self.print_error('%s: %s', path, e)
continue
else:
restrict_dev = None
self._process(archive, cache, args.patterns, skip_inodes, path, restrict_dev)
archive.save()
if args.stats:
t = datetime.now()
@ -103,7 +111,7 @@ def do_create(self, args):
print '-' * 40
return self.exit_code
def _process(self, archive, cache, patterns, skip_inodes, path):
def _process(self, archive, cache, patterns, skip_inodes, path, restrict_dev):
if exclude_path(path, patterns):
return
try:
@ -113,6 +121,9 @@ def _process(self, archive, cache, patterns, skip_inodes, path):
return
if (st.st_ino, st.st_dev) in skip_inodes:
return
# Entering a new filesystem?
if restrict_dev and st.st_dev != restrict_dev:
return
# Ignore unix sockets
if stat.S_ISSOCK(st.st_mode):
return
@ -126,7 +137,7 @@ def _process(self, archive, cache, patterns, skip_inodes, path):
else:
for filename in sorted(entries):
self._process(archive, cache, patterns, skip_inodes,
os.path.join(path, filename))
os.path.join(path, filename), restrict_dev)
elif stat.S_ISLNK(st.st_mode):
archive.process_symlink(path, st)
elif stat.S_ISFIFO(st.st_mode):
@ -333,6 +344,9 @@ def run(self, args=None):
subparser.add_argument('-c', '--checkpoint-interval', dest='checkpoint_interval',
type=int, default=300, metavar='SECONDS',
help='Write checkpointe ever SECONDS seconds (Default: 300)')
subparser.add_argument('--do-not-cross-mountpoints', dest='dontcross',
action='store_true', default=False,
help='Do not cross mount points')
subparser.add_argument('archive', metavar='ARCHIVE',
type=location_validator(archive=True),
help='Archive to create')