Skip to content

Commit

Permalink
🚧 Test caching DeferLoad
Browse files Browse the repository at this point in the history
Signed-off-by: ff137 <ff137@proton.me>
  • Loading branch information
ff137 committed Nov 28, 2024
1 parent c13e645 commit 4d41633
Showing 1 changed file with 8 additions and 5 deletions.
13 changes: 8 additions & 5 deletions acapy_agent/utils/classloader.py
Original file line number Diff line number Diff line change
Expand Up @@ -233,22 +233,25 @@ def scan_subpackages(cls, package: str) -> Sequence[str]:
class DeferLoad:
"""Helper to defer loading of a class definition."""

_class_cache = {} # Shared cache for resolved classes

def __init__(self, cls_path: str):
"""Initialize the `DeferLoad` instance with a qualified class path."""
self._cls_path = cls_path
self._inst = None

def __call__(self, *args, **kwargs):
"""Magic method to call the `DeferLoad` as a function."""
LOGGER.debug("Calling deferred class load for: %s", self._cls_path)
return (self.resolved)(*args, **kwargs)
return self.resolved(*args, **kwargs)

@property
def resolved(self):
"""Accessor for the resolved class instance."""
LOGGER.debug("Resolving deferred class load for: %s", self._cls_path)
if not self._inst:
if self._cls_path not in DeferLoad._class_cache:
LOGGER.debug("Class not yet loaded, loading: %s", self._cls_path)
self._inst = ClassLoader.load_class(self._cls_path)
DeferLoad._class_cache[self._cls_path] = ClassLoader.load_class(
self._cls_path
)
LOGGER.debug("Successfully loaded class: %s", self._cls_path)
return self._inst
return DeferLoad._class_cache[self._cls_path]

0 comments on commit 4d41633

Please sign in to comment.