mirror of
https://github.com/simonw/datasette.git
synced 2025-12-10 16:51:24 +01:00
datasette.utils.check_callable(obj) - refs #2078
This commit is contained in:
parent
49184c569c
commit
2e43a14da1
2 changed files with 71 additions and 0 deletions
25
datasette/utils/callable.py
Normal file
25
datasette/utils/callable.py
Normal file
|
|
@ -0,0 +1,25 @@
|
|||
import asyncio
|
||||
import types
|
||||
from typing import NamedTuple, Any
|
||||
|
||||
|
||||
class CallableStatus(NamedTuple):
|
||||
is_callable: bool
|
||||
is_async_callable: bool
|
||||
|
||||
|
||||
def check_callable(obj: Any) -> CallableStatus:
|
||||
if not callable(obj):
|
||||
return CallableStatus(False, False)
|
||||
|
||||
if isinstance(obj, type):
|
||||
# It's a class
|
||||
return CallableStatus(True, False)
|
||||
|
||||
if isinstance(obj, types.FunctionType):
|
||||
return CallableStatus(True, asyncio.iscoroutinefunction(obj))
|
||||
|
||||
if hasattr(obj, "__call__"):
|
||||
return CallableStatus(True, asyncio.iscoroutinefunction(obj.__call__))
|
||||
|
||||
assert False, "obj {} is somehow callable with no __call__ method".format(repr(obj))
|
||||
Loading…
Add table
Add a link
Reference in a new issue