aboutsummaryrefslogtreecommitdiff
path: root/modules/errors.py
diff options
context:
space:
mode:
authorAUTOMATIC1111 <16777216c@gmail.com>2023-11-26 11:29:27 +0300
committerGitHub <noreply@github.com>2023-11-26 11:29:27 +0300
commitf7f015e84b8146fae1659e8f8c2eafcf69063e2f (patch)
tree375f8fd565f31f711e8ea7d86699652c6a946240 /modules/errors.py
parentf85b74763d4501542d8ea80e99db4111d39b4776 (diff)
parent5cedc8f9b2b51f392e7c8f5e29286466e3bee8d6 (diff)
Merge pull request #14084 from wfjsw/move-from-sysinfo-to-errors
Move exception_records related methods to errors.py
Diffstat (limited to 'modules/errors.py')
-rw-r--r--modules/errors.py18
1 files changed, 16 insertions, 2 deletions
diff --git a/modules/errors.py b/modules/errors.py
index 8c339464..eb234a83 100644
--- a/modules/errors.py
+++ b/modules/errors.py
@@ -6,6 +6,21 @@ import traceback
exception_records = []
+def format_traceback(tb):
+ return [[f"{x.filename}, line {x.lineno}, {x.name}", x.line] for x in traceback.extract_tb(tb)]
+
+
+def format_exception(e, tb):
+ return {"exception": str(e), "traceback": format_traceback(tb)}
+
+
+def get_exceptions():
+ try:
+ return list(reversed(exception_records))
+ except Exception as e:
+ return str(e)
+
+
def record_exception():
_, e, tb = sys.exc_info()
if e is None:
@@ -14,8 +29,7 @@ def record_exception():
if exception_records and exception_records[-1] == e:
return
- from modules import sysinfo
- exception_records.append(sysinfo.format_exception(e, tb))
+ exception_records.append(format_exception(e, tb))
if len(exception_records) > 5:
exception_records.pop(0)