소스 검색

Merge pull request #759 from nachtgeist/public

refactor get_home_dir
TW 9 년 전
부모
커밋
15c20dcd37

+ 12 - 7
borg/helpers.py

@@ -213,19 +213,24 @@ class Statistics:
             print(msg, file=stream or sys.stderr, end="\r", flush=True)
             print(msg, file=stream or sys.stderr, end="\r", flush=True)
 
 
 
 
-def get_keys_dir():
-    """Determine where to repository keys and cache"""
-
+def get_home_dir():
+    """Get user's home directory while preferring a possibly set HOME
+    environment variable
+    """
     # os.path.expanduser() behaves differently for '~' and '~someuser' as
     # os.path.expanduser() behaves differently for '~' and '~someuser' as
     # parameters: when called with an explicit username, the possibly set
     # parameters: when called with an explicit username, the possibly set
     # environment variable HOME is no longer respected. So we have to check if
     # environment variable HOME is no longer respected. So we have to check if
     # it is set and only expand the user's home directory if HOME is unset.
     # it is set and only expand the user's home directory if HOME is unset.
     if os.environ.get('HOME', ''):
     if os.environ.get('HOME', ''):
-        home_dir = os.environ.get('HOME')
+        return os.environ.get('HOME')
     else:
     else:
-        home_dir = os.path.expanduser('~%s' % os.environ.get('USER'))
+        return os.path.expanduser('~%s' % os.environ.get('USER', ''))
+
+
+def get_keys_dir():
+    """Determine where to repository keys and cache"""
 
 
-    xdg_config = os.environ.get('XDG_CONFIG_HOME', os.path.join(home_dir, '.config'))
+    xdg_config = os.environ.get('XDG_CONFIG_HOME', os.path.join(get_home_dir(), '.config'))
     keys_dir = os.environ.get('BORG_KEYS_DIR', os.path.join(xdg_config, 'borg', 'keys'))
     keys_dir = os.environ.get('BORG_KEYS_DIR', os.path.join(xdg_config, 'borg', 'keys'))
     if not os.path.exists(keys_dir):
     if not os.path.exists(keys_dir):
         os.makedirs(keys_dir)
         os.makedirs(keys_dir)
@@ -235,7 +240,7 @@ def get_keys_dir():
 
 
 def get_cache_dir():
 def get_cache_dir():
     """Determine where to repository keys and cache"""
     """Determine where to repository keys and cache"""
-    xdg_cache = os.environ.get('XDG_CACHE_HOME', os.path.join(os.path.expanduser('~'), '.cache'))
+    xdg_cache = os.environ.get('XDG_CACHE_HOME', os.path.join(get_home_dir(), '.cache'))
     cache_dir = os.environ.get('BORG_CACHE_DIR', os.path.join(xdg_cache, 'borg'))
     cache_dir = os.environ.get('BORG_CACHE_DIR', os.path.join(xdg_cache, 'borg'))
     if not os.path.exists(cache_dir):
     if not os.path.exists(cache_dir):
         os.makedirs(cache_dir)
         os.makedirs(cache_dir)

+ 3 - 3
borg/remote.py

@@ -10,7 +10,7 @@ import tempfile
 
 
 from . import __version__
 from . import __version__
 
 
-from .helpers import Error, IntegrityError, sysinfo
+from .helpers import Error, IntegrityError, get_home_dir, sysinfo
 from .repository import Repository
 from .repository import Repository
 
 
 import msgpack
 import msgpack
@@ -108,8 +108,8 @@ class RepositoryServer:  # pragma: no cover
     def open(self, path, create=False, lock_wait=None, lock=True):
     def open(self, path, create=False, lock_wait=None, lock=True):
         path = os.fsdecode(path)
         path = os.fsdecode(path)
         if path.startswith('/~'):
         if path.startswith('/~'):
-            path = path[1:]
-        path = os.path.realpath(os.path.expanduser(path))
+            path = os.path.join(get_home_dir(), path[2:])
+        path = os.path.realpath(path)
         if self.restrict_to_paths:
         if self.restrict_to_paths:
             for restrict_to_path in self.restrict_to_paths:
             for restrict_to_path in self.restrict_to_paths:
                 if path.startswith(os.path.realpath(restrict_to_path)):
                 if path.startswith(os.path.realpath(restrict_to_path)):

+ 4 - 4
borg/upgrader.py

@@ -6,7 +6,7 @@ import os
 import shutil
 import shutil
 import time
 import time
 
 
-from .helpers import get_keys_dir, get_cache_dir, ProgressIndicatorPercent
+from .helpers import get_home_dir, get_keys_dir, get_cache_dir, ProgressIndicatorPercent
 from .locking import UpgradableLock
 from .locking import UpgradableLock
 from .repository import Repository, MAGIC
 from .repository import Repository, MAGIC
 from .key import KeyfileKey, KeyfileNotFoundError
 from .key import KeyfileKey, KeyfileNotFoundError
@@ -187,7 +187,7 @@ class AtticRepositoryUpgrader(Repository):
         """
         """
         # copy of attic's get_cache_dir()
         # copy of attic's get_cache_dir()
         attic_cache_dir = os.environ.get('ATTIC_CACHE_DIR',
         attic_cache_dir = os.environ.get('ATTIC_CACHE_DIR',
-                                         os.path.join(os.path.expanduser('~'),
+                                         os.path.join(get_home_dir(),
                                                       '.cache', 'attic'))
                                                       '.cache', 'attic'))
         attic_cache_dir = os.path.join(attic_cache_dir, hexlify(self.id).decode('ascii'))
         attic_cache_dir = os.path.join(attic_cache_dir, hexlify(self.id).decode('ascii'))
         borg_cache_dir = os.path.join(get_cache_dir(), hexlify(self.id).decode('ascii'))
         borg_cache_dir = os.path.join(get_cache_dir(), hexlify(self.id).decode('ascii'))
@@ -248,7 +248,7 @@ class AtticKeyfileKey(KeyfileKey):
     def get_keys_dir():
     def get_keys_dir():
         """Determine where to repository keys and cache"""
         """Determine where to repository keys and cache"""
         return os.environ.get('ATTIC_KEYS_DIR',
         return os.environ.get('ATTIC_KEYS_DIR',
-                              os.path.join(os.path.expanduser('~'), '.attic', 'keys'))
+                              os.path.join(get_home_dir(), '.attic', 'keys'))
 
 
     @classmethod
     @classmethod
     def find_key_file(cls, repository):
     def find_key_file(cls, repository):
@@ -308,7 +308,7 @@ class Borg0xxKeyfileKey(KeyfileKey):
     @staticmethod
     @staticmethod
     def get_keys_dir():
     def get_keys_dir():
         return os.environ.get('BORG_KEYS_DIR',
         return os.environ.get('BORG_KEYS_DIR',
-                              os.path.join(os.path.expanduser('~'), '.borg', 'keys'))
+                              os.path.join(get_home_dir(), '.borg', 'keys'))
 
 
     @classmethod
     @classmethod
     def find_key_file(cls, repository):
     def find_key_file(cls, repository):

+ 18 - 18
docs/api.rst

@@ -2,11 +2,11 @@
 API Documentation
 API Documentation
 =================
 =================
 
 
-.. automodule:: borg.archiver
+.. automodule:: borg.xattr
     :members:
     :members:
     :undoc-members:
     :undoc-members:
 
 
-.. automodule:: borg.upgrader
+.. automodule:: borg.hash_sizes
     :members:
     :members:
     :undoc-members:
     :undoc-members:
 
 
@@ -14,7 +14,7 @@ API Documentation
     :members:
     :members:
     :undoc-members:
     :undoc-members:
 
 
-.. automodule:: borg.fuse
+.. automodule:: borg.repository
     :members:
     :members:
     :undoc-members:
     :undoc-members:
 
 
@@ -22,55 +22,55 @@ API Documentation
     :members:
     :members:
     :undoc-members:
     :undoc-members:
 
 
-.. automodule:: borg.locking
+.. automodule:: borg.cache
     :members:
     :members:
     :undoc-members:
     :undoc-members:
 
 
-.. automodule:: borg.shellpattern
+.. automodule:: borg.helpers
     :members:
     :members:
     :undoc-members:
     :undoc-members:
 
 
-.. automodule:: borg.repository
+.. automodule:: borg.lrucache
     :members:
     :members:
     :undoc-members:
     :undoc-members:
 
 
-.. automodule:: borg.lrucache
+.. automodule:: borg.key
     :members:
     :members:
     :undoc-members:
     :undoc-members:
 
 
-.. automodule:: borg.remote
+.. automodule:: borg.upgrader
     :members:
     :members:
     :undoc-members:
     :undoc-members:
 
 
-.. automodule:: borg.hash_sizes
+.. automodule:: borg.shellpattern
     :members:
     :members:
     :undoc-members:
     :undoc-members:
 
 
-.. automodule:: borg.xattr
+.. automodule:: borg.locking
     :members:
     :members:
     :undoc-members:
     :undoc-members:
 
 
-.. automodule:: borg.helpers
+.. automodule:: borg.fuse
     :members:
     :members:
     :undoc-members:
     :undoc-members:
 
 
-.. automodule:: borg.cache
+.. automodule:: borg.logger
     :members:
     :members:
     :undoc-members:
     :undoc-members:
 
 
-.. automodule:: borg.key
+.. automodule:: borg.archiver
     :members:
     :members:
     :undoc-members:
     :undoc-members:
 
 
-.. automodule:: borg.logger
+.. automodule:: borg.remote
     :members:
     :members:
     :undoc-members:
     :undoc-members:
 
 
-.. automodule:: borg.platform_darwin
+.. automodule:: borg.chunker
     :members:
     :members:
     :undoc-members:
     :undoc-members:
 
 
-.. automodule:: borg.platform_linux
+.. automodule:: borg.platform_freebsd
     :members:
     :members:
     :undoc-members:
     :undoc-members:
 
 
@@ -82,7 +82,7 @@ API Documentation
     :members:
     :members:
     :undoc-members:
     :undoc-members:
 
 
-.. automodule:: borg.chunker
+.. automodule:: borg.platform_linux
     :members:
     :members:
     :undoc-members:
     :undoc-members:
 
 
@@ -90,6 +90,6 @@ API Documentation
     :members:
     :members:
     :undoc-members:
     :undoc-members:
 
 
-.. automodule:: borg.platform_freebsd
+.. automodule:: borg.platform_darwin
     :members:
     :members:
     :undoc-members:
     :undoc-members:

+ 4 - 2
docs/usage/break-lock.rst.inc

@@ -4,8 +4,9 @@ borg break-lock
 ---------------
 ---------------
 ::
 ::
 
 
-    usage: borg break-lock [-h] [-v] [--debug] [--lock-wait N] [--show-rc]
-                           [--no-files-cache] [--umask M] [--remote-path PATH]
+    usage: borg break-lock [-h] [-v] [--debug] [--lock-wait N] [--show-version]
+                           [--show-rc] [--no-files-cache] [--umask M]
+                           [--remote-path PATH]
                            REPOSITORY
                            REPOSITORY
     
     
     Break the repository lock (e.g. in case it was left by a dead borg.
     Break the repository lock (e.g. in case it was left by a dead borg.
@@ -20,6 +21,7 @@ borg break-lock
                             INFO
                             INFO
       --debug               enable debug output, work on log level DEBUG
       --debug               enable debug output, work on log level DEBUG
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
+      --show-version        show/log the borg version
       --show-rc             show/log the return code (rc)
       --show-rc             show/log the return code (rc)
       --no-files-cache      do not load/update the file metadata cache used to
       --no-files-cache      do not load/update the file metadata cache used to
                             detect unchanged files
                             detect unchanged files

+ 4 - 3
docs/usage/change-passphrase.rst.inc

@@ -4,9 +4,9 @@ borg change-passphrase
 ----------------------
 ----------------------
 ::
 ::
 
 
-    usage: borg change-passphrase [-h] [-v] [--debug] [--lock-wait N] [--show-rc]
-                                  [--no-files-cache] [--umask M]
-                                  [--remote-path PATH]
+    usage: borg change-passphrase [-h] [-v] [--debug] [--lock-wait N]
+                                  [--show-version] [--show-rc] [--no-files-cache]
+                                  [--umask M] [--remote-path PATH]
                                   [REPOSITORY]
                                   [REPOSITORY]
     
     
     Change repository key file passphrase
     Change repository key file passphrase
@@ -21,6 +21,7 @@ borg change-passphrase
                             INFO
                             INFO
       --debug               enable debug output, work on log level DEBUG
       --debug               enable debug output, work on log level DEBUG
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
+      --show-version        show/log the borg version
       --show-rc             show/log the return code (rc)
       --show-rc             show/log the return code (rc)
       --no-files-cache      do not load/update the file metadata cache used to
       --no-files-cache      do not load/update the file metadata cache used to
                             detect unchanged files
                             detect unchanged files

+ 5 - 4
docs/usage/check.rst.inc

@@ -4,10 +4,10 @@ borg check
 ----------
 ----------
 ::
 ::
 
 
-    usage: borg check [-h] [-v] [--debug] [--lock-wait N] [--show-rc]
-                      [--no-files-cache] [--umask M] [--remote-path PATH]
-                      [--repository-only] [--archives-only] [--repair]
-                      [--save-space] [--last N] [-P PREFIX]
+    usage: borg check [-h] [-v] [--debug] [--lock-wait N] [--show-version]
+                      [--show-rc] [--no-files-cache] [--umask M]
+                      [--remote-path PATH] [--repository-only] [--archives-only]
+                      [--repair] [--save-space] [--last N] [-P PREFIX]
                       [REPOSITORY_OR_ARCHIVE]
                       [REPOSITORY_OR_ARCHIVE]
     
     
     Check repository consistency
     Check repository consistency
@@ -23,6 +23,7 @@ borg check
                             INFO
                             INFO
       --debug               enable debug output, work on log level DEBUG
       --debug               enable debug output, work on log level DEBUG
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
+      --show-version        show/log the borg version
       --show-rc             show/log the return code (rc)
       --show-rc             show/log the return code (rc)
       --no-files-cache      do not load/update the file metadata cache used to
       --no-files-cache      do not load/update the file metadata cache used to
                             detect unchanged files
                             detect unchanged files

+ 14 - 4
docs/usage/create.rst.inc

@@ -4,15 +4,16 @@ borg create
 -----------
 -----------
 ::
 ::
 
 
-    usage: borg create [-h] [-v] [--debug] [--lock-wait N] [--show-rc]
-                       [--no-files-cache] [--umask M] [--remote-path PATH] [-s]
-                       [-p] [--list] [--filter STATUSCHARS] [-e PATTERN]
+    usage: borg create [-h] [-v] [--debug] [--lock-wait N] [--show-version]
+                       [--show-rc] [--no-files-cache] [--umask M]
+                       [--remote-path PATH] [-s] [-p] [--list]
+                       [--filter STATUSCHARS] [-e PATTERN]
                        [--exclude-from EXCLUDEFILE] [--exclude-caches]
                        [--exclude-from EXCLUDEFILE] [--exclude-caches]
                        [--exclude-if-present FILENAME] [--keep-tag-files]
                        [--exclude-if-present FILENAME] [--keep-tag-files]
                        [-c SECONDS] [-x] [--numeric-owner]
                        [-c SECONDS] [-x] [--numeric-owner]
                        [--timestamp yyyy-mm-ddThh:mm:ss]
                        [--timestamp yyyy-mm-ddThh:mm:ss]
                        [--chunker-params CHUNK_MIN_EXP,CHUNK_MAX_EXP,HASH_MASK_BITS,HASH_WINDOW_SIZE]
                        [--chunker-params CHUNK_MIN_EXP,CHUNK_MAX_EXP,HASH_MASK_BITS,HASH_WINDOW_SIZE]
-                       [-C COMPRESSION] [--read-special] [-n]
+                       [--ignore-inode] [-C COMPRESSION] [--read-special] [-n]
                        ARCHIVE PATH [PATH ...]
                        ARCHIVE PATH [PATH ...]
     
     
     Create new archive
     Create new archive
@@ -29,6 +30,7 @@ borg create
                             INFO
                             INFO
       --debug               enable debug output, work on log level DEBUG
       --debug               enable debug output, work on log level DEBUG
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
+      --show-version        show/log the borg version
       --show-rc             show/log the return code (rc)
       --show-rc             show/log the return code (rc)
       --no-files-cache      do not load/update the file metadata cache used to
       --no-files-cache      do not load/update the file metadata cache used to
                             detect unchanged files
                             detect unchanged files
@@ -60,6 +62,8 @@ borg create
                             alternatively, give a reference file/directory.
                             alternatively, give a reference file/directory.
       --chunker-params CHUNK_MIN_EXP,CHUNK_MAX_EXP,HASH_MASK_BITS,HASH_WINDOW_SIZE
       --chunker-params CHUNK_MIN_EXP,CHUNK_MAX_EXP,HASH_MASK_BITS,HASH_WINDOW_SIZE
                             specify the chunker parameters. default: 19,23,21,4095
                             specify the chunker parameters. default: 19,23,21,4095
+      --ignore-inode        ignore inode data in the file metadata cache used to
+                            detect unchanged files.
       -C COMPRESSION, --compression COMPRESSION
       -C COMPRESSION, --compression COMPRESSION
                             select compression algorithm (and level): none == no
                             select compression algorithm (and level): none == no
                             compression (default), lz4 == lz4, zlib == zlib
                             compression (default), lz4 == lz4, zlib == zlib
@@ -77,4 +81,10 @@ This command creates a backup archive containing all files found while recursive
 traversing all paths specified. The archive will consume almost no disk space for
 traversing all paths specified. The archive will consume almost no disk space for
 files or parts of files that have already been stored in other archives.
 files or parts of files that have already been stored in other archives.
 
 
+
+To speed up pulling backups over sshfs and similar network file systems which do
+not provide correct inode information the --ignore-inode flag can be used. This
+potentially decreases reliability of change detection, while avoiding always reading
+all files on these file systems.
+
 See the output of the "borg help patterns" command for more help on exclude patterns.
 See the output of the "borg help patterns" command for more help on exclude patterns.

+ 4 - 3
docs/usage/debug-delete-obj.rst.inc

@@ -4,9 +4,9 @@ borg debug-delete-obj
 ---------------------
 ---------------------
 ::
 ::
 
 
-    usage: borg debug-delete-obj [-h] [-v] [--debug] [--lock-wait N] [--show-rc]
-                                 [--no-files-cache] [--umask M]
-                                 [--remote-path PATH]
+    usage: borg debug-delete-obj [-h] [-v] [--debug] [--lock-wait N]
+                                 [--show-version] [--show-rc] [--no-files-cache]
+                                 [--umask M] [--remote-path PATH]
                                  [REPOSITORY] IDs [IDs ...]
                                  [REPOSITORY] IDs [IDs ...]
     
     
     delete the objects with the given IDs from the repo
     delete the objects with the given IDs from the repo
@@ -22,6 +22,7 @@ borg debug-delete-obj
                             INFO
                             INFO
       --debug               enable debug output, work on log level DEBUG
       --debug               enable debug output, work on log level DEBUG
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
+      --show-version        show/log the borg version
       --show-rc             show/log the return code (rc)
       --show-rc             show/log the return code (rc)
       --no-files-cache      do not load/update the file metadata cache used to
       --no-files-cache      do not load/update the file metadata cache used to
                             detect unchanged files
                             detect unchanged files

+ 4 - 2
docs/usage/debug-dump-archive-items.rst.inc

@@ -5,8 +5,9 @@ borg debug-dump-archive-items
 ::
 ::
 
 
     usage: borg debug-dump-archive-items [-h] [-v] [--debug] [--lock-wait N]
     usage: borg debug-dump-archive-items [-h] [-v] [--debug] [--lock-wait N]
-                                         [--show-rc] [--no-files-cache]
-                                         [--umask M] [--remote-path PATH]
+                                         [--show-version] [--show-rc]
+                                         [--no-files-cache] [--umask M]
+                                         [--remote-path PATH]
                                          ARCHIVE
                                          ARCHIVE
     
     
     dump (decrypted, decompressed) archive items metadata (not: data)
     dump (decrypted, decompressed) archive items metadata (not: data)
@@ -21,6 +22,7 @@ borg debug-dump-archive-items
                             INFO
                             INFO
       --debug               enable debug output, work on log level DEBUG
       --debug               enable debug output, work on log level DEBUG
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
+      --show-version        show/log the borg version
       --show-rc             show/log the return code (rc)
       --show-rc             show/log the return code (rc)
       --no-files-cache      do not load/update the file metadata cache used to
       --no-files-cache      do not load/update the file metadata cache used to
                             detect unchanged files
                             detect unchanged files

+ 4 - 2
docs/usage/debug-get-obj.rst.inc

@@ -4,8 +4,9 @@ borg debug-get-obj
 ------------------
 ------------------
 ::
 ::
 
 
-    usage: borg debug-get-obj [-h] [-v] [--debug] [--lock-wait N] [--show-rc]
-                              [--no-files-cache] [--umask M] [--remote-path PATH]
+    usage: borg debug-get-obj [-h] [-v] [--debug] [--lock-wait N] [--show-version]
+                              [--show-rc] [--no-files-cache] [--umask M]
+                              [--remote-path PATH]
                               [REPOSITORY] ID PATH
                               [REPOSITORY] ID PATH
     
     
     get object contents from the repository and write it into file
     get object contents from the repository and write it into file
@@ -22,6 +23,7 @@ borg debug-get-obj
                             INFO
                             INFO
       --debug               enable debug output, work on log level DEBUG
       --debug               enable debug output, work on log level DEBUG
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
+      --show-version        show/log the borg version
       --show-rc             show/log the return code (rc)
       --show-rc             show/log the return code (rc)
       --no-files-cache      do not load/update the file metadata cache used to
       --no-files-cache      do not load/update the file metadata cache used to
                             detect unchanged files
                             detect unchanged files

+ 4 - 2
docs/usage/debug-put-obj.rst.inc

@@ -4,8 +4,9 @@ borg debug-put-obj
 ------------------
 ------------------
 ::
 ::
 
 
-    usage: borg debug-put-obj [-h] [-v] [--debug] [--lock-wait N] [--show-rc]
-                              [--no-files-cache] [--umask M] [--remote-path PATH]
+    usage: borg debug-put-obj [-h] [-v] [--debug] [--lock-wait N] [--show-version]
+                              [--show-rc] [--no-files-cache] [--umask M]
+                              [--remote-path PATH]
                               [REPOSITORY] PATH [PATH ...]
                               [REPOSITORY] PATH [PATH ...]
     
     
     put file(s) contents into the repository
     put file(s) contents into the repository
@@ -21,6 +22,7 @@ borg debug-put-obj
                             INFO
                             INFO
       --debug               enable debug output, work on log level DEBUG
       --debug               enable debug output, work on log level DEBUG
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
+      --show-version        show/log the borg version
       --show-rc             show/log the return code (rc)
       --show-rc             show/log the return code (rc)
       --no-files-cache      do not load/update the file metadata cache used to
       --no-files-cache      do not load/update the file metadata cache used to
                             detect unchanged files
                             detect unchanged files

+ 4 - 3
docs/usage/delete.rst.inc

@@ -4,9 +4,9 @@ borg delete
 -----------
 -----------
 ::
 ::
 
 
-    usage: borg delete [-h] [-v] [--debug] [--lock-wait N] [--show-rc]
-                       [--no-files-cache] [--umask M] [--remote-path PATH] [-p]
-                       [-s] [-c] [--save-space]
+    usage: borg delete [-h] [-v] [--debug] [--lock-wait N] [--show-version]
+                       [--show-rc] [--no-files-cache] [--umask M]
+                       [--remote-path PATH] [-p] [-s] [-c] [--save-space]
                        [TARGET]
                        [TARGET]
     
     
     Delete an existing repository or archive
     Delete an existing repository or archive
@@ -21,6 +21,7 @@ borg delete
                             INFO
                             INFO
       --debug               enable debug output, work on log level DEBUG
       --debug               enable debug output, work on log level DEBUG
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
+      --show-version        show/log the borg version
       --show-rc             show/log the return code (rc)
       --show-rc             show/log the return code (rc)
       --no-files-cache      do not load/update the file metadata cache used to
       --no-files-cache      do not load/update the file metadata cache used to
                             detect unchanged files
                             detect unchanged files

+ 51 - 0
docs/usage/diff.rst.inc

@@ -0,0 +1,51 @@
+.. _borg_diff:
+
+borg diff
+---------
+::
+
+    usage: borg diff [-h] [-v] [--debug] [--lock-wait N] [--show-version]
+                     [--show-rc] [--no-files-cache] [--umask M]
+                     [--remote-path PATH] [-e PATTERN]
+                     [--exclude-from EXCLUDEFILE] [--numeric-owner]
+                     [--same-chunker-params]
+                     ARCHIVE1 ARCHIVE2 [PATH [PATH ...]]
+    
+    Diff contents of two archives
+    
+    positional arguments:
+      ARCHIVE1              archive
+      ARCHIVE2              archive to compare with ARCHIVE1 (no repository
+                            location)
+      PATH                  paths to compare; patterns are supported
+    
+    optional arguments:
+      -h, --help            show this help message and exit
+      -v, --verbose, --info
+                            enable informative (verbose) output, work on log level
+                            INFO
+      --debug               enable debug output, work on log level DEBUG
+      --lock-wait N         wait for the lock, but max. N seconds (default: 1).
+      --show-version        show/log the borg version
+      --show-rc             show/log the return code (rc)
+      --no-files-cache      do not load/update the file metadata cache used to
+                            detect unchanged files
+      --umask M             set umask to M (local and remote, default: 0077)
+      --remote-path PATH    set remote path to executable (default: "borg")
+      -e PATTERN, --exclude PATTERN
+                            exclude paths matching PATTERN
+      --exclude-from EXCLUDEFILE
+                            read exclude patterns from EXCLUDEFILE, one per line
+      --numeric-owner       only consider numeric user and group identifiers
+      --same-chunker-params
+                            Override check of chunker parameters.
+    
+Description
+~~~~~~~~~~~
+
+This command finds differences in files (contents, user, group, mode) between archives.
+
+Both archives need to be in the same repository, and a repository location may only
+be specified for ARCHIVE1.
+
+See the output of the "borg help patterns" command for more help on exclude patterns.

+ 6 - 5
docs/usage/extract.rst.inc

@@ -4,11 +4,11 @@ borg extract
 ------------
 ------------
 ::
 ::
 
 
-    usage: borg extract [-h] [-v] [--debug] [--lock-wait N] [--show-rc]
-                        [--no-files-cache] [--umask M] [--remote-path PATH]
-                        [--list] [-n] [-e PATTERN] [--exclude-from EXCLUDEFILE]
-                        [--numeric-owner] [--strip-components NUMBER] [--stdout]
-                        [--sparse]
+    usage: borg extract [-h] [-v] [--debug] [--lock-wait N] [--show-version]
+                        [--show-rc] [--no-files-cache] [--umask M]
+                        [--remote-path PATH] [--list] [-n] [-e PATTERN]
+                        [--exclude-from EXCLUDEFILE] [--numeric-owner]
+                        [--strip-components NUMBER] [--stdout] [--sparse]
                         ARCHIVE [PATH [PATH ...]]
                         ARCHIVE [PATH [PATH ...]]
     
     
     Extract archive contents
     Extract archive contents
@@ -24,6 +24,7 @@ borg extract
                             INFO
                             INFO
       --debug               enable debug output, work on log level DEBUG
       --debug               enable debug output, work on log level DEBUG
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
+      --show-version        show/log the borg version
       --show-rc             show/log the return code (rc)
       --show-rc             show/log the return code (rc)
       --no-files-cache      do not load/update the file metadata cache used to
       --no-files-cache      do not load/update the file metadata cache used to
                             detect unchanged files
                             detect unchanged files

+ 4 - 2
docs/usage/info.rst.inc

@@ -4,8 +4,9 @@ borg info
 ---------
 ---------
 ::
 ::
 
 
-    usage: borg info [-h] [-v] [--debug] [--lock-wait N] [--show-rc]
-                     [--no-files-cache] [--umask M] [--remote-path PATH]
+    usage: borg info [-h] [-v] [--debug] [--lock-wait N] [--show-version]
+                     [--show-rc] [--no-files-cache] [--umask M]
+                     [--remote-path PATH]
                      ARCHIVE
                      ARCHIVE
     
     
     Show archive details such as disk space used
     Show archive details such as disk space used
@@ -20,6 +21,7 @@ borg info
                             INFO
                             INFO
       --debug               enable debug output, work on log level DEBUG
       --debug               enable debug output, work on log level DEBUG
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
+      --show-version        show/log the borg version
       --show-rc             show/log the return code (rc)
       --show-rc             show/log the return code (rc)
       --no-files-cache      do not load/update the file metadata cache used to
       --no-files-cache      do not load/update the file metadata cache used to
                             detect unchanged files
                             detect unchanged files

+ 4 - 3
docs/usage/init.rst.inc

@@ -4,9 +4,9 @@ borg init
 ---------
 ---------
 ::
 ::
 
 
-    usage: borg init [-h] [-v] [--debug] [--lock-wait N] [--show-rc]
-                     [--no-files-cache] [--umask M] [--remote-path PATH]
-                     [-e {none,keyfile,repokey}]
+    usage: borg init [-h] [-v] [--debug] [--lock-wait N] [--show-version]
+                     [--show-rc] [--no-files-cache] [--umask M]
+                     [--remote-path PATH] [-e {none,keyfile,repokey}]
                      [REPOSITORY]
                      [REPOSITORY]
     
     
     Initialize an empty repository
     Initialize an empty repository
@@ -21,6 +21,7 @@ borg init
                             INFO
                             INFO
       --debug               enable debug output, work on log level DEBUG
       --debug               enable debug output, work on log level DEBUG
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
+      --show-version        show/log the borg version
       --show-rc             show/log the return code (rc)
       --show-rc             show/log the return code (rc)
       --no-files-cache      do not load/update the file metadata cache used to
       --no-files-cache      do not load/update the file metadata cache used to
                             detect unchanged files
                             detect unchanged files

+ 5 - 3
docs/usage/list.rst.inc

@@ -4,9 +4,10 @@ borg list
 ---------
 ---------
 ::
 ::
 
 
-    usage: borg list [-h] [-v] [--debug] [--lock-wait N] [--show-rc]
-                     [--no-files-cache] [--umask M] [--remote-path PATH] [--short]
-                     [--list-format LISTFORMAT] [-P PREFIX]
+    usage: borg list [-h] [-v] [--debug] [--lock-wait N] [--show-version]
+                     [--show-rc] [--no-files-cache] [--umask M]
+                     [--remote-path PATH] [--short] [--list-format LISTFORMAT]
+                     [-P PREFIX]
                      [REPOSITORY_OR_ARCHIVE]
                      [REPOSITORY_OR_ARCHIVE]
     
     
     List archive or repository contents
     List archive or repository contents
@@ -22,6 +23,7 @@ borg list
                             INFO
                             INFO
       --debug               enable debug output, work on log level DEBUG
       --debug               enable debug output, work on log level DEBUG
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
+      --show-version        show/log the borg version
       --show-rc             show/log the return code (rc)
       --show-rc             show/log the return code (rc)
       --no-files-cache      do not load/update the file metadata cache used to
       --no-files-cache      do not load/update the file metadata cache used to
                             detect unchanged files
                             detect unchanged files

+ 4 - 3
docs/usage/migrate-to-repokey.rst.inc

@@ -4,9 +4,9 @@ borg migrate-to-repokey
 -----------------------
 -----------------------
 ::
 ::
 
 
-    usage: borg migrate-to-repokey [-h] [-v] [--debug] [--lock-wait N] [--show-rc]
-                                   [--no-files-cache] [--umask M]
-                                   [--remote-path PATH]
+    usage: borg migrate-to-repokey [-h] [-v] [--debug] [--lock-wait N]
+                                   [--show-version] [--show-rc] [--no-files-cache]
+                                   [--umask M] [--remote-path PATH]
                                    [REPOSITORY]
                                    [REPOSITORY]
     
     
     Migrate passphrase -> repokey
     Migrate passphrase -> repokey
@@ -21,6 +21,7 @@ borg migrate-to-repokey
                             INFO
                             INFO
       --debug               enable debug output, work on log level DEBUG
       --debug               enable debug output, work on log level DEBUG
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
+      --show-version        show/log the borg version
       --show-rc             show/log the return code (rc)
       --show-rc             show/log the return code (rc)
       --no-files-cache      do not load/update the file metadata cache used to
       --no-files-cache      do not load/update the file metadata cache used to
                             detect unchanged files
                             detect unchanged files

+ 4 - 3
docs/usage/mount.rst.inc

@@ -4,9 +4,9 @@ borg mount
 ----------
 ----------
 ::
 ::
 
 
-    usage: borg mount [-h] [-v] [--debug] [--lock-wait N] [--show-rc]
-                      [--no-files-cache] [--umask M] [--remote-path PATH] [-f]
-                      [-o OPTIONS]
+    usage: borg mount [-h] [-v] [--debug] [--lock-wait N] [--show-version]
+                      [--show-rc] [--no-files-cache] [--umask M]
+                      [--remote-path PATH] [-f] [-o OPTIONS]
                       REPOSITORY_OR_ARCHIVE MOUNTPOINT
                       REPOSITORY_OR_ARCHIVE MOUNTPOINT
     
     
     Mount archive or an entire repository as a FUSE fileystem
     Mount archive or an entire repository as a FUSE fileystem
@@ -23,6 +23,7 @@ borg mount
                             INFO
                             INFO
       --debug               enable debug output, work on log level DEBUG
       --debug               enable debug output, work on log level DEBUG
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
+      --show-version        show/log the borg version
       --show-rc             show/log the return code (rc)
       --show-rc             show/log the return code (rc)
       --no-files-cache      do not load/update the file metadata cache used to
       --no-files-cache      do not load/update the file metadata cache used to
                             detect unchanged files
                             detect unchanged files

+ 6 - 5
docs/usage/prune.rst.inc

@@ -4,11 +4,11 @@ borg prune
 ----------
 ----------
 ::
 ::
 
 
-    usage: borg prune [-h] [-v] [--debug] [--lock-wait N] [--show-rc]
-                      [--no-files-cache] [--umask M] [--remote-path PATH] [-n]
-                      [-s] [--list] [--keep-within WITHIN] [-H HOURLY] [-d DAILY]
-                      [-w WEEKLY] [-m MONTHLY] [-y YEARLY] [-P PREFIX]
-                      [--save-space]
+    usage: borg prune [-h] [-v] [--debug] [--lock-wait N] [--show-version]
+                      [--show-rc] [--no-files-cache] [--umask M]
+                      [--remote-path PATH] [-n] [-s] [--list]
+                      [--keep-within WITHIN] [-H HOURLY] [-d DAILY] [-w WEEKLY]
+                      [-m MONTHLY] [-y YEARLY] [-P PREFIX] [--save-space]
                       [REPOSITORY]
                       [REPOSITORY]
     
     
     Prune repository archives according to specified rules
     Prune repository archives according to specified rules
@@ -23,6 +23,7 @@ borg prune
                             INFO
                             INFO
       --debug               enable debug output, work on log level DEBUG
       --debug               enable debug output, work on log level DEBUG
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
+      --show-version        show/log the borg version
       --show-rc             show/log the return code (rc)
       --show-rc             show/log the return code (rc)
       --no-files-cache      do not load/update the file metadata cache used to
       --no-files-cache      do not load/update the file metadata cache used to
                             detect unchanged files
                             detect unchanged files

+ 4 - 2
docs/usage/rename.rst.inc

@@ -4,8 +4,9 @@ borg rename
 -----------
 -----------
 ::
 ::
 
 
-    usage: borg rename [-h] [-v] [--debug] [--lock-wait N] [--show-rc]
-                       [--no-files-cache] [--umask M] [--remote-path PATH]
+    usage: borg rename [-h] [-v] [--debug] [--lock-wait N] [--show-version]
+                       [--show-rc] [--no-files-cache] [--umask M]
+                       [--remote-path PATH]
                        ARCHIVE NEWNAME
                        ARCHIVE NEWNAME
     
     
     Rename an existing archive
     Rename an existing archive
@@ -21,6 +22,7 @@ borg rename
                             INFO
                             INFO
       --debug               enable debug output, work on log level DEBUG
       --debug               enable debug output, work on log level DEBUG
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
+      --show-version        show/log the borg version
       --show-rc             show/log the return code (rc)
       --show-rc             show/log the return code (rc)
       --no-files-cache      do not load/update the file metadata cache used to
       --no-files-cache      do not load/update the file metadata cache used to
                             detect unchanged files
                             detect unchanged files

+ 4 - 3
docs/usage/serve.rst.inc

@@ -4,9 +4,9 @@ borg serve
 ----------
 ----------
 ::
 ::
 
 
-    usage: borg serve [-h] [-v] [--debug] [--lock-wait N] [--show-rc]
-                      [--no-files-cache] [--umask M] [--remote-path PATH]
-                      [--restrict-to-path PATH]
+    usage: borg serve [-h] [-v] [--debug] [--lock-wait N] [--show-version]
+                      [--show-rc] [--no-files-cache] [--umask M]
+                      [--remote-path PATH] [--restrict-to-path PATH]
     
     
     Start in server mode. This command is usually not used manually.
     Start in server mode. This command is usually not used manually.
             
             
@@ -18,6 +18,7 @@ borg serve
                             INFO
                             INFO
       --debug               enable debug output, work on log level DEBUG
       --debug               enable debug output, work on log level DEBUG
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
+      --show-version        show/log the borg version
       --show-rc             show/log the return code (rc)
       --show-rc             show/log the return code (rc)
       --no-files-cache      do not load/update the file metadata cache used to
       --no-files-cache      do not load/update the file metadata cache used to
                             detect unchanged files
                             detect unchanged files

+ 4 - 3
docs/usage/upgrade.rst.inc

@@ -4,9 +4,9 @@ borg upgrade
 ------------
 ------------
 ::
 ::
 
 
-    usage: borg upgrade [-h] [-v] [--debug] [--lock-wait N] [--show-rc]
-                        [--no-files-cache] [--umask M] [--remote-path PATH] [-p]
-                        [-n] [-i]
+    usage: borg upgrade [-h] [-v] [--debug] [--lock-wait N] [--show-version]
+                        [--show-rc] [--no-files-cache] [--umask M]
+                        [--remote-path PATH] [-p] [-n] [-i]
                         [REPOSITORY]
                         [REPOSITORY]
     
     
     upgrade a repository from a previous version
     upgrade a repository from a previous version
@@ -21,6 +21,7 @@ borg upgrade
                             INFO
                             INFO
       --debug               enable debug output, work on log level DEBUG
       --debug               enable debug output, work on log level DEBUG
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
       --lock-wait N         wait for the lock, but max. N seconds (default: 1).
+      --show-version        show/log the borg version
       --show-rc             show/log the return code (rc)
       --show-rc             show/log the return code (rc)
       --no-files-cache      do not load/update the file metadata cache used to
       --no-files-cache      do not load/update the file metadata cache used to
                             detect unchanged files
                             detect unchanged files