logger and fix up the parent/child references which pointed to the
placeholder to now point to the logger.
"""
- rv = None
if not isinstance(name, str):
raise TypeError('A logger name must be a string')
+ # Fast path: an already-registered, non-placeholder logger can be
+ # returned without taking the lock. dict.get() is atomic under both
+ # the GIL and free threading, and a Logger is fully initialised before
+ # being inserted into loggerDict under the lock, so this never sees a
+ # partially-constructed object.
+ rv = self.loggerDict.get(name)
+ if rv is not None and not isinstance(rv, PlaceHolder):
+ return rv
with _lock:
if name in self.loggerDict:
rv = self.loggerDict[name]