view libervia/desktop_kivy/core/kivy_hack.py @ 508:d87b9a6b0b69

doc (calls): updated documentation to describe the new UI features: fix 425
author Goffi <goffi@goffi.org>
date Wed, 25 Oct 2023 15:29:33 +0200
parents 59bdf78bd1d9
children
line wrap: on
line source

#!/usr//bin/env python3

#Libervia Desktop-Kivy
# Copyright (C) 2016-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/>.

from .constants import Const as C
from libervia.backend.core import log_config
import os
import sys


def do_hack():
    """work around Kivy hijacking of logs and arguments"""
    # we remove args so kivy doesn't use them
    # this is need to avoid kivy breaking QuickApp args handling
    ori_argv = sys.argv[:]
    sys.argv = sys.argv[:1]
    log_config.libervia_configure(C.LOG_BACKEND_STANDARD, C)

    os.environ["KIVY_LOG_MODE"] = "PYTHON"

    import kivy
    assert kivy # to avoid pyflakes warning

    # we restore original arguments
    sys.argv = ori_argv