bear-utils 0.8.1__tar.gz → 0.8.3__tar.gz

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.
Files changed (109) hide show
  1. {bear_utils-0.8.1 → bear_utils-0.8.3}/.bumpversion.cfg +1 -1
  2. {bear_utils-0.8.1 → bear_utils-0.8.3}/PKG-INFO +3 -3
  3. {bear_utils-0.8.1 → bear_utils-0.8.3}/README.md +2 -2
  4. {bear_utils-0.8.1 → bear_utils-0.8.3}/pyproject.toml +1 -1
  5. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/constants/logger_protocol.py +5 -5
  6. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/logger_manager/loggers/_console_logger.pyi +0 -1
  7. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/logger_manager/loggers/_file_logger.py +0 -2
  8. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/logger_manager/loggers/_sub_logger.py +0 -1
  9. {bear_utils-0.8.1 → bear_utils-0.8.3}/tests/test_logger.py +12 -16
  10. {bear_utils-0.8.1 → bear_utils-0.8.3}/.gitignore +0 -0
  11. {bear_utils-0.8.1 → bear_utils-0.8.3}/.python-version +0 -0
  12. {bear_utils-0.8.1 → bear_utils-0.8.3}/AGENTS.md +0 -0
  13. {bear_utils-0.8.1 → bear_utils-0.8.3}/config/coverage.ini +0 -0
  14. {bear_utils-0.8.1 → bear_utils-0.8.3}/config/default.toml +0 -0
  15. {bear_utils-0.8.1 → bear_utils-0.8.3}/config/git-changelog.toml +0 -0
  16. {bear_utils-0.8.1 → bear_utils-0.8.3}/config/pytest.ini +0 -0
  17. {bear_utils-0.8.1 → bear_utils-0.8.3}/config/ruff.toml +0 -0
  18. {bear_utils-0.8.1 → bear_utils-0.8.3}/config/vscode/launch.json +0 -0
  19. {bear_utils-0.8.1 → bear_utils-0.8.3}/config/vscode/settings.json +0 -0
  20. {bear_utils-0.8.1 → bear_utils-0.8.3}/config/vscode/tasks.json +0 -0
  21. {bear_utils-0.8.1 → bear_utils-0.8.3}/directory_structure.txt +0 -0
  22. {bear_utils-0.8.1 → bear_utils-0.8.3}/maskfile.md +0 -0
  23. {bear_utils-0.8.1 → bear_utils-0.8.3}/noxfile.py +0 -0
  24. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/__init__.py +0 -0
  25. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/__main__.py +0 -0
  26. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/_internal/__init__.py +0 -0
  27. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/_internal/cli.py +0 -0
  28. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/_internal/debug.py +0 -0
  29. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/ai/__init__.py +0 -0
  30. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/ai/ai_helpers/__init__.py +0 -0
  31. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/ai/ai_helpers/_common.py +0 -0
  32. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/ai/ai_helpers/_config.py +0 -0
  33. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/ai/ai_helpers/_parsers.py +0 -0
  34. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/ai/ai_helpers/_types.py +0 -0
  35. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/cache/__init__.py +0 -0
  36. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/cli/__init__.py +0 -0
  37. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/cli/commands.py +0 -0
  38. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/cli/prompt_helpers.py +0 -0
  39. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/cli/shell/__init__.py +0 -0
  40. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/cli/shell/_base_command.py +0 -0
  41. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/cli/shell/_base_shell.py +0 -0
  42. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/cli/shell/_common.py +0 -0
  43. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/config/__init__.py +0 -0
  44. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/config/config_manager.py +0 -0
  45. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/config/dir_manager.py +0 -0
  46. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/config/settings_manager.py +0 -0
  47. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/constants/__init__.py +0 -0
  48. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/constants/_exceptions.py +0 -0
  49. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/constants/_lazy_typing.py +0 -0
  50. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/constants/date_related.py +0 -0
  51. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/constants/time_related.py +0 -0
  52. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/database/__init__.py +0 -0
  53. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/database/_db_manager.py +0 -0
  54. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/events/__init__.py +0 -0
  55. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/events/events_class.py +0 -0
  56. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/events/events_module.py +0 -0
  57. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/extras/__init__.py +0 -0
  58. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/extras/_async_helpers.py +0 -0
  59. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/extras/_tools.py +0 -0
  60. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/extras/platform_utils.py +0 -0
  61. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/extras/responses/__init__.py +0 -0
  62. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/extras/responses/function_response.py +0 -0
  63. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/extras/wrappers/__init__.py +0 -0
  64. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/extras/wrappers/add_methods.py +0 -0
  65. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/files/__init__.py +0 -0
  66. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/files/file_handlers/__init__.py +0 -0
  67. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/files/file_handlers/_base_file_handler.py +0 -0
  68. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/files/file_handlers/file_handler_factory.py +0 -0
  69. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/files/file_handlers/json_file_handler.py +0 -0
  70. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/files/file_handlers/log_file_handler.py +0 -0
  71. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/files/file_handlers/toml_file_handler.py +0 -0
  72. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/files/file_handlers/txt_file_handler.py +0 -0
  73. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/files/file_handlers/yaml_file_handler.py +0 -0
  74. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/files/ignore_parser.py +0 -0
  75. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/graphics/__init__.py +0 -0
  76. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/graphics/bear_gradient.py +0 -0
  77. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/graphics/image_helpers.py +0 -0
  78. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/gui/__init__.py +0 -0
  79. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/gui/gui_tools/__init__.py +0 -0
  80. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/gui/gui_tools/_settings.py +0 -0
  81. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/gui/gui_tools/_types.py +0 -0
  82. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/gui/gui_tools/qt_app.py +0 -0
  83. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/gui/gui_tools/qt_color_picker.py +0 -0
  84. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/gui/gui_tools/qt_file_handler.py +0 -0
  85. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/gui/gui_tools/qt_input_dialog.py +0 -0
  86. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/logger_manager/__init__.py +0 -0
  87. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/logger_manager/_common.py +0 -0
  88. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/logger_manager/_console_junk.py +0 -0
  89. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/logger_manager/_styles.py +0 -0
  90. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/logger_manager/loggers/__init__.py +0 -0
  91. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/logger_manager/loggers/_base_logger.py +0 -0
  92. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/logger_manager/loggers/_base_logger.pyi +0 -0
  93. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/logger_manager/loggers/_buffer_logger.py +0 -0
  94. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/logger_manager/loggers/_console_logger.py +0 -0
  95. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/logger_manager/loggers/_level_sin.py +0 -0
  96. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/logger_manager/loggers/_logger.py +0 -0
  97. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/logger_manager/loggers/_sub_logger.pyi +0 -0
  98. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/monitoring/__init__.py +0 -0
  99. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/monitoring/_common.py +0 -0
  100. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/monitoring/host_monitor.py +0 -0
  101. {bear_utils-0.8.1 → bear_utils-0.8.3}/src/bear_utils/time/__init__.py +0 -0
  102. {bear_utils-0.8.1 → bear_utils-0.8.3}/tests/__init__.py +0 -0
  103. {bear_utils-0.8.1 → bear_utils-0.8.3}/tests/test_add_ord_suffix.py +0 -0
  104. {bear_utils-0.8.1 → bear_utils-0.8.3}/tests/test_clipboard.py +0 -0
  105. {bear_utils-0.8.1 → bear_utils-0.8.3}/tests/test_default_shell.py +0 -0
  106. {bear_utils-0.8.1 → bear_utils-0.8.3}/tests/test_function_response.py +0 -0
  107. {bear_utils-0.8.1 → bear_utils-0.8.3}/tests/test_gradient.py +0 -0
  108. {bear_utils-0.8.1 → bear_utils-0.8.3}/tests/test_platform_utils.py +0 -0
  109. {bear_utils-0.8.1 → bear_utils-0.8.3}/uv.lock +0 -0
@@ -1,5 +1,5 @@
1
1
  [bumpversion]
2
- current_version = 0.8.1
2
+ current_version = 0.8.3
3
3
 
4
4
  [bumpversion:file:pyproject.toml]
5
5
 
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: bear-utils
3
- Version: 0.8.1
3
+ Version: 0.8.3
4
4
  Summary: Various utilities for Bear programmers, including a rich logging utility, a disk cache, and a SQLite database wrapper amongst other things.
5
5
  Author-email: chaz <bright.lid5647@fastmail.com>
6
6
  Requires-Python: >=3.12
@@ -20,7 +20,7 @@ Requires-Dist: tinydb>=4.8.2
20
20
  Requires-Dist: toml>=0.10.2
21
21
  Description-Content-Type: text/markdown
22
22
 
23
- # Bear Utils v# Bear Utils v0.8.1
23
+ # Bear Utils v# Bear Utils v0.8.3
24
24
 
25
25
  Personal set of tools and utilities for Python projects, focusing on modularity and ease of use. This library includes components for caching, database management, logging, time handling, file operations, CLI prompts, image processing, clipboard interaction, gradient utilities, event systems, and async helpers.
26
26
 
@@ -87,7 +87,7 @@ with db.session() as session:
87
87
  The `logging` package provides an enhanced console logger using rich:
88
88
 
89
89
  ```python
90
- from bear_utils.logging import ConsoleLogger
90
+ from bear_utils.logger_manager import ConsoleLogger
91
91
 
92
92
  logger = ConsoleLogger()
93
93
  logger.info("Information message")
@@ -1,4 +1,4 @@
1
- # Bear Utils v# Bear Utils v0.8.1
1
+ # Bear Utils v# Bear Utils v0.8.3
2
2
 
3
3
  Personal set of tools and utilities for Python projects, focusing on modularity and ease of use. This library includes components for caching, database management, logging, time handling, file operations, CLI prompts, image processing, clipboard interaction, gradient utilities, event systems, and async helpers.
4
4
 
@@ -65,7 +65,7 @@ with db.session() as session:
65
65
  The `logging` package provides an enhanced console logger using rich:
66
66
 
67
67
  ```python
68
- from bear_utils.logging import ConsoleLogger
68
+ from bear_utils.logger_manager import ConsoleLogger
69
69
 
70
70
  logger = ConsoleLogger()
71
71
  logger.info("Information message")
@@ -1,6 +1,6 @@
1
1
  [project]
2
2
  name = "bear-utils"
3
- version = "0.8.1"
3
+ version = "0.8.3"
4
4
  description = "Various utilities for Bear programmers, including a rich logging utility, a disk cache, and a SQLite database wrapper amongst other things."
5
5
  authors = [{ name = "chaz", email = "bright.lid5647@fastmail.com" }]
6
6
  readme = "README.md"
@@ -7,22 +7,22 @@ from typing import Protocol, runtime_checkable
7
7
  class LoggerProtocol(Protocol):
8
8
  """A protocol for logging classes."""
9
9
 
10
- def debug(self, message: object, *args, **kwargs) -> None:
10
+ def debug(self, msg: object, *args, **kwargs) -> None:
11
11
  """Log a debug message."""
12
12
  ...
13
13
 
14
- def info(self, message: object, *args, **kwargs) -> None:
14
+ def info(self, msg: object, *args, **kwargs) -> None:
15
15
  """Log an info message."""
16
16
  ...
17
17
 
18
- def warning(self, message: object, *args, **kwargs) -> None:
18
+ def warning(self, msg: object, *args, **kwargs) -> None:
19
19
  """Log a warning message."""
20
20
  ...
21
21
 
22
- def error(self, message: object, *args, **kwargs) -> None:
22
+ def error(self, msg: object, *args, **kwargs) -> None:
23
23
  """Log an error message."""
24
24
  ...
25
25
 
26
- def verbose(self, message: object, *args, **kwargs) -> None:
26
+ def verbose(self, msg: object, *args, **kwargs) -> None:
27
27
  """Log a verbose message."""
28
28
  ...
@@ -6,7 +6,6 @@ from rich.text import Text
6
6
  from rich.theme import Theme
7
7
 
8
8
  from bear_utils.logger_manager._console_junk import ConsoleBuffering, ConsoleHandler
9
- from bear_utils.logging.logger_manager._console_junk import ConsoleBuffering, ConsoleHandler
10
9
 
11
10
  from ._base_logger import BaseLogger
12
11
  from ._sub_logger import SubConsoleLogger
@@ -5,14 +5,12 @@ from typing import TYPE_CHECKING, Any, override
5
5
  from rich.theme import Theme
6
6
 
7
7
  from bear_utils.logger_manager._common import FIVE_MEGABYTES
8
- from bear_utils.logging.logger_manager._common import FIVE_MEGABYTES
9
8
 
10
9
  from ._console_logger import ConsoleLogger
11
10
  from ._sub_logger import SubConsoleLogger
12
11
 
13
12
  if TYPE_CHECKING:
14
13
  from bear_utils.logger_manager._styles import LoggerExtraInfo
15
- from bear_utils.logging.logger_manager._styles import LoggerExtraInfo
16
14
 
17
15
 
18
16
  class FileLogger(ConsoleLogger):
@@ -10,7 +10,6 @@ from typing import TYPE_CHECKING, Any, Generic, TypeVar
10
10
  from rich.text import Text
11
11
 
12
12
  from bear_utils.logger_manager._styles import LOGGER_METHODS, LoggerExtraInfo
13
- from bear_utils.logging.logger_manager._styles import LOGGER_METHODS, LoggerExtraInfo
14
13
 
15
14
  from ._level_sin import check_level
16
15
 
@@ -5,13 +5,8 @@ from unittest.mock import patch
5
5
  import pytest
6
6
  from rich.console import Console
7
7
 
8
- <<<<<<< HEAD
9
8
  from bear_utils import VERBOSE, BufferLogger, ConsoleLogger, FileLogger
10
9
  from bear_utils.extras import fmt_header
11
- =======
12
- from bear_utils.extras._tools import fmt_header
13
- from bear_utils.logging import VERBOSE, BufferLogger, ConsoleLogger, FileLogger
14
- >>>>>>> main
15
10
 
16
11
  console = Console()
17
12
 
@@ -21,10 +16,11 @@ class TestLoggerFactory:
21
16
 
22
17
  @staticmethod
23
18
  def create_console_logger(**kwargs) -> ConsoleLogger:
19
+ """Create a ConsoleLogger instance for testing."""
24
20
  if ConsoleLogger.has_instance():
25
21
  ConsoleLogger.reset_instance()
26
22
 
27
- import logging
23
+ import logging # noqa: PLC0415
28
24
 
29
25
  logging.getLogger().handlers.clear()
30
26
 
@@ -39,15 +35,15 @@ class TestLoggerFactory:
39
35
  "logger_mode": True,
40
36
  }
41
37
  defaults.update(kwargs)
42
- instance = ConsoleLogger.get_instance(init=True, **defaults)
43
- return instance
38
+ return ConsoleLogger.get_instance(init=True, **defaults)
44
39
 
45
40
  @staticmethod
46
- def create_file_logger(**kwargs):
41
+ def create_file_logger(**kwargs) -> FileLogger:
42
+ """Create a FileLogger instance for testing."""
47
43
  if FileLogger.has_instance():
48
44
  FileLogger.reset_instance()
49
45
 
50
- import logging
46
+ import logging # noqa: PLC0415
51
47
 
52
48
  logging.getLogger().handlers.clear()
53
49
 
@@ -67,7 +63,7 @@ class TestLoggerFactory:
67
63
  if BufferLogger.has_instance():
68
64
  BufferLogger.reset_instance()
69
65
 
70
- import logging
66
+ import logging # noqa: PLC0415
71
67
 
72
68
  logging.getLogger().handlers.clear()
73
69
 
@@ -234,7 +230,7 @@ class TestVisualVerification:
234
230
  with capsys.disabled():
235
231
  fmt_header("Visual Test: Traceback Verification")
236
232
  try:
237
- v = 200 / 0
233
+ v: float = 200 / 0 # noqa: F841 # Intentionally cause a ZeroDivisionError
238
234
  except Exception:
239
235
  logger.error("Test", exc_info=True)
240
236
 
@@ -248,7 +244,7 @@ class TestVisualVerification:
248
244
  fmt_header("Visual Test: Sub Logger Traceback Verification")
249
245
 
250
246
  try:
251
- v = 200 / 0
247
+ v: float = 200 / 0 # noqa: F841 # Intentionally cause a ZeroDivisionError
252
248
  except Exception:
253
249
  sub_logger.error("SubLogger Test", exc_info=True)
254
250
 
@@ -257,8 +253,8 @@ class TestVisualVerification:
257
253
 
258
254
  def test_buffer_logger(self):
259
255
  """Test that BufferLogger works correctly."""
260
- from contextlib import redirect_stdout
261
- from io import StringIO
256
+ from contextlib import redirect_stdout # noqa: PLC0415
257
+ from io import StringIO # noqa: PLC0415
262
258
 
263
259
  logger: BufferLogger = TestLoggerFactory.create_buffer_logger()
264
260
  fmt_header("Test Buffer Logger")
@@ -294,7 +290,7 @@ class TestVisualVerification:
294
290
  fmt_header("Visual Test: Buffer Logger Traceback Verification")
295
291
 
296
292
  try:
297
- v = 200 / 0
293
+ v: float = 200 / 0 # noqa: F841 # Intentionally cause a ZeroDivisionError
298
294
  except Exception:
299
295
  logger.error("BufferLogger Test happened on purpose!", exc_info=True)
300
296
 
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes