File: init.py

package info (click to toggle)
python-pyface 8.0.0-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 13,944 kB
  • sloc: python: 54,107; makefile: 82
file content (46 lines) | stat: -rw-r--r-- 1,605 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
# (C) Copyright 2007 Riverbank Computing Limited
# (C) Copyright 2005-2023 Enthought, Inc., Austin, TX
# All rights reserved.
#
# This software is provided without warranty under the terms of the BSD
# license included in LICENSE.txt and may be redistributed only under
# the conditions described in the aforementioned license. The license
# is also available online at http://www.enthought.com/licenses/BSD.txt
#
# Thanks for using Enthought open source!


import sys

from traits.trait_notifiers import set_ui_handler, ui_handler

from pyface.qt import QtGui
from pyface.base_toolkit import Toolkit
from .gui import GUI

# It's possible that it has already been initialised.
_app = QtGui.QApplication.instance()

if _app is None:
    try:
        # pyface.qt.QtWebKit tries QtWebEngineWidgets first, but
        # if QtWebEngineWidgets is present, it must be imported prior to
        # creating a QCoreApplication instance, otherwise importing
        # QtWebEngineWidgets later would fail (see enthought/pyface#581).
        # Import it here first before creating the instance.
        from pyface.qt import QtWebKit  # noqa: F401
    except ImportError:
        # This error will be raised in the context where
        # QtWebKit/QtWebEngine widgets are required.
        pass
    _app = QtGui.QApplication(sys.argv)


# create the toolkit object
toolkit_object = Toolkit("pyface", "qt", "pyface.ui.qt")


# ensure that Traits has a UI handler appropriate for the toolkit.
if ui_handler is None:
    # Tell the traits notification handlers to use this UI handler
    set_ui_handler(GUI.invoke_later)