diff libervia/backend/tools/common/dynamic_import.py @ 4071:4b842c1fb686

refactoring: renamed `sat` package to `libervia.backend`
author Goffi <goffi@goffi.org>
date Fri, 02 Jun 2023 11:49:51 +0200
parents sat/tools/common/dynamic_import.py@524856bd7b19
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/libervia/backend/tools/common/dynamic_import.py	Fri Jun 02 11:49:51 2023 +0200
@@ -0,0 +1,43 @@
+#!/usr/bin/env python3
+
+# Libervia: an XMPP client
+# Copyright (C) 2009-2021 Jérôme Poisson (goffi@goffi.org)
+
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU Affero General Public License for more details.
+
+# You should have received a copy of the GNU Affero General Public License
+# along with this program.  If not, see <http://www.gnu.org/licenses/>.
+
+""" tools dynamic import """
+
+from importlib import import_module
+from libervia.backend.core.log import getLogger
+
+
+log = getLogger(__name__)
+
+
+def bridge(name, module_path="libervia.backend.bridge"):
+    """import bridge module
+
+    @param module_path(str): path of the module to import
+    @param name(str): name of the bridge to import (e.g.: dbus)
+    @return (module, None): imported module or None if nothing is found
+    """
+    try:
+        bridge_module = import_module(module_path + "." + name)
+    except ImportError:
+        try:
+            bridge_module = import_module(module_path + "." + name + "_bridge")
+        except ImportError as e:
+            log.warning(f"Can't import bridge {name!r}: {e}")
+            bridge_module = None
+    return bridge_module