dycw-utilities 0.114.4__py3-none-any.whl → 0.114.6__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {dycw_utilities-0.114.4.dist-info → dycw_utilities-0.114.6.dist-info}/METADATA +1 -1
- {dycw_utilities-0.114.4.dist-info → dycw_utilities-0.114.6.dist-info}/RECORD +8 -8
- utilities/__init__.py +1 -1
- utilities/asyncio.py +4 -4
- utilities/logging.py +25 -15
- utilities/traceback.py +14 -1
- {dycw_utilities-0.114.4.dist-info → dycw_utilities-0.114.6.dist-info}/WHEEL +0 -0
- {dycw_utilities-0.114.4.dist-info → dycw_utilities-0.114.6.dist-info}/licenses/LICENSE +0 -0
@@ -1,7 +1,7 @@
|
|
1
|
-
utilities/__init__.py,sha256=
|
1
|
+
utilities/__init__.py,sha256=tsYuJeSJY0N2Azm2GNEdQ3CJGral9P44WehpNjApPR0,60
|
2
2
|
utilities/altair.py,sha256=Gpja-flOo-Db0PIPJLJsgzAlXWoKUjPU1qY-DQ829ek,9156
|
3
3
|
utilities/astor.py,sha256=xuDUkjq0-b6fhtwjhbnebzbqQZAjMSHR1IIS5uOodVg,777
|
4
|
-
utilities/asyncio.py,sha256=
|
4
|
+
utilities/asyncio.py,sha256=zz8W_35vp3u7N4rRahr82HmBnq6uXWgJe8XW8KgXh6w,21507
|
5
5
|
utilities/atomicwrites.py,sha256=geFjn9Pwn-tTrtoGjDDxWli9NqbYfy3gGL6ZBctiqSo,5393
|
6
6
|
utilities/atools.py,sha256=IYMuFSFGSKyuQmqD6v5IUtDlz8PPw0Sr87Cub_gRU3M,1168
|
7
7
|
utilities/cachetools.py,sha256=C1zqOg7BYz0IfQFK8e3qaDDgEZxDpo47F15RTfJM37Q,2910
|
@@ -29,7 +29,7 @@ utilities/ipython.py,sha256=V2oMYHvEKvlNBzxDXdLvKi48oUq2SclRg5xasjaXStw,763
|
|
29
29
|
utilities/iterables.py,sha256=prKXBdF5QfLTGC-q4567DwO8xzUng_Z-2a4wBkMqyDo,45360
|
30
30
|
utilities/jupyter.py,sha256=ft5JA7fBxXKzP-L9W8f2-wbF0QeYc_2uLQNFDVk4Z-M,2917
|
31
31
|
utilities/lightweight_charts.py,sha256=vyVOzarYhBIOZj2xDhqdbP85qbSKUjdc6Au91rc1W4M,2814
|
32
|
-
utilities/logging.py,sha256=
|
32
|
+
utilities/logging.py,sha256=gwo3pusPjnWO1ollrtn1VKYyRAQJTue4SkCbMeNvec4,25715
|
33
33
|
utilities/loguru.py,sha256=MEMQVWrdECxk1e3FxGzmOf21vWT9j8CAir98SEXFKPA,3809
|
34
34
|
utilities/luigi.py,sha256=fpH9MbxJDuo6-k9iCXRayFRtiVbUtibCJKugf7ygpv0,5988
|
35
35
|
utilities/math.py,sha256=-mQgbah-dPJwOEWf3SonrFoVZ2AVxMgpeQ3dfVa-oJA,26764
|
@@ -76,7 +76,7 @@ utilities/tenacity.py,sha256=1PUvODiBVgeqIh7G5TRt5WWMSqjLYkEqP53itT97WQc,4914
|
|
76
76
|
utilities/text.py,sha256=Fo12N4aA7k2rnb4W4vH9iiDh88Q5_nvRssTkfNsvVM8,10965
|
77
77
|
utilities/threading.py,sha256=GvBOp4CyhHfN90wGXZuA2VKe9fGzMaEa7oCl4f3nnPU,1009
|
78
78
|
utilities/timer.py,sha256=Rkc49KSpHuC8s7vUxGO9DU55U9I6yDKnchsQqrUCVBs,4075
|
79
|
-
utilities/traceback.py,sha256=
|
79
|
+
utilities/traceback.py,sha256=p9WATV-e4_5AW6SvyRBiU-MY8XnEFcKgrFNUoFzalXI,27521
|
80
80
|
utilities/types.py,sha256=FhE1b8v_s_IlmXucwY7jAMWAq9cfpzyKssQwgwb3jnM,18267
|
81
81
|
utilities/typing.py,sha256=H6ysJkI830aRwLsMKz0SZIw4cpcsm7d6KhQOwr-SDh0,13817
|
82
82
|
utilities/tzdata.py,sha256=yCf70NICwAeazN3_JcXhWvRqCy06XJNQ42j7r6gw3HY,1217
|
@@ -87,7 +87,7 @@ utilities/warnings.py,sha256=un1LvHv70PU-LLv8RxPVmugTzDJkkGXRMZTE2-fTQHw,1771
|
|
87
87
|
utilities/whenever.py,sha256=iLRP_-8CZtBpHKbGZGu-kjSMg1ZubJ-VSmgSy7Eudxw,17787
|
88
88
|
utilities/zipfile.py,sha256=24lQc9ATcJxHXBPc_tBDiJk48pWyRrlxO2fIsFxU0A8,699
|
89
89
|
utilities/zoneinfo.py,sha256=-Xm57PMMwDTYpxJdkiJG13wnbwK--I7XItBh5WVhD-o,1874
|
90
|
-
dycw_utilities-0.114.
|
91
|
-
dycw_utilities-0.114.
|
92
|
-
dycw_utilities-0.114.
|
93
|
-
dycw_utilities-0.114.
|
90
|
+
dycw_utilities-0.114.6.dist-info/METADATA,sha256=Bdrv-QtLXNjCfRIkLbQN192NUfqoMmn7uECg_NTm4Vs,12943
|
91
|
+
dycw_utilities-0.114.6.dist-info/WHEEL,sha256=qtCwoSJWgHk21S1Kb4ihdzI2rlJ1ZKaIurTj_ngOhyQ,87
|
92
|
+
dycw_utilities-0.114.6.dist-info/licenses/LICENSE,sha256=gppZp16M6nSVpBbUBrNL6JuYfvKwZiKgV7XoKKsHzqo,1066
|
93
|
+
dycw_utilities-0.114.6.dist-info/RECORD,,
|
utilities/__init__.py
CHANGED
utilities/asyncio.py
CHANGED
@@ -400,9 +400,9 @@ class InfiniteLooper(ABC, Generic[THashable]):
|
|
400
400
|
"""Handle any errors upon initializing the looper."""
|
401
401
|
if self.logger is not None:
|
402
402
|
getLogger(name=self.logger).error(
|
403
|
-
"Error initializing %r due to %
|
403
|
+
"Error initializing %r due to %r; sleeping for %s...",
|
404
404
|
get_class_name(self),
|
405
|
-
error,
|
405
|
+
repr(error),
|
406
406
|
self.sleep_restart,
|
407
407
|
)
|
408
408
|
|
@@ -410,9 +410,9 @@ class InfiniteLooper(ABC, Generic[THashable]):
|
|
410
410
|
"""Handle any errors upon running the core function."""
|
411
411
|
if self.logger is not None:
|
412
412
|
getLogger(name=self.logger).error(
|
413
|
-
"Error running
|
413
|
+
"Error running %r due to %r; sleeping for %s...",
|
414
414
|
get_class_name(self),
|
415
|
-
error,
|
415
|
+
repr(error),
|
416
416
|
self.sleep_restart,
|
417
417
|
)
|
418
418
|
|
utilities/logging.py
CHANGED
@@ -587,19 +587,19 @@ def setup_logging(
|
|
587
587
|
|
588
588
|
# console
|
589
589
|
if console_level is not None: # skipif-ci-and-windows
|
590
|
-
|
591
|
-
add_filters(
|
592
|
-
add_filters(
|
593
|
-
add_filters(
|
594
|
-
|
595
|
-
|
596
|
-
logger_use.addHandler(
|
597
|
-
|
598
|
-
|
599
|
-
add_filters(
|
600
|
-
add_filters(
|
590
|
+
console_low_or_no_exc_handler = StreamHandler(stream=stdout)
|
591
|
+
add_filters(console_low_or_no_exc_handler, _console_low_or_no_exc_filter)
|
592
|
+
add_filters(console_low_or_no_exc_handler, *console_filters)
|
593
|
+
add_filters(console_low_or_no_exc_handler, *filters)
|
594
|
+
console_low_or_no_exc_handler.setFormatter(console_formatter)
|
595
|
+
console_low_or_no_exc_handler.setLevel(console_level)
|
596
|
+
logger_use.addHandler(console_low_or_no_exc_handler)
|
597
|
+
|
598
|
+
console_high_and_exc_handler = StreamHandler(stream=stdout)
|
599
|
+
add_filters(console_high_and_exc_handler, *console_filters)
|
600
|
+
add_filters(console_high_and_exc_handler, *filters)
|
601
601
|
_ = RichTracebackFormatter.create_and_set(
|
602
|
-
|
602
|
+
console_high_and_exc_handler,
|
603
603
|
version=formatter_version,
|
604
604
|
max_width=formatter_max_width,
|
605
605
|
indent_size=formatter_indent_size,
|
@@ -610,10 +610,10 @@ def setup_logging(
|
|
610
610
|
detail=True,
|
611
611
|
post=_ansi_wrap_red,
|
612
612
|
)
|
613
|
-
|
613
|
+
console_high_and_exc_handler.setLevel(
|
614
614
|
max(get_logging_level_number(console_level), ERROR)
|
615
615
|
)
|
616
|
-
logger_use.addHandler(
|
616
|
+
logger_use.addHandler(console_high_and_exc_handler)
|
617
617
|
|
618
618
|
# debug & info
|
619
619
|
directory = resolve_path(path=files_dir) # skipif-ci-and-windows
|
@@ -640,7 +640,7 @@ def setup_logging(
|
|
640
640
|
standalone_file_handler = StandaloneFileHandler( # skipif-ci-and-windows
|
641
641
|
level=ERROR, path=directory.joinpath("errors")
|
642
642
|
)
|
643
|
-
add_filters(standalone_file_handler,
|
643
|
+
add_filters(standalone_file_handler, _standalone_file_filter)
|
644
644
|
standalone_file_handler.setFormatter(
|
645
645
|
RichTracebackFormatter(
|
646
646
|
version=formatter_version,
|
@@ -660,6 +660,16 @@ def setup_logging(
|
|
660
660
|
extra(logger_use)
|
661
661
|
|
662
662
|
|
663
|
+
def _console_low_or_no_exc_filter(record: LogRecord, /) -> bool:
|
664
|
+
return (record.levelno < ERROR) or (
|
665
|
+
(record.levelno >= ERROR) and (record.exc_info is None)
|
666
|
+
)
|
667
|
+
|
668
|
+
|
669
|
+
def _standalone_file_filter(record: LogRecord, /) -> bool:
|
670
|
+
return record.exc_info is not None
|
671
|
+
|
672
|
+
|
663
673
|
##
|
664
674
|
|
665
675
|
|
utilities/traceback.py
CHANGED
@@ -60,6 +60,9 @@ _CALL_ARGS = "_CALL_ARGS"
|
|
60
60
|
_INDENT = 4 * " "
|
61
61
|
|
62
62
|
|
63
|
+
##
|
64
|
+
|
65
|
+
|
63
66
|
class RichTracebackFormatter(Formatter):
|
64
67
|
"""Formatter for rich tracebacks."""
|
65
68
|
|
@@ -162,10 +165,17 @@ class RichTracebackFormatter(Formatter):
|
|
162
165
|
detail=detail,
|
163
166
|
post=post,
|
164
167
|
)
|
165
|
-
handler.addFilter(
|
168
|
+
handler.addFilter(cls._has_exc_info)
|
166
169
|
handler.setFormatter(formatter)
|
167
170
|
return formatter
|
168
171
|
|
172
|
+
@classmethod
|
173
|
+
def _has_exc_info(cls, record: LogRecord, /) -> bool:
|
174
|
+
return record.exc_info is not None
|
175
|
+
|
176
|
+
|
177
|
+
##
|
178
|
+
|
169
179
|
|
170
180
|
@dataclass(repr=False, kw_only=True, slots=True)
|
171
181
|
class _CallArgs:
|
@@ -470,6 +480,9 @@ class _Frame:
|
|
470
480
|
return indent("\n".join(lines), depth * _INDENT)
|
471
481
|
|
472
482
|
|
483
|
+
##
|
484
|
+
|
485
|
+
|
473
486
|
def get_rich_traceback(
|
474
487
|
error: TBaseException,
|
475
488
|
/,
|
File without changes
|
File without changes
|