]> arthur.barton.de Git - bup.git/commitdiff
cat-file-cmd: accommodate python 3
authorRob Browning <rlb@defaultvalue.org>
Tue, 31 Dec 2019 17:47:47 +0000 (11:47 -0600)
committerRob Browning <rlb@defaultvalue.org>
Sun, 2 Feb 2020 19:30:12 +0000 (13:30 -0600)
Signed-off-by: Rob Browning <rlb@defaultvalue.org>
Tested-by: Rob Browning <rlb@defaultvalue.org>
cmd/cat-file-cmd.py

index 9cb6961f081645be1cf3f0f7ac0dc0896dfba832..3f776a284d46f1ca83f8f31793c74f4d30b38ec0 100755 (executable)
@@ -9,7 +9,9 @@ from __future__ import absolute_import
 import re, stat, sys
 
 from bup import options, git, vfs
+from bup.compat import argv_bytes
 from bup.helpers import chunkyreader, handle_ctrl_c, log, saved_errors
+from bup.io import byte_stream
 from bup.repo import LocalRepo
 
 optspec = """
@@ -33,9 +35,9 @@ if len(extra) > 1:
 if opt.bupm and opt.meta:
     o.fatal('--meta and --bupm are incompatible')
     
-target = extra[0]
+target = argv_bytes(extra[0])
 
-if not re.match(r'/*[^/]+/[^/]+', target):
+if not re.match(br'/*[^/]+/[^/]+', target):
     o.fatal("path %r doesn't include a branch and revision" % target)
 
 repo = LocalRepo()
@@ -48,21 +50,24 @@ if not leaf_item:
 
 mode = vfs.item_mode(leaf_item)
 
+sys.stdout.flush()
+out = byte_stream(sys.stdout)
+
 if opt.bupm:
     if not stat.S_ISDIR(mode):
         o.fatal('%r is not a directory' % target)
     _, bupm_oid = vfs.tree_data_and_bupm(repo, leaf_item.oid)
     if bupm_oid:
         with vfs.tree_data_reader(repo, bupm_oid) as meta_stream:
-            sys.stdout.write(meta_stream.read())
+            out.write(meta_stream.read())
 elif opt.meta:
     augmented = vfs.augment_item_meta(repo, leaf_item, include_size=True)
-    sys.stdout.write(augmented.meta.encode())
+    out.write(augmented.meta.encode())
 else:
     if stat.S_ISREG(mode):
         with vfs.fopen(repo, leaf_item) as f:
             for b in chunkyreader(f):
-                sys.stdout.write(b)
+                out.write(b)
     else:
         o.fatal('%r is not a plain file' % target)