aboutsummaryrefslogtreecommitdiffstats
path: root/sources/shiboken2/libshiboken/embed/signature_bootstrap.py
diff options
context:
space:
mode:
Diffstat (limited to 'sources/shiboken2/libshiboken/embed/signature_bootstrap.py')
-rw-r--r--sources/shiboken2/libshiboken/embed/signature_bootstrap.py180
1 files changed, 0 insertions, 180 deletions
diff --git a/sources/shiboken2/libshiboken/embed/signature_bootstrap.py b/sources/shiboken2/libshiboken/embed/signature_bootstrap.py
deleted file mode 100644
index eb182d8c4..000000000
--- a/sources/shiboken2/libshiboken/embed/signature_bootstrap.py
+++ /dev/null
@@ -1,180 +0,0 @@
-#############################################################################
-##
-## Copyright (C) 2019 The Qt Company Ltd.
-## Contact: https://www.qt.io/licensing/
-##
-## This file is part of PySide2.
-##
-## $QT_BEGIN_LICENSE:LGPL$
-## Commercial License Usage
-## Licensees holding valid commercial Qt licenses may use this file in
-## accordance with the commercial license agreement provided with the
-## Software or, alternatively, in accordance with the terms contained in
-## a written agreement between you and The Qt Company. For licensing terms
-## and conditions see https://www.qt.io/terms-conditions. For further
-## information use the contact form at https://www.qt.io/contact-us.
-##
-## GNU Lesser General Public License Usage
-## Alternatively, this file may be used under the terms of the GNU Lesser
-## General Public License version 3 as published by the Free Software
-## Foundation and appearing in the file LICENSE.LGPL3 included in the
-## packaging of this file. Please review the following information to
-## ensure the GNU Lesser General Public License version 3 requirements
-## will be met: https://www.gnu.org/licenses/lgpl-3.0.html.
-##
-## GNU General Public License Usage
-## Alternatively, this file may be used under the terms of the GNU
-## General Public License version 2.0 or (at your option) the GNU General
-## Public license version 3 or any later version approved by the KDE Free
-## Qt Foundation. The licenses are as published by the Free Software
-## Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3
-## included in the packaging of this file. Please review the following
-## information to ensure the GNU General Public License requirements will
-## be met: https://www.gnu.org/licenses/gpl-2.0.html and
-## https://www.gnu.org/licenses/gpl-3.0.html.
-##
-## $QT_END_LICENSE$
-##
-#############################################################################
-
-"""
-signature_bootstrap.py
-----------------------
-
-This file was originally directly embedded into the C source.
-After it grew more and more, I now prefer to have it as Python file.
-
-Meanwhile, there is also no more a stub loader necessary:
-Because we meanwhile have embedding support, we could also load this file
-directly from a .pyc file.
-
-This file replaces the hard to read Python stub in 'signature.cpp', and we
-could distinguish better between bootstrap related functions and loader
-functions.
-It is embedded into 'signature.cpp' as "embed/signature_bootstrap.inc".
-"""
-
-from __future__ import print_function, absolute_import
-
-recursion_trap = 0
-
-# We avoid real imports in phase 1 that could fail (simply removed all).
-# Python 2 is not able to import when the extension import is still active.
-# Phase 1 simply defines the functions, which will be used in Phase 2.
-
-def bootstrap():
- import sys
- import os
- import tempfile
- import traceback
- from contextlib import contextmanager
-
- global recursion_trap
- if recursion_trap:
- # we are probably called from outside, already
- print("Recursion occurred in Bootstrap. Did you start by hand? Then it's ok.")
- print("But you should trigger start by 'type.__signature__', only!")
- recursion_trap += 1
-
- @contextmanager
- def ensure_shibokensupport(support_path):
- # Make sure that we always have the shibokensupport containing package first.
- # Also remove any prior loaded module of this name, just in case.
- sys.path.insert(0, support_path)
-
- sbks = "shibokensupport"
- if sbks in sys.modules:
- del sys.modules[sbks]
- prefix = sbks + "."
- for key in list(key for key in sys.modules if key.startswith(prefix)):
- del sys.modules[key]
- try:
- import shibokensupport
- yield
- except Exception as e:
- print("Problem importing shibokensupport:")
- print(e)
- traceback.print_exc()
- print("sys.path:")
- for p in sys.path:
- print(" " + p)
- sys.stdout.flush()
- sys.exit(-1)
- sys.path.remove(support_path)
-
- try:
- import shiboken2 as root
- except ImportError:
- # uninstalled case without ctest, try only this one which has __init__:
- import shibokenmodule as root
- rp = os.path.realpath(os.path.dirname(root.__file__))
- # This can be the shiboken2 directory or the binary module, so search.
- look_for = os.path.join("files.dir", "shibokensupport", "signature", "loader.py")
- while len(rp) > 3 and not os.path.exists(os.path.join(rp, look_for)):
- rp = os.path.abspath(os.path.join(rp, ".."))
-
- # Here we decide if we work embedded or not.
- embedding_var = "pyside_uses_embedding"
- use_embedding = bool(getattr(sys, embedding_var, False))
- # We keep the zip file for inspection if the sys variable has been set.
- keep_zipfile = hasattr(sys, embedding_var)
- loader_path = os.path.join(rp, look_for)
- files_dir = os.path.abspath(os.path.join(loader_path, "..", "..", ".."))
- assert files_dir.endswith("files.dir")
-
- # We report in sys what we used. We could put more here as well.
- if not os.path.exists(loader_path):
- use_embedding = True
- support_path = prepare_zipfile() if use_embedding else files_dir
- setattr(sys, embedding_var, use_embedding)
-
- try:
- with ensure_shibokensupport(support_path):
- from shibokensupport.signature import loader
-
- except Exception as e:
- print('Exception:', e)
- traceback.print_exc(file=sys.stdout)
-
- finally:
- if use_embedding and not keep_zipfile:
- # clear the temp zipfile
- try:
- os.remove(support_path)
- except OSError as e:
- print(e)
- print("Error deleting {support_path}, ignored".format(**locals()))
- return loader
-
-# New functionality: Loading from a zip archive.
-# There exists the zip importer, but as it is written, only real zip files are
-# supported. Before I will start an own implementation, it is easiest to use
-# a temporary zip file.
-
-def prepare_zipfile():
- """
- Write the zip file to a real file and return its name.
- It will be implicitly opened as such when we add the name to sys.path .
- """
- import base64
- import tempfile
- import os
- import zipfile
-
- # 'zipstring_sequence' comes from signature.cpp
- zipbytes = base64.b64decode(''.join(zipstring_sequence))
- fd, fname = tempfile.mkstemp(prefix='embedded.', suffix='.zip')
- os.write(fd, zipbytes)
- os.close(fd)
- # Let us test the zipfile if it really is one.
- # Otherwise, zipimporter would simply ignore it without notice.
- try:
- z = zipfile.ZipFile(fname)
- z.close()
- except zipfile.BadZipFile as e:
- print('Broken Zip File:', e)
- traceback.print_exc(file=sys.stdout)
- finally:
- return fname
-
-# eof