diff options
author | Fahad Alrashed <fahad@keylock.net> | 2024-05-09 00:11:05 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2024-05-09 00:44:14 +0200 |
commit | 55702c543ea39230847dfc635ea1b604d66d9b83 (patch) | |
tree | d68c293ca6ebef6409f33158d8338797a0a0d37f /git-p4.py | |
parent | Git 2.45 (diff) | |
download | git-55702c543ea39230847dfc635ea1b604d66d9b83.tar.xz git-55702c543ea39230847dfc635ea1b604d66d9b83.zip |
git-p4: show Perforce error to the user
During "git p4 clone" if p4 process returns an error from the server,
it will store the message in the 'err' variable. Then it will send a
text command "die-now" to git-fast-import. However, git-fast-import
raises an exception: "fatal: Unsupported command: die-now" and err is
never displayed. This patch ensures that err is shown to the end user.
Signed-off-by: Fahad Alrashed <fahad@keylock.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'git-p4.py')
-rwxr-xr-x | git-p4.py | 24 |
1 files changed, 13 insertions, 11 deletions
@@ -3253,17 +3253,19 @@ class P4Sync(Command, P4UserMap): if self.stream_have_file_info: if "depotFile" in self.stream_file: f = self.stream_file["depotFile"] - # force a failure in fast-import, else an empty - # commit will be made - self.gitStream.write("\n") - self.gitStream.write("die-now\n") - self.gitStream.close() - # ignore errors, but make sure it exits first - self.importProcess.wait() - if f: - die("Error from p4 print for %s: %s" % (f, err)) - else: - die("Error from p4 print: %s" % err) + try: + # force a failure in fast-import, else an empty + # commit will be made + self.gitStream.write("\n") + self.gitStream.write("die-now\n") + self.gitStream.close() + # ignore errors, but make sure it exits first + self.importProcess.wait() + finally: + if f: + die("Error from p4 print for %s: %s" % (f, err)) + else: + die("Error from p4 print: %s" % err) if 'depotFile' in marshalled and self.stream_have_file_info: # start of a new file - output the old one first |