mirror of
https://github.com/samba-team/samba.git
synced 2025-03-11 16:58:40 +03:00
third_party: Update waf to version 2.0.26
https://gitlab.com/ita1024/waf/-/blob/waf-2.0.26/ChangeLog Signed-off-by: Andreas Schneider <asn@samba.org> Reviewed-by: Andrew Bartlett <abartlet@samba.org> Autobuild-User(master): Andreas Schneider <asn@cryptomilk.org> Autobuild-Date(master): Wed Nov 29 10:47:00 UTC 2023 on atb-devel-224
This commit is contained in:
parent
e265162884
commit
c4a5d4eb62
2
buildtools/bin/waf
vendored
2
buildtools/bin/waf
vendored
@ -32,7 +32,7 @@ POSSIBILITY OF SUCH DAMAGE.
|
||||
|
||||
import os, sys, inspect
|
||||
|
||||
VERSION="2.0.25"
|
||||
VERSION="2.0.26"
|
||||
REVISION="x"
|
||||
GIT="x"
|
||||
INSTALL="x"
|
||||
|
@ -38,7 +38,7 @@ LIB_PATH="shared"
|
||||
|
||||
os.environ['PYTHONUNBUFFERED'] = '1'
|
||||
|
||||
if Context.HEXVERSION not in (0x2001900,):
|
||||
if Context.HEXVERSION not in (0x2001a00,):
|
||||
Logs.error('''
|
||||
Please use the version of waf that comes with Samba, not
|
||||
a system installed version. See http://wiki.samba.org/index.php/Waf
|
||||
|
6
third_party/waf/waflib/Context.py
vendored
6
third_party/waf/waflib/Context.py
vendored
@ -18,13 +18,13 @@ else:
|
||||
import imp
|
||||
|
||||
# the following 3 constants are updated on each new release (do not touch)
|
||||
HEXVERSION=0x2001900
|
||||
HEXVERSION=0x2001a00
|
||||
"""Constant updated on new releases"""
|
||||
|
||||
WAFVERSION="2.0.25"
|
||||
WAFVERSION="2.0.26"
|
||||
"""Constant updated on new releases"""
|
||||
|
||||
WAFREVISION="2db0b41b2805cd5db3b55476c06b23c1e46d319f"
|
||||
WAFREVISION="0fb985ce1932c6f3e7533f435e4ee209d673776e"
|
||||
"""Git revision when the waf version is updated"""
|
||||
|
||||
WAFNAME="waf"
|
||||
|
8
third_party/waf/waflib/Scripting.py
vendored
8
third_party/waf/waflib/Scripting.py
vendored
@ -388,7 +388,11 @@ class Dist(Context.Context):
|
||||
|
||||
for x in files:
|
||||
archive_name = self.get_base_name() + '/' + x.path_from(self.base_path)
|
||||
zip.write(x.abspath(), archive_name, zipfile.ZIP_DEFLATED)
|
||||
if os.environ.get('SOURCE_DATE_EPOCH'):
|
||||
# TODO: parse that timestamp
|
||||
zip.writestr(zipfile.ZipInfo(archive_name), x.read(), zipfile.ZIP_DEFLATED)
|
||||
else:
|
||||
zip.write(x.abspath(), archive_name, zipfile.ZIP_DEFLATED)
|
||||
zip.close()
|
||||
else:
|
||||
self.fatal('Valid algo types are tar.bz2, tar.gz, tar.xz or zip')
|
||||
@ -425,6 +429,8 @@ class Dist(Context.Context):
|
||||
tinfo.gid = 0
|
||||
tinfo.uname = 'root'
|
||||
tinfo.gname = 'root'
|
||||
if os.environ.get('SOURCE_DATE_EPOCH'):
|
||||
tinfo.mtime = int(os.environ.get('SOURCE_DATE_EPOCH'))
|
||||
|
||||
if os.path.isfile(p):
|
||||
with open(p, 'rb') as f:
|
||||
|
186
third_party/waf/waflib/Tools/qt5.py
vendored
186
third_party/waf/waflib/Tools/qt5.py
vendored
@ -1,10 +1,11 @@
|
||||
#!/usr/bin/env python
|
||||
# encoding: utf-8
|
||||
# Thomas Nagy, 2006-2018 (ita)
|
||||
# Rafaël Kooi, 2023 (RA-Kooi)
|
||||
|
||||
"""
|
||||
This tool helps with finding Qt5 tools and libraries,
|
||||
and also provides syntactic sugar for using Qt5 tools.
|
||||
This tool helps with finding Qt5 and Qt6 tools and libraries,
|
||||
and also provides syntactic sugar for using Qt5 and Qt6 tools.
|
||||
|
||||
The following snippet illustrates the tool usage::
|
||||
|
||||
@ -22,6 +23,23 @@ The following snippet illustrates the tool usage::
|
||||
target = 'window',
|
||||
)
|
||||
|
||||
Alternatively the following snippet illustrates Qt6 tool usage::
|
||||
|
||||
def options(opt):
|
||||
opt.load('compiler_cxx qt5')
|
||||
|
||||
def configure(conf):
|
||||
conf.want_qt6 = True
|
||||
conf.load('compiler_cxx qt5')
|
||||
|
||||
def build(bld):
|
||||
bld(
|
||||
features = 'qt6 cxx cxxprogram',
|
||||
uselib = 'QT6CORE QT6GUI QT6OPENGL QT6SVG',
|
||||
source = 'main.cpp textures.qrc aboutDialog.ui',
|
||||
target = 'window',
|
||||
)
|
||||
|
||||
Here, the UI description and resource files will be processed
|
||||
to generate code.
|
||||
|
||||
@ -56,25 +74,32 @@ Note: another tool provides Qt processing that does not require
|
||||
A few options (--qt{dir,bin,...}) and environment variables
|
||||
(QT5_{ROOT,DIR,MOC,UIC,XCOMPILE}) allow finer tuning of the tool,
|
||||
tool path selection, etc; please read the source for more info.
|
||||
For Qt6 replace the QT5_ prefix with QT6_.
|
||||
|
||||
The detection uses pkg-config on Linux by default. The list of
|
||||
libraries to be requested to pkg-config is formulated by scanning
|
||||
in the QTLIBS directory (that can be passed via --qtlibs or by
|
||||
setting the environment variable QT5_LIBDIR otherwise is derived
|
||||
by querying qmake for QT_INSTALL_LIBS directory) for shared/static
|
||||
libraries present.
|
||||
setting the environment variable QT5_LIBDIR or QT6_LIBDIR otherwise is
|
||||
derived by querying qmake for QT_INSTALL_LIBS directory) for
|
||||
shared/static libraries present.
|
||||
Alternatively the list of libraries to be requested via pkg-config
|
||||
can be set using the qt5_vars attribute, ie:
|
||||
|
||||
conf.qt5_vars = ['Qt5Core', 'Qt5Gui', 'Qt5Widgets', 'Qt5Test'];
|
||||
|
||||
For Qt6 use the qt6_vars attribute.
|
||||
|
||||
This can speed up configuration phase if needed libraries are
|
||||
known beforehand, can improve detection on systems with a
|
||||
sparse QT5 libraries installation (ie. NIX) and can improve
|
||||
sparse QT5/Qt6 libraries installation (ie. NIX) and can improve
|
||||
detection of some header-only Qt modules (ie. Qt5UiPlugin).
|
||||
|
||||
To force static library detection use:
|
||||
QT5_XCOMPILE=1 QT5_FORCE_STATIC=1 waf configure
|
||||
|
||||
To use Qt6 set the want_qt6 attribute, ie:
|
||||
|
||||
conf.want_qt6 = True;
|
||||
"""
|
||||
|
||||
from __future__ import with_statement
|
||||
@ -282,8 +307,8 @@ def create_uic_task(self, node):
|
||||
|
||||
"""
|
||||
If UIC file is used in more than one bld, we would have a conflict in parallel execution
|
||||
It is not possible to change the file names (like .self.idx. as for objects) as they have
|
||||
to be referenced by the source file, but we can assume that the transformation will be identical
|
||||
It is not possible to change the file names (like .self.idx. as for objects) as they have
|
||||
to be referenced by the source file, but we can assume that the transformation will be identical
|
||||
and the tasks can be shared in a global cache.
|
||||
"""
|
||||
try:
|
||||
@ -300,7 +325,7 @@ def add_lang(self, node):
|
||||
"""Adds all the .ts file into ``self.lang``"""
|
||||
self.lang = self.to_list(getattr(self, 'lang', [])) + [node]
|
||||
|
||||
@feature('qt5')
|
||||
@feature('qt5', 'qt6')
|
||||
@before_method('process_source')
|
||||
def process_mocs(self):
|
||||
"""
|
||||
@ -322,7 +347,7 @@ def process_mocs(self):
|
||||
|
||||
self.create_task('moc', x, moc_node)
|
||||
|
||||
@feature('qt5')
|
||||
@feature('qt5', 'qt6')
|
||||
@after_method('apply_link')
|
||||
def apply_qt5(self):
|
||||
"""
|
||||
@ -485,6 +510,13 @@ def configure(self):
|
||||
if 'COMPILER_CXX' not in self.env:
|
||||
self.fatal('No CXX compiler defined: did you forget to configure compiler_cxx first?')
|
||||
|
||||
self.want_qt6 = getattr(self, 'want_qt6', False)
|
||||
|
||||
if self.want_qt6:
|
||||
self.qt_vars = Utils.to_list(getattr(self, 'qt6_vars', []))
|
||||
else:
|
||||
self.qt_vars = Utils.to_list(getattr(self, 'qt5_vars', []))
|
||||
|
||||
self.find_qt5_binaries()
|
||||
self.set_qt5_libs_dir()
|
||||
self.set_qt5_libs_to_check()
|
||||
@ -497,15 +529,19 @@ def configure(self):
|
||||
if not has_xml:
|
||||
Logs.error('No xml.sax support was found, rcc dependencies will be incomplete!')
|
||||
|
||||
feature = 'qt6' if self.want_qt6 else 'qt5'
|
||||
# Qt6 requires C++17 (https://www.qt.io/blog/qt-6.0-released)
|
||||
stdflag = '-std=c++17' if self.want_qt6 else '-std=c++11'
|
||||
|
||||
# Qt5 may be compiled with '-reduce-relocations' which requires dependent programs to have -fPIE or -fPIC?
|
||||
frag = '#include <QMap>\nint main(int argc, char **argv) {QMap<int,int> m;return m.keys().size();}\n'
|
||||
uses = 'QT5CORE'
|
||||
for flag in [[], '-fPIE', '-fPIC', '-std=c++11' , ['-std=c++11', '-fPIE'], ['-std=c++11', '-fPIC']]:
|
||||
uses = 'QT6CORE' if self.want_qt6 else 'QT5CORE'
|
||||
for flag in [[], '-fPIE', '-fPIC', stdflag, [stdflag, '-fPIE'], [stdflag, '-fPIC']]:
|
||||
msg = 'See if Qt files compile '
|
||||
if flag:
|
||||
msg += 'with %s' % flag
|
||||
try:
|
||||
self.check(features='qt5 cxx', use=uses, uselib_store='qt5', cxxflags=flag, fragment=frag, msg=msg)
|
||||
self.check(features=feature + ' cxx', use=uses, uselib_store=feature, cxxflags=flag, fragment=frag, msg=msg)
|
||||
except self.errors.ConfigurationError:
|
||||
pass
|
||||
else:
|
||||
@ -517,9 +553,9 @@ def configure(self):
|
||||
if Utils.unversioned_sys_platform() == 'freebsd':
|
||||
frag = '#include <QMap>\nint main(int argc, char **argv) {QMap<int,int> m;return m.keys().size();}\n'
|
||||
try:
|
||||
self.check(features='qt5 cxx cxxprogram', use=uses, fragment=frag, msg='Can we link Qt programs on FreeBSD directly?')
|
||||
self.check(features=feature + ' cxx cxxprogram', use=uses, fragment=frag, msg='Can we link Qt programs on FreeBSD directly?')
|
||||
except self.errors.ConfigurationError:
|
||||
self.check(features='qt5 cxx cxxprogram', use=uses, uselib_store='qt5', libpath='/usr/local/lib', fragment=frag, msg='Is /usr/local/lib required?')
|
||||
self.check(features=feature + ' cxx cxxprogram', use=uses, uselib_store=feature, libpath='/usr/local/lib', fragment=frag, msg='Is /usr/local/lib required?')
|
||||
|
||||
@conf
|
||||
def find_qt5_binaries(self):
|
||||
@ -531,6 +567,7 @@ def find_qt5_binaries(self):
|
||||
|
||||
qtdir = getattr(opt, 'qtdir', '')
|
||||
qtbin = getattr(opt, 'qtbin', '')
|
||||
qt_ver = '6' if self.want_qt6 else '5'
|
||||
|
||||
paths = []
|
||||
|
||||
@ -539,8 +576,8 @@ def find_qt5_binaries(self):
|
||||
|
||||
# the qt directory has been given from QT5_ROOT - deduce the qt binary path
|
||||
if not qtdir:
|
||||
qtdir = self.environ.get('QT5_ROOT', '')
|
||||
qtbin = self.environ.get('QT5_BIN') or os.path.join(qtdir, 'bin')
|
||||
qtdir = self.environ.get('QT' + qt_ver + '_ROOT', '')
|
||||
qtbin = self.environ.get('QT' + qt_ver + '_BIN') or os.path.join(qtdir, 'bin')
|
||||
|
||||
if qtbin:
|
||||
paths = [qtbin]
|
||||
@ -548,7 +585,10 @@ def find_qt5_binaries(self):
|
||||
# no qtdir, look in the path and in /usr/local/Trolltech
|
||||
if not qtdir:
|
||||
paths = self.environ.get('PATH', '').split(os.pathsep)
|
||||
paths.extend(['/usr/share/qt5/bin', '/usr/local/lib/qt5/bin'])
|
||||
paths.extend([
|
||||
'/usr/share/qt' + qt_ver + '/bin',
|
||||
'/usr/local/lib/qt' + qt_ver + '/bin'])
|
||||
|
||||
try:
|
||||
lst = Utils.listdir('/usr/local/Trolltech/')
|
||||
except OSError:
|
||||
@ -567,7 +607,9 @@ def find_qt5_binaries(self):
|
||||
# keep the one with the highest version
|
||||
cand = None
|
||||
prev_ver = ['0', '0', '0']
|
||||
for qmk in ('qmake-qt5', 'qmake5', 'qmake'):
|
||||
qmake_vars = ['qmake-qt' + qt_ver, 'qmake' + qt_ver, 'qmake']
|
||||
|
||||
for qmk in qmake_vars:
|
||||
try:
|
||||
qmake = self.find_program(qmk, path_list=paths)
|
||||
except self.errors.ConfigurationError:
|
||||
@ -580,7 +622,7 @@ def find_qt5_binaries(self):
|
||||
else:
|
||||
if version:
|
||||
new_ver = version.split('.')
|
||||
if new_ver[0] == '5' and new_ver > prev_ver:
|
||||
if new_ver[0] == qt_ver and new_ver > prev_ver:
|
||||
cand = qmake
|
||||
prev_ver = new_ver
|
||||
|
||||
@ -591,7 +633,7 @@ def find_qt5_binaries(self):
|
||||
except self.errors.ConfigurationError:
|
||||
pass
|
||||
else:
|
||||
cmd = self.env.QTCHOOSER + ['-qt=5', '-run-tool=qmake']
|
||||
cmd = self.env.QTCHOOSER + ['-qt=' + qt_ver, '-run-tool=qmake']
|
||||
try:
|
||||
version = self.cmd_and_log(cmd + ['-query', 'QT_VERSION'])
|
||||
except self.errors.WafError:
|
||||
@ -602,10 +644,17 @@ def find_qt5_binaries(self):
|
||||
if cand:
|
||||
self.env.QMAKE = cand
|
||||
else:
|
||||
self.fatal('Could not find qmake for qt5')
|
||||
self.fatal('Could not find qmake for qt' + qt_ver)
|
||||
|
||||
# Once we have qmake, we want to query qmake for the paths where we want to look for tools instead
|
||||
paths = []
|
||||
|
||||
self.env.QT_HOST_BINS = qtbin = self.cmd_and_log(self.env.QMAKE + ['-query', 'QT_HOST_BINS']).strip()
|
||||
paths.insert(0, qtbin)
|
||||
paths.append(qtbin)
|
||||
|
||||
if self.want_qt6:
|
||||
self.env.QT_HOST_LIBEXECS = self.cmd_and_log(self.env.QMAKE + ['-query', 'QT_HOST_LIBEXECS']).strip()
|
||||
paths.append(self.env.QT_HOST_LIBEXECS)
|
||||
|
||||
def find_bin(lst, var):
|
||||
if var in env:
|
||||
@ -619,22 +668,25 @@ def find_qt5_binaries(self):
|
||||
env[var]=ret
|
||||
break
|
||||
|
||||
find_bin(['uic-qt5', 'uic'], 'QT_UIC')
|
||||
find_bin(['uic-qt' + qt_ver, 'uic'], 'QT_UIC')
|
||||
if not env.QT_UIC:
|
||||
self.fatal('cannot find the uic compiler for qt5')
|
||||
self.fatal('cannot find the uic compiler for qt' + qt_ver)
|
||||
|
||||
self.start_msg('Checking for uic version')
|
||||
uicver = self.cmd_and_log(env.QT_UIC + ['-version'], output=Context.BOTH)
|
||||
uicver = ''.join(uicver).strip()
|
||||
uicver = uicver.replace('Qt User Interface Compiler ','').replace('User Interface Compiler for Qt', '')
|
||||
self.end_msg(uicver)
|
||||
if uicver.find(' 3.') != -1 or uicver.find(' 4.') != -1:
|
||||
self.fatal('this uic compiler is for qt3 or qt4, add uic for qt5 to your path')
|
||||
if uicver.find(' 3.') != -1 or uicver.find(' 4.') != -1 or (self.want_qt6 and uicver.find(' 5.') != -1):
|
||||
if self.want_qt6:
|
||||
self.fatal('this uic compiler is for qt3 or qt4 or qt5, add uic for qt6 to your path')
|
||||
else:
|
||||
self.fatal('this uic compiler is for qt3 or qt4, add uic for qt5 to your path')
|
||||
|
||||
find_bin(['moc-qt5', 'moc'], 'QT_MOC')
|
||||
find_bin(['rcc-qt5', 'rcc'], 'QT_RCC')
|
||||
find_bin(['lrelease-qt5', 'lrelease'], 'QT_LRELEASE')
|
||||
find_bin(['lupdate-qt5', 'lupdate'], 'QT_LUPDATE')
|
||||
find_bin(['moc-qt' + qt_ver, 'moc'], 'QT_MOC')
|
||||
find_bin(['rcc-qt' + qt_ver, 'rcc'], 'QT_RCC')
|
||||
find_bin(['lrelease-qt' + qt_ver, 'lrelease'], 'QT_LRELEASE')
|
||||
find_bin(['lupdate-qt' + qt_ver, 'lupdate'], 'QT_LUPDATE')
|
||||
|
||||
env.UIC_ST = '%s -o %s'
|
||||
env.MOC_ST = '-o'
|
||||
@ -646,19 +698,26 @@ def find_qt5_binaries(self):
|
||||
@conf
|
||||
def set_qt5_libs_dir(self):
|
||||
env = self.env
|
||||
qtlibs = getattr(Options.options, 'qtlibs', None) or self.environ.get('QT5_LIBDIR')
|
||||
qt_ver = '6' if self.want_qt6 else '5'
|
||||
|
||||
qtlibs = getattr(Options.options, 'qtlibs', None) or self.environ.get('QT' + qt_ver + '_LIBDIR')
|
||||
|
||||
if not qtlibs:
|
||||
try:
|
||||
qtlibs = self.cmd_and_log(env.QMAKE + ['-query', 'QT_INSTALL_LIBS']).strip()
|
||||
except Errors.WafError:
|
||||
qtdir = self.cmd_and_log(env.QMAKE + ['-query', 'QT_INSTALL_PREFIX']).strip()
|
||||
qtlibs = os.path.join(qtdir, 'lib')
|
||||
self.msg('Found the Qt5 library path', qtlibs)
|
||||
|
||||
self.msg('Found the Qt' + qt_ver + ' library path', qtlibs)
|
||||
|
||||
env.QTLIBS = qtlibs
|
||||
|
||||
@conf
|
||||
def find_single_qt5_lib(self, name, uselib, qtlibs, qtincludes, force_static):
|
||||
env = self.env
|
||||
qt_ver = '6' if self.want_qt6 else '5'
|
||||
|
||||
if force_static:
|
||||
exts = ('.a', '.lib')
|
||||
prefix = 'STLIB'
|
||||
@ -668,7 +727,7 @@ def find_single_qt5_lib(self, name, uselib, qtlibs, qtincludes, force_static):
|
||||
|
||||
def lib_names():
|
||||
for x in exts:
|
||||
for k in ('', '5') if Utils.is_win32 else ['']:
|
||||
for k in ('', qt_ver) if Utils.is_win32 else ['']:
|
||||
for p in ('lib', ''):
|
||||
yield (p, name, k, x)
|
||||
|
||||
@ -683,26 +742,28 @@ def find_single_qt5_lib(self, name, uselib, qtlibs, qtincludes, force_static):
|
||||
env.append_unique(prefix + '_' + uselib, libval)
|
||||
env.append_unique('%sPATH_%s' % (prefix, uselib), qtlibs)
|
||||
env.append_unique('INCLUDES_' + uselib, qtincludes)
|
||||
env.append_unique('INCLUDES_' + uselib, os.path.join(qtincludes, name.replace('Qt5', 'Qt')))
|
||||
env.append_unique('INCLUDES_' + uselib, os.path.join(qtincludes, name.replace('Qt' + qt_ver, 'Qt')))
|
||||
return k
|
||||
return False
|
||||
|
||||
@conf
|
||||
def find_qt5_libraries(self):
|
||||
env = self.env
|
||||
qt_ver = '6' if self.want_qt6 else '5'
|
||||
|
||||
qtincludes = self.environ.get('QT' + qt_ver + '_INCLUDES') or self.cmd_and_log(env.QMAKE + ['-query', 'QT_INSTALL_HEADERS']).strip()
|
||||
force_static = self.environ.get('QT' + qt_ver + '_FORCE_STATIC')
|
||||
|
||||
qtincludes = self.environ.get('QT5_INCLUDES') or self.cmd_and_log(env.QMAKE + ['-query', 'QT_INSTALL_HEADERS']).strip()
|
||||
force_static = self.environ.get('QT5_FORCE_STATIC')
|
||||
try:
|
||||
if self.environ.get('QT5_XCOMPILE'):
|
||||
self.fatal('QT5_XCOMPILE Disables pkg-config detection')
|
||||
if self.environ.get('QT' + qt_ver + '_XCOMPILE'):
|
||||
self.fatal('QT' + qt_ver + '_XCOMPILE Disables pkg-config detection')
|
||||
self.check_cfg(atleast_pkgconfig_version='0.1')
|
||||
except self.errors.ConfigurationError:
|
||||
for i in self.qt5_vars:
|
||||
for i in self.qt_vars:
|
||||
uselib = i.upper()
|
||||
if Utils.unversioned_sys_platform() == 'darwin':
|
||||
# Since at least qt 4.7.3 each library locates in separate directory
|
||||
fwk = i.replace('Qt5', 'Qt')
|
||||
fwk = i.replace('Qt' + qt_ver, 'Qt')
|
||||
frameworkName = fwk + '.framework'
|
||||
|
||||
qtDynamicLib = os.path.join(env.QTLIBS, frameworkName, fwk)
|
||||
@ -719,9 +780,9 @@ def find_qt5_libraries(self):
|
||||
ret = self.find_single_qt5_lib(i, uselib, env.QTLIBS, qtincludes, True)
|
||||
self.msg('Checking for %s' % i, ret, 'GREEN' if ret else 'YELLOW')
|
||||
else:
|
||||
path = '%s:%s:%s/pkgconfig:/usr/lib/qt5/lib/pkgconfig:/opt/qt5/lib/pkgconfig:/usr/lib/qt5/lib:/opt/qt5/lib' % (
|
||||
self.environ.get('PKG_CONFIG_PATH', ''), env.QTLIBS, env.QTLIBS)
|
||||
for i in self.qt5_vars:
|
||||
path = '%s:%s:%s/pkgconfig:/usr/lib/qt%s/lib/pkgconfig:/opt/qt%s/lib/pkgconfig:/usr/lib/qt%s/lib:/opt/qt%s/lib' % (
|
||||
self.environ.get('PKG_CONFIG_PATH', ''), env.QTLIBS, env.QTLIBS, qt_ver, qt_ver, qt_ver, qt_ver)
|
||||
for i in self.qt_vars:
|
||||
self.check_cfg(package=i, args='--cflags --libs', mandatory=False, force_static=force_static, pkg_config_path=path)
|
||||
|
||||
@conf
|
||||
@ -746,7 +807,7 @@ def simplify_qt5_libs(self):
|
||||
continue
|
||||
accu.append(lib)
|
||||
env['LIBPATH_'+var] = accu
|
||||
process_lib(self.qt5_vars, 'LIBPATH_QTCORE')
|
||||
process_lib(self.qt_vars, 'LIBPATH_QTCORE')
|
||||
|
||||
@conf
|
||||
def add_qt5_rpath(self):
|
||||
@ -768,39 +829,52 @@ def add_qt5_rpath(self):
|
||||
continue
|
||||
accu.append('-Wl,--rpath='+lib)
|
||||
env['RPATH_' + var] = accu
|
||||
process_rpath(self.qt5_vars, 'LIBPATH_QTCORE')
|
||||
process_rpath(self.qt_vars, 'LIBPATH_QTCORE')
|
||||
|
||||
@conf
|
||||
def set_qt5_libs_to_check(self):
|
||||
self.qt5_vars = Utils.to_list(getattr(self, 'qt5_vars', []))
|
||||
if not self.qt5_vars:
|
||||
qt_ver = '6' if self.want_qt6 else '5'
|
||||
|
||||
if not self.qt_vars:
|
||||
dirlst = Utils.listdir(self.env.QTLIBS)
|
||||
|
||||
pat = self.env.cxxshlib_PATTERN
|
||||
if Utils.is_win32:
|
||||
pat = pat.replace('.dll', '.lib')
|
||||
if self.environ.get('QT5_FORCE_STATIC'):
|
||||
if self.environ.get('QT' + qt_ver + '_FORCE_STATIC'):
|
||||
pat = self.env.cxxstlib_PATTERN
|
||||
if Utils.unversioned_sys_platform() == 'darwin':
|
||||
pat = r"%s\.framework"
|
||||
re_qt = re.compile(pat % 'Qt5?(?P<name>\\w+)' + '$')
|
||||
|
||||
# We only want to match Qt5 or Qt in the case of Qt5, in the case
|
||||
# of Qt6 we want to match Qt6 or Qt. This speeds up configuration
|
||||
# and reduces the chattiness of the configuration. Should also prevent
|
||||
# possible misconfiguration.
|
||||
if self.want_qt6:
|
||||
re_qt = re.compile(pat % 'Qt6?(?!\\d)(?P<name>\\w+)' + '$')
|
||||
else:
|
||||
re_qt = re.compile(pat % 'Qt5?(?!\\d)(?P<name>\\w+)' + '$')
|
||||
|
||||
for x in sorted(dirlst):
|
||||
m = re_qt.match(x)
|
||||
if m:
|
||||
self.qt5_vars.append("Qt5%s" % m.group('name'))
|
||||
if not self.qt5_vars:
|
||||
self.fatal('cannot find any Qt5 library (%r)' % self.env.QTLIBS)
|
||||
self.qt_vars.append("Qt%s%s" % (qt_ver, m.group('name')))
|
||||
if not self.qt_vars:
|
||||
self.fatal('cannot find any Qt%s library (%r)' % (qt_ver, self.env.QTLIBS))
|
||||
|
||||
qtextralibs = getattr(Options.options, 'qtextralibs', None)
|
||||
if qtextralibs:
|
||||
self.qt5_vars.extend(qtextralibs.split(','))
|
||||
self.qt_vars.extend(qtextralibs.split(','))
|
||||
|
||||
@conf
|
||||
def set_qt5_defines(self):
|
||||
qt_ver = '6' if self.want_qt6 else '5'
|
||||
|
||||
if sys.platform != 'win32':
|
||||
return
|
||||
for x in self.qt5_vars:
|
||||
y=x.replace('Qt5', 'Qt')[2:].upper()
|
||||
|
||||
for x in self.qt_vars:
|
||||
y=x.replace('Qt' + qt_ver, 'Qt')[2:].upper()
|
||||
self.env.append_unique('DEFINES_%s' % x.upper(), 'QT_%s_LIB' % y)
|
||||
|
||||
def options(opt):
|
||||
|
2
third_party/waf/waflib/extras/distnet.py
vendored
2
third_party/waf/waflib/extras/distnet.py
vendored
@ -101,6 +101,8 @@ class package(Context.Context):
|
||||
tarinfo.uid = tarinfo.gid = 0
|
||||
tarinfo.uname = tarinfo.gname = 'root'
|
||||
tarinfo.size = os.stat(x).st_size
|
||||
if os.environ.get('SOURCE_DATE_EPOCH'):
|
||||
tarinfo.mtime = int(os.environ.get('SOURCE_DATE_EPOCH'))
|
||||
|
||||
# TODO - more archive creation options?
|
||||
if kw.get('bare', True):
|
||||
|
245
third_party/waf/waflib/extras/haxe.py
vendored
245
third_party/waf/waflib/extras/haxe.py
vendored
@ -1,131 +1,154 @@
|
||||
import os, re
|
||||
from waflib import Utils, Task, Errors
|
||||
from waflib.TaskGen import extension, taskgen_method, feature
|
||||
import re
|
||||
|
||||
from waflib import Utils, Task, Errors, Logs
|
||||
from waflib.Configure import conf
|
||||
from waflib.TaskGen import extension, taskgen_method
|
||||
|
||||
HAXE_COMPILERS = {
|
||||
'JS': {'tgt': '--js', 'ext_out': ['.js']},
|
||||
'LUA': {'tgt': '--lua', 'ext_out': ['.lua']},
|
||||
'SWF': {'tgt': '--swf', 'ext_out': ['.swf']},
|
||||
'NEKO': {'tgt': '--neko', 'ext_out': ['.n']},
|
||||
'PHP': {'tgt': '--php', 'ext_out': ['.php']},
|
||||
'CPP': {'tgt': '--cpp', 'ext_out': ['.h', '.cpp']},
|
||||
'CPPIA': {'tgt': '--cppia', 'ext_out': ['.cppia']},
|
||||
'CS': {'tgt': '--cs', 'ext_out': ['.cs']},
|
||||
'JAVA': {'tgt': '--java', 'ext_out': ['.java']},
|
||||
'JVM': {'tgt': '--jvm', 'ext_out': ['.jar']},
|
||||
'PYTHON': {'tgt': '--python', 'ext_out': ['.py']},
|
||||
'HL': {'tgt': '--hl', 'ext_out': ['.hl']},
|
||||
'HLC': {'tgt': '--hl', 'ext_out': ['.h', '.c']},
|
||||
}
|
||||
|
||||
@conf
|
||||
def libname_haxe(self, libname):
|
||||
return libname
|
||||
def check_haxe_pkg(self, **kw):
|
||||
self.find_program('haxelib')
|
||||
libs = kw.get('libs')
|
||||
if not libs or not (type(libs) == str or (type(libs) == list and all(isinstance(s, str) for s in libs))):
|
||||
self.fatal('Specify correct libs value in ensure call')
|
||||
return
|
||||
fetch = kw.get('fetch')
|
||||
if not fetch is None and not type(fetch) == bool:
|
||||
self.fatal('Specify correct fetch value in ensure call')
|
||||
|
||||
@conf
|
||||
def check_lib_haxe(self, libname, uselib_store=None):
|
||||
haxe_libs = [node.name for node in self.root.find_node('haxe_libraries').ant_glob()]
|
||||
changed = False
|
||||
self.start_msg('Checking for library %s' % libname)
|
||||
if libname + '.hxml' in haxe_libs:
|
||||
self.end_msg('yes')
|
||||
else:
|
||||
changed = True
|
||||
try:
|
||||
cmd = self.env.LIX + ['+lib', libname]
|
||||
res = self.cmd_and_log(cmd)
|
||||
if (res):
|
||||
raise Errors.WafError(res)
|
||||
else:
|
||||
self.end_msg('downloaded', color = 'YELLOW')
|
||||
except Errors.WafError as e:
|
||||
self.end_msg('no', color = 'RED')
|
||||
self.fatal('Getting %s has failed' % libname)
|
||||
libs = [libs] if type(libs) == str else libs
|
||||
halt = False
|
||||
for lib in libs:
|
||||
try:
|
||||
self.start_msg('Checking for library %s' % lib)
|
||||
output = self.cmd_and_log(self.env.HAXELIB + ['list', lib])
|
||||
except Errors.WafError:
|
||||
self.end_msg(False)
|
||||
self.fatal('Can\'t run haxelib list, ensuring halted')
|
||||
return
|
||||
|
||||
postfix = uselib_store if uselib_store else libname.upper()
|
||||
self.env['LIB_' + postfix] += [self.libname_haxe(libname)]
|
||||
return changed
|
||||
if lib in output:
|
||||
self.end_msg(lib in output)
|
||||
else:
|
||||
if not fetch:
|
||||
self.end_msg(False)
|
||||
halt = True
|
||||
continue
|
||||
try:
|
||||
status = self.exec_command(self.env.HAXELIB + ['install', lib])
|
||||
if status:
|
||||
self.end_msg(False)
|
||||
self.fatal('Can\'t get %s with haxelib, ensuring halted' % lib)
|
||||
return
|
||||
else:
|
||||
self.end_msg('downloaded', color='YELLOW')
|
||||
except Errors.WafError:
|
||||
self.end_msg(False)
|
||||
self.fatal('Can\'t run haxelib install, ensuring halted')
|
||||
return
|
||||
postfix = kw.get('uselib_store') or lib.upper()
|
||||
self.env.append_unique('LIB_' + postfix, lib)
|
||||
|
||||
@conf
|
||||
def check_libs_haxe(self, libnames, uselib_store=None):
|
||||
changed = False
|
||||
for libname in Utils.to_list(libnames):
|
||||
if self.check_lib_haxe(libname, uselib_store):
|
||||
changed = True
|
||||
return changed
|
||||
|
||||
@conf
|
||||
def ensure_lix_pkg(self, *k, **kw):
|
||||
if kw.get('compiler') == 'hx':
|
||||
if isinstance(kw.get('libs'), list) and len(kw.get('libs')):
|
||||
changed = self.check_libs_haxe(kw.get('libs'), kw.get('uselib_store'))
|
||||
if changed:
|
||||
try:
|
||||
cmd = self.env.LIX + ['download']
|
||||
res = self.cmd_and_log(cmd)
|
||||
if (res):
|
||||
raise Errors.WafError(res)
|
||||
except Errors.WafError as e:
|
||||
self.fatal('lix download has failed')
|
||||
else:
|
||||
self.check_lib_haxe(kw.get('lib'), kw.get('uselib_store'))
|
||||
|
||||
@conf
|
||||
def haxe(bld, *k, **kw):
|
||||
task_gen = bld(*k, **kw)
|
||||
if halt:
|
||||
self.fatal('Can\'t find libraries in haxelib list, ensuring halted')
|
||||
return
|
||||
|
||||
class haxe(Task.Task):
|
||||
vars = ['HAXE', 'HAXE_VERSION', 'HAXEFLAGS']
|
||||
ext_out = ['.hl', '.c', '.h']
|
||||
vars = ['HAXE_VERSION', 'HAXE_FLAGS']
|
||||
ext_in = ['.hx']
|
||||
|
||||
def run(self):
|
||||
cmd = self.env.HAXE + self.env.HAXEFLAGS
|
||||
return self.exec_command(cmd, stdout = open(os.devnull, 'w'))
|
||||
def run(self):
|
||||
cmd = self.env.HAXE + self.env.HAXE_FLAGS_DEFAULT + self.env.HAXE_FLAGS
|
||||
return self.exec_command(cmd)
|
||||
|
||||
for COMP in HAXE_COMPILERS:
|
||||
# create runners for each compile target
|
||||
type("haxe_" + COMP, (haxe,), {'ext_out': HAXE_COMPILERS[COMP]['ext_out']})
|
||||
|
||||
@taskgen_method
|
||||
def init_haxe_task(self, node):
|
||||
def addflags(flags):
|
||||
self.env.append_value('HAXEFLAGS', flags)
|
||||
def init_haxe(self):
|
||||
errmsg = '%s not found, specify correct value'
|
||||
try:
|
||||
compiler = HAXE_COMPILERS[self.compiler]
|
||||
comp_tgt = compiler['tgt']
|
||||
comp_mod = '/main.c' if self.compiler == 'HLC' else ''
|
||||
except (AttributeError, KeyError):
|
||||
self.bld.fatal(errmsg % 'COMPILER' + ': ' + ', '.join(HAXE_COMPILERS.keys()))
|
||||
return
|
||||
|
||||
if node.suffix() == '.hxml':
|
||||
addflags(self.path.abspath() + '/' + node.name)
|
||||
else:
|
||||
addflags(['-main', node.name])
|
||||
addflags(['-hl', self.path.get_bld().make_node(self.target).abspath()])
|
||||
addflags(['-cp', self.path.abspath()])
|
||||
addflags(['-D', 'resourcesPath=%s' % getattr(self, 'res', '')])
|
||||
if hasattr(self, 'use'):
|
||||
for dep in self.use:
|
||||
if self.env['LIB_' + dep]:
|
||||
for lib in self.env['LIB_' + dep]: addflags(['-lib', lib])
|
||||
self.env.append_value(
|
||||
'HAXE_FLAGS',
|
||||
[comp_tgt, self.path.get_bld().make_node(self.target + comp_mod).abspath()])
|
||||
if hasattr(self, 'use'):
|
||||
if not (type(self.use) == str or type(self.use) == list):
|
||||
self.bld.fatal(errmsg % 'USE')
|
||||
return
|
||||
self.use = [self.use] if type(self.use) == str else self.use
|
||||
|
||||
@extension('.hx', '.hxml')
|
||||
def haxe_file(self, node):
|
||||
if len(self.source) > 1:
|
||||
self.bld.fatal('Use separate task generators for multiple files')
|
||||
for dep in self.use:
|
||||
if self.env['LIB_' + dep]:
|
||||
for lib in self.env['LIB_' + dep]:
|
||||
self.env.append_value('HAXE_FLAGS', ['-lib', lib])
|
||||
|
||||
try:
|
||||
haxetask = self.haxetask
|
||||
except AttributeError:
|
||||
haxetask = self.haxetask = self.create_task('haxe')
|
||||
self.init_haxe_task(node)
|
||||
if hasattr(self, 'res'):
|
||||
if not type(self.res) == str:
|
||||
self.bld.fatal(errmsg % 'RES')
|
||||
return
|
||||
self.env.append_value('HAXE_FLAGS', ['-D', 'resourcesPath=%s' % self.res])
|
||||
|
||||
haxetask.inputs.append(node)
|
||||
haxetask.outputs.append(self.path.get_bld().make_node(self.target))
|
||||
@extension('.hx')
|
||||
def haxe_hook(self, node):
|
||||
if len(self.source) > 1:
|
||||
self.bld.fatal('Use separate task generators for multiple files')
|
||||
return
|
||||
|
||||
src = node
|
||||
tgt = self.path.get_bld().find_or_declare(self.target)
|
||||
|
||||
self.init_haxe()
|
||||
self.create_task('haxe_' + self.compiler, src, tgt)
|
||||
|
||||
@conf
|
||||
def find_haxe(self, min_version):
|
||||
npx = self.env.NPX = self.find_program('npx')
|
||||
self.env.LIX = npx + ['lix']
|
||||
npx_haxe = self.env.HAXE = npx + ['haxe']
|
||||
try:
|
||||
output = self.cmd_and_log(npx_haxe + ['-version'])
|
||||
except Errors.WafError:
|
||||
haxe_version = None
|
||||
else:
|
||||
ver = re.search(r'\d+.\d+.\d+', output).group().split('.')
|
||||
haxe_version = tuple([int(x) for x in ver])
|
||||
def check_haxe(self, mini=None, maxi=None):
|
||||
self.start_msg('Checking for haxe version')
|
||||
try:
|
||||
curr = re.search(
|
||||
r'(\d+.?)+',
|
||||
self.cmd_and_log(self.env.HAXE + ['-version'])).group()
|
||||
except Errors.WafError:
|
||||
self.end_msg(False)
|
||||
self.fatal('Can\'t get haxe version')
|
||||
return
|
||||
|
||||
self.msg('Checking for haxe version',
|
||||
haxe_version, haxe_version and haxe_version >= min_version)
|
||||
if npx_haxe and haxe_version < min_version:
|
||||
self.fatal('haxe version %r is too old, need >= %r' % (haxe_version, min_version))
|
||||
|
||||
self.env.HAXE_VERSION = haxe_version
|
||||
return npx_haxe
|
||||
|
||||
@conf
|
||||
def check_haxe(self, min_version=(4,1,4)):
|
||||
if self.env.HAXE_MINVER:
|
||||
min_version = self.env.HAXE_MINVER
|
||||
find_haxe(self, min_version)
|
||||
if mini and Utils.num2ver(curr) < Utils.num2ver(mini):
|
||||
self.end_msg('wrong', color='RED')
|
||||
self.fatal('%s is too old, need >= %s' % (curr, mini))
|
||||
return
|
||||
if maxi and Utils.num2ver(curr) > Utils.num2ver(maxi):
|
||||
self.end_msg('wrong', color='RED')
|
||||
self.fatal('%s is too new, need <= %s' % (curr, maxi))
|
||||
return
|
||||
self.end_msg(curr, color='GREEN')
|
||||
self.env.HAXE_VERSION = curr
|
||||
|
||||
def configure(self):
|
||||
self.env.HAXEFLAGS = []
|
||||
self.check_haxe()
|
||||
self.add_os_flags('HAXEFLAGS', dup = False)
|
||||
self.env.append_value(
|
||||
'HAXE_FLAGS_DEFAULT',
|
||||
['-D', 'no-compilation', '-cp', self.path.abspath()])
|
||||
Logs.warn('Default flags: %s' % ' '.join(self.env.HAXE_FLAGS_DEFAULT))
|
||||
self.find_program('haxe')
|
||||
|
4
third_party/waf/waflib/extras/msvs.py
vendored
4
third_party/waf/waflib/extras/msvs.py
vendored
@ -583,7 +583,7 @@ class vsnode_project(vsnode):
|
||||
self.build_properties = ret
|
||||
|
||||
def get_build_params(self, props):
|
||||
opt = '--execsolution=%s' % self.ctx.get_solution_node().win32path()
|
||||
opt = '--execsolution="%s"' % self.ctx.get_solution_node().win32path()
|
||||
return (self.get_waf(), opt)
|
||||
|
||||
def get_build_command(self, props):
|
||||
@ -681,7 +681,7 @@ class vsnode_target(vsnode_project):
|
||||
"""
|
||||
Override the default to add the target name
|
||||
"""
|
||||
opt = '--execsolution=%s' % self.ctx.get_solution_node().win32path()
|
||||
opt = '--execsolution="%s"' % self.ctx.get_solution_node().win32path()
|
||||
if getattr(self, 'tg', None):
|
||||
opt += " --targets=%s" % self.tg.name
|
||||
return (self.get_waf(), opt)
|
||||
|
2
third_party/waf/waflib/extras/sphinx.py
vendored
2
third_party/waf/waflib/extras/sphinx.py
vendored
@ -86,7 +86,7 @@ def get_install_path(object):
|
||||
|
||||
class SphinxBuildingTask(Task.Task):
|
||||
color = 'BOLD'
|
||||
run_str = '${SPHINX_BUILD} -M ${SPHINX_OUTPUT_FORMAT} ${SRC} ${TGT} ${SPHINX_OPTIONS}'
|
||||
run_str = '${SPHINX_BUILD} -M ${SPHINX_OUTPUT_FORMAT} ${SRC} ${TGT} -d ${TGT[0].bld_dir()}/doctrees-${SPHINX_OUTPUT_FORMAT} ${SPHINX_OPTIONS}'
|
||||
|
||||
def keyword(self):
|
||||
return 'Compiling (%s)' % self.env.SPHINX_OUTPUT_FORMAT
|
||||
|
Loading…
x
Reference in New Issue
Block a user