|
"""Utility helpers to handle progress bars in `datasets`. |
|
|
|
Example: |
|
1. Use `datasets.utils.tqdm` as you would use `tqdm.tqdm` or `tqdm.auto.tqdm`. |
|
2. To disable progress bars, either use `disable_progress_bars()` helper or set the |
|
environment variable `HF_DATASETS_DISABLE_PROGRESS_BARS` to 1. |
|
3. To re-enable progress bars, use `enable_progress_bars()`. |
|
4. To check whether progress bars are disabled, use `are_progress_bars_disabled()`. |
|
|
|
NOTE: Environment variable `HF_DATASETS_DISABLE_PROGRESS_BARS` has the priority. |
|
|
|
Example: |
|
```py |
|
from datasets.utils import ( |
|
are_progress_bars_disabled, |
|
disable_progress_bars, |
|
enable_progress_bars, |
|
tqdm, |
|
) |
|
|
|
# Disable progress bars globally |
|
disable_progress_bars() |
|
|
|
# Use as normal `tqdm` |
|
for _ in tqdm(range(5)): |
|
do_something() |
|
|
|
# Still not showing progress bars, as `disable=False` is overwritten to `True`. |
|
for _ in tqdm(range(5), disable=False): |
|
do_something() |
|
|
|
are_progress_bars_disabled() # True |
|
|
|
# Re-enable progress bars globally |
|
enable_progress_bars() |
|
|
|
# Progress bar will be shown ! |
|
for _ in tqdm(range(5)): |
|
do_something() |
|
``` |
|
""" |
|
|
|
import warnings |
|
|
|
from tqdm.auto import tqdm as old_tqdm |
|
|
|
from ..config import HF_DATASETS_DISABLE_PROGRESS_BARS |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_hf_datasets_progress_bars_disabled: bool = HF_DATASETS_DISABLE_PROGRESS_BARS or False |
|
|
|
|
|
def disable_progress_bars() -> None: |
|
""" |
|
Disable globally progress bars used in `datasets` except if `HF_DATASETS_DISABLE_PROGRESS_BAR` environment |
|
variable has been set. |
|
|
|
Use [`~utils.enable_progress_bars`] to re-enable them. |
|
""" |
|
if HF_DATASETS_DISABLE_PROGRESS_BARS is False: |
|
warnings.warn( |
|
"Cannot disable progress bars: environment variable `HF_DATASETS_DISABLE_PROGRESS_BAR=0` is set and has" |
|
" priority." |
|
) |
|
return |
|
global _hf_datasets_progress_bars_disabled |
|
_hf_datasets_progress_bars_disabled = True |
|
|
|
|
|
def enable_progress_bars() -> None: |
|
""" |
|
Enable globally progress bars used in `datasets` except if `HF_DATASETS_DISABLE_PROGRESS_BAR` environment |
|
variable has been set. |
|
|
|
Use [`~utils.disable_progress_bars`] to disable them. |
|
""" |
|
if HF_DATASETS_DISABLE_PROGRESS_BARS is True: |
|
warnings.warn( |
|
"Cannot enable progress bars: environment variable `HF_DATASETS_DISABLE_PROGRESS_BAR=1` is set and has" |
|
" priority." |
|
) |
|
return |
|
global _hf_datasets_progress_bars_disabled |
|
_hf_datasets_progress_bars_disabled = False |
|
|
|
|
|
def are_progress_bars_disabled() -> bool: |
|
"""Return whether progress bars are globally disabled or not. |
|
|
|
Progress bars used in `datasets` can be enable or disabled globally using [`~utils.enable_progress_bars`] |
|
and [`~utils.disable_progress_bars`] or by setting `HF_DATASETS_DISABLE_PROGRESS_BAR` as environment variable. |
|
""" |
|
global _hf_datasets_progress_bars_disabled |
|
return _hf_datasets_progress_bars_disabled |
|
|
|
|
|
class tqdm(old_tqdm): |
|
""" |
|
Class to override `disable` argument in case progress bars are globally disabled. |
|
|
|
Taken from https://github.com/tqdm/tqdm/issues/619#issuecomment-619639324. |
|
""" |
|
|
|
def __init__(self, *args, **kwargs): |
|
if are_progress_bars_disabled(): |
|
kwargs["disable"] = True |
|
super().__init__(*args, **kwargs) |
|
|
|
def __delattr__(self, attr: str) -> None: |
|
"""Fix for https://github.com/huggingface/datasets/issues/6066""" |
|
try: |
|
super().__delattr__(attr) |
|
except AttributeError: |
|
if attr != "_lock": |
|
raise |
|
|
|
|
|
|
|
enable_progress_bar = enable_progress_bars |
|
disable_progress_bar = disable_progress_bars |
|
|
|
|
|
def is_progress_bar_enabled(): |
|
return not are_progress_bars_disabled() |
|
|