Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
20 changes: 20 additions & 0 deletions hexrdgui/ignore_warnings.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
"""Suppress known harmless warnings. Call apply() early in main.py."""

import os
import warnings


def apply():
# Suppress harmless leaked semaphore warning from loky at shutdown.
# The resource_tracker runs as a separate daemon process, so
# warnings.filterwarnings only covers the main process. We also
# set PYTHONWARNINGS so the filter propagates to the tracker.
warnings.filterwarnings(
'ignore',
message=r'resource_tracker:.*leaked semaphore',
category=UserWarning,
)
_pw = os.environ.get('PYTHONWARNINGS', '')
_filter = 'ignore:resource_tracker:UserWarning'
if _filter not in _pw:
os.environ['PYTHONWARNINGS'] = f'{_pw},{_filter}' if _pw else _filter
13 changes: 5 additions & 8 deletions hexrdgui/main.py
Original file line number Diff line number Diff line change
@@ -1,17 +1,14 @@
# Must be first - sets env vars before any child processes are spawned
from hexrdgui.ignore_warnings import apply as apply_warning_filters

apply_warning_filters()

import argparse
import atexit
import gc
import os
import signal
import sys
import warnings

# Suppress harmless leaked semaphore warning from loky at shutdown
warnings.filterwarnings(
'ignore',
message=r'resource_tracker:.*leaked semaphore',
category=UserWarning,
)

if sys.platform.startswith('darwin'):
# Prevent crashing when using OpenBLAS
Expand Down
Loading