in awswrangler/_utils.py [0:0]
def ensure_cpu_count(use_threads: bool | int = True) -> int:
"""Get the number of cpu cores to be used.
Note
----
In case of `use_threads=True` the number of threads that could be spawned will be get from os.cpu_count().
Parameters
----------
use_threads : Union[bool, int]
True to enable multi-core utilization, False to disable.
If given an int will simply return the input value.
Returns
-------
int
Number of cpu cores to be used.
Examples
--------
>>> from awswrangler._utils import ensure_cpu_count
>>> ensure_cpu_count(use_threads=True)
4
>>> ensure_cpu_count(use_threads=False)
1
"""
if type(use_threads) == int: # noqa: E721
if use_threads < 1:
return 1
return use_threads
cpus: int = 1
if use_threads is True:
cpu_cnt: int | None = os.cpu_count()
if cpu_cnt is not None:
cpus = cpu_cnt if cpu_cnt > cpus else cpus
return cpus