frida 16.2.1 → 16.2.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/BSDmakefile +6 -0
- package/Makefile +16 -0
- package/README.md +14 -11
- package/configure +18 -0
- package/configure.bat +22 -0
- package/dist/native.js +0 -8
- package/lib/application.ts +98 -0
- package/lib/authentication.ts +3 -0
- package/lib/build.py +50 -0
- package/lib/bus.ts +30 -0
- package/lib/cancellable.ts +33 -0
- package/lib/child.ts +15 -0
- package/lib/crash.ts +11 -0
- package/lib/device.ts +329 -0
- package/lib/device_manager.ts +69 -0
- package/lib/endpoint_parameters.ts +56 -0
- package/lib/icon.ts +15 -0
- package/lib/index.ts +311 -0
- package/lib/iostream.ts +78 -0
- package/lib/meson.build +53 -0
- package/lib/native.ts +9 -0
- package/lib/portal_membership.ts +10 -0
- package/lib/portal_service.ts +105 -0
- package/lib/process.ts +57 -0
- package/lib/relay.ts +44 -0
- package/lib/script.ts +352 -0
- package/lib/session.ts +113 -0
- package/lib/signals.ts +45 -0
- package/lib/socket_address.ts +35 -0
- package/lib/spawn.ts +4 -0
- package/lib/system_parameters.ts +78 -0
- package/make.bat +23 -0
- package/meson.build +160 -0
- package/meson.options +11 -0
- package/package.json +27 -6
- package/releng/deps.py +1133 -0
- package/releng/deps.toml +391 -0
- package/releng/devkit-assets/frida-core-example-unix.c +188 -0
- package/releng/devkit-assets/frida-core-example-windows.c +197 -0
- package/releng/devkit-assets/frida-core-example.sln +28 -0
- package/releng/devkit-assets/frida-core-example.vcxproj +157 -0
- package/releng/devkit-assets/frida-core-example.vcxproj.filters +27 -0
- package/releng/devkit-assets/frida-gum-example-unix.c +122 -0
- package/releng/devkit-assets/frida-gum-example-windows.c +132 -0
- package/releng/devkit-assets/frida-gum-example.sln +28 -0
- package/releng/devkit-assets/frida-gum-example.vcxproj +157 -0
- package/releng/devkit-assets/frida-gum-example.vcxproj.filters +27 -0
- package/releng/devkit-assets/frida-gumjs-example-unix.c +84 -0
- package/releng/devkit-assets/frida-gumjs-example-windows.c +91 -0
- package/releng/devkit-assets/frida-gumjs-example.sln +28 -0
- package/releng/devkit-assets/frida-gumjs-example.vcxproj +157 -0
- package/releng/devkit-assets/frida-gumjs-example.vcxproj.filters +27 -0
- package/releng/devkit.py +535 -0
- package/releng/env.py +420 -0
- package/releng/env_android.py +150 -0
- package/releng/env_apple.py +176 -0
- package/releng/env_generic.py +373 -0
- package/releng/frida_version.py +69 -0
- package/releng/machine_file.py +44 -0
- package/releng/machine_spec.py +290 -0
- package/releng/meson/meson.py +27 -0
- package/releng/meson/mesonbuild/__init__.py +0 -0
- package/releng/meson/mesonbuild/_pathlib.py +63 -0
- package/releng/meson/mesonbuild/_typing.py +69 -0
- package/releng/meson/mesonbuild/arglist.py +321 -0
- package/releng/meson/mesonbuild/ast/__init__.py +23 -0
- package/releng/meson/mesonbuild/ast/interpreter.py +441 -0
- package/releng/meson/mesonbuild/ast/introspection.py +374 -0
- package/releng/meson/mesonbuild/ast/postprocess.py +109 -0
- package/releng/meson/mesonbuild/ast/printer.py +620 -0
- package/releng/meson/mesonbuild/ast/visitor.py +161 -0
- package/releng/meson/mesonbuild/backend/__init__.py +0 -0
- package/releng/meson/mesonbuild/backend/backends.py +2047 -0
- package/releng/meson/mesonbuild/backend/ninjabackend.py +3808 -0
- package/releng/meson/mesonbuild/backend/nonebackend.py +26 -0
- package/releng/meson/mesonbuild/backend/vs2010backend.py +2078 -0
- package/releng/meson/mesonbuild/backend/vs2012backend.py +35 -0
- package/releng/meson/mesonbuild/backend/vs2013backend.py +34 -0
- package/releng/meson/mesonbuild/backend/vs2015backend.py +35 -0
- package/releng/meson/mesonbuild/backend/vs2017backend.py +59 -0
- package/releng/meson/mesonbuild/backend/vs2019backend.py +54 -0
- package/releng/meson/mesonbuild/backend/vs2022backend.py +54 -0
- package/releng/meson/mesonbuild/backend/xcodebackend.py +1781 -0
- package/releng/meson/mesonbuild/build.py +3249 -0
- package/releng/meson/mesonbuild/cargo/__init__.py +5 -0
- package/releng/meson/mesonbuild/cargo/builder.py +238 -0
- package/releng/meson/mesonbuild/cargo/cfg.py +274 -0
- package/releng/meson/mesonbuild/cargo/interpreter.py +733 -0
- package/releng/meson/mesonbuild/cargo/manifest.py +227 -0
- package/releng/meson/mesonbuild/cargo/version.py +95 -0
- package/releng/meson/mesonbuild/cmake/__init__.py +28 -0
- package/releng/meson/mesonbuild/cmake/common.py +331 -0
- package/releng/meson/mesonbuild/cmake/data/__init__.py +0 -0
- package/releng/meson/mesonbuild/cmake/data/preload.cmake +82 -0
- package/releng/meson/mesonbuild/cmake/executor.py +241 -0
- package/releng/meson/mesonbuild/cmake/fileapi.py +324 -0
- package/releng/meson/mesonbuild/cmake/generator.py +186 -0
- package/releng/meson/mesonbuild/cmake/interpreter.py +1267 -0
- package/releng/meson/mesonbuild/cmake/toolchain.py +248 -0
- package/releng/meson/mesonbuild/cmake/traceparser.py +814 -0
- package/releng/meson/mesonbuild/cmake/tracetargets.py +161 -0
- package/releng/meson/mesonbuild/compilers/__init__.py +86 -0
- package/releng/meson/mesonbuild/compilers/asm.py +307 -0
- package/releng/meson/mesonbuild/compilers/c.py +788 -0
- package/releng/meson/mesonbuild/compilers/c_function_attributes.py +143 -0
- package/releng/meson/mesonbuild/compilers/compilers.py +1388 -0
- package/releng/meson/mesonbuild/compilers/cpp.py +1035 -0
- package/releng/meson/mesonbuild/compilers/cs.py +136 -0
- package/releng/meson/mesonbuild/compilers/cuda.py +806 -0
- package/releng/meson/mesonbuild/compilers/cython.py +91 -0
- package/releng/meson/mesonbuild/compilers/d.py +861 -0
- package/releng/meson/mesonbuild/compilers/detect.py +1396 -0
- package/releng/meson/mesonbuild/compilers/fortran.py +523 -0
- package/releng/meson/mesonbuild/compilers/java.py +113 -0
- package/releng/meson/mesonbuild/compilers/mixins/__init__.py +0 -0
- package/releng/meson/mesonbuild/compilers/mixins/arm.py +167 -0
- package/releng/meson/mesonbuild/compilers/mixins/ccrx.py +113 -0
- package/releng/meson/mesonbuild/compilers/mixins/clang.py +170 -0
- package/releng/meson/mesonbuild/compilers/mixins/clike.py +1330 -0
- package/releng/meson/mesonbuild/compilers/mixins/compcert.py +117 -0
- package/releng/meson/mesonbuild/compilers/mixins/elbrus.py +93 -0
- package/releng/meson/mesonbuild/compilers/mixins/emscripten.py +89 -0
- package/releng/meson/mesonbuild/compilers/mixins/gnu.py +629 -0
- package/releng/meson/mesonbuild/compilers/mixins/intel.py +167 -0
- package/releng/meson/mesonbuild/compilers/mixins/islinker.py +120 -0
- package/releng/meson/mesonbuild/compilers/mixins/metrowerks.py +279 -0
- package/releng/meson/mesonbuild/compilers/mixins/pgi.py +88 -0
- package/releng/meson/mesonbuild/compilers/mixins/ti.py +130 -0
- package/releng/meson/mesonbuild/compilers/mixins/visualstudio.py +458 -0
- package/releng/meson/mesonbuild/compilers/mixins/xc16.py +111 -0
- package/releng/meson/mesonbuild/compilers/objc.py +120 -0
- package/releng/meson/mesonbuild/compilers/objcpp.py +102 -0
- package/releng/meson/mesonbuild/compilers/rust.py +230 -0
- package/releng/meson/mesonbuild/compilers/swift.py +131 -0
- package/releng/meson/mesonbuild/compilers/vala.py +121 -0
- package/releng/meson/mesonbuild/coredata.py +1532 -0
- package/releng/meson/mesonbuild/dependencies/__init__.py +252 -0
- package/releng/meson/mesonbuild/dependencies/base.py +663 -0
- package/releng/meson/mesonbuild/dependencies/boost.py +1083 -0
- package/releng/meson/mesonbuild/dependencies/cmake.py +656 -0
- package/releng/meson/mesonbuild/dependencies/coarrays.py +80 -0
- package/releng/meson/mesonbuild/dependencies/configtool.py +163 -0
- package/releng/meson/mesonbuild/dependencies/cuda.py +295 -0
- package/releng/meson/mesonbuild/dependencies/data/CMakeLists.txt +102 -0
- package/releng/meson/mesonbuild/dependencies/data/CMakeListsLLVM.txt +204 -0
- package/releng/meson/mesonbuild/dependencies/data/CMakePathInfo.txt +31 -0
- package/releng/meson/mesonbuild/dependencies/data/__init__.py +0 -0
- package/releng/meson/mesonbuild/dependencies/detect.py +225 -0
- package/releng/meson/mesonbuild/dependencies/dev.py +707 -0
- package/releng/meson/mesonbuild/dependencies/dub.py +424 -0
- package/releng/meson/mesonbuild/dependencies/factory.py +146 -0
- package/releng/meson/mesonbuild/dependencies/framework.py +111 -0
- package/releng/meson/mesonbuild/dependencies/hdf5.py +168 -0
- package/releng/meson/mesonbuild/dependencies/misc.py +618 -0
- package/releng/meson/mesonbuild/dependencies/mpi.py +231 -0
- package/releng/meson/mesonbuild/dependencies/pkgconfig.py +570 -0
- package/releng/meson/mesonbuild/dependencies/platform.py +52 -0
- package/releng/meson/mesonbuild/dependencies/python.py +431 -0
- package/releng/meson/mesonbuild/dependencies/qt.py +484 -0
- package/releng/meson/mesonbuild/dependencies/scalapack.py +142 -0
- package/releng/meson/mesonbuild/dependencies/ui.py +281 -0
- package/releng/meson/mesonbuild/depfile.py +82 -0
- package/releng/meson/mesonbuild/envconfig.py +480 -0
- package/releng/meson/mesonbuild/environment.py +987 -0
- package/releng/meson/mesonbuild/interpreter/__init__.py +47 -0
- package/releng/meson/mesonbuild/interpreter/compiler.py +900 -0
- package/releng/meson/mesonbuild/interpreter/dependencyfallbacks.py +386 -0
- package/releng/meson/mesonbuild/interpreter/interpreter.py +3595 -0
- package/releng/meson/mesonbuild/interpreter/interpreterobjects.py +1096 -0
- package/releng/meson/mesonbuild/interpreter/kwargs.py +479 -0
- package/releng/meson/mesonbuild/interpreter/mesonmain.py +487 -0
- package/releng/meson/mesonbuild/interpreter/primitives/__init__.py +29 -0
- package/releng/meson/mesonbuild/interpreter/primitives/array.py +108 -0
- package/releng/meson/mesonbuild/interpreter/primitives/boolean.py +52 -0
- package/releng/meson/mesonbuild/interpreter/primitives/dict.py +88 -0
- package/releng/meson/mesonbuild/interpreter/primitives/integer.py +86 -0
- package/releng/meson/mesonbuild/interpreter/primitives/range.py +38 -0
- package/releng/meson/mesonbuild/interpreter/primitives/string.py +247 -0
- package/releng/meson/mesonbuild/interpreter/type_checking.py +853 -0
- package/releng/meson/mesonbuild/interpreterbase/__init__.py +126 -0
- package/releng/meson/mesonbuild/interpreterbase/_unholder.py +25 -0
- package/releng/meson/mesonbuild/interpreterbase/baseobjects.py +174 -0
- package/releng/meson/mesonbuild/interpreterbase/decorators.py +806 -0
- package/releng/meson/mesonbuild/interpreterbase/disabler.py +35 -0
- package/releng/meson/mesonbuild/interpreterbase/exceptions.py +22 -0
- package/releng/meson/mesonbuild/interpreterbase/helpers.py +67 -0
- package/releng/meson/mesonbuild/interpreterbase/interpreterbase.py +665 -0
- package/releng/meson/mesonbuild/interpreterbase/operator.py +32 -0
- package/releng/meson/mesonbuild/linkers/__init__.py +20 -0
- package/releng/meson/mesonbuild/linkers/base.py +39 -0
- package/releng/meson/mesonbuild/linkers/detect.py +229 -0
- package/releng/meson/mesonbuild/linkers/linkers.py +1614 -0
- package/releng/meson/mesonbuild/mcompile.py +380 -0
- package/releng/meson/mesonbuild/mconf.py +368 -0
- package/releng/meson/mesonbuild/mdevenv.py +234 -0
- package/releng/meson/mesonbuild/mdist.py +376 -0
- package/releng/meson/mesonbuild/mesondata.py +38 -0
- package/releng/meson/mesonbuild/mesonlib.py +23 -0
- package/releng/meson/mesonbuild/mesonmain.py +289 -0
- package/releng/meson/mesonbuild/minit.py +204 -0
- package/releng/meson/mesonbuild/minstall.py +864 -0
- package/releng/meson/mesonbuild/mintro.py +667 -0
- package/releng/meson/mesonbuild/mlog.py +542 -0
- package/releng/meson/mesonbuild/modules/__init__.py +270 -0
- package/releng/meson/mesonbuild/modules/cmake.py +442 -0
- package/releng/meson/mesonbuild/modules/cuda.py +377 -0
- package/releng/meson/mesonbuild/modules/dlang.py +117 -0
- package/releng/meson/mesonbuild/modules/external_project.py +306 -0
- package/releng/meson/mesonbuild/modules/fs.py +323 -0
- package/releng/meson/mesonbuild/modules/gnome.py +2215 -0
- package/releng/meson/mesonbuild/modules/hotdoc.py +487 -0
- package/releng/meson/mesonbuild/modules/i18n.py +405 -0
- package/releng/meson/mesonbuild/modules/icestorm.py +123 -0
- package/releng/meson/mesonbuild/modules/java.py +112 -0
- package/releng/meson/mesonbuild/modules/keyval.py +65 -0
- package/releng/meson/mesonbuild/modules/modtest.py +33 -0
- package/releng/meson/mesonbuild/modules/pkgconfig.py +744 -0
- package/releng/meson/mesonbuild/modules/python.py +556 -0
- package/releng/meson/mesonbuild/modules/python3.py +85 -0
- package/releng/meson/mesonbuild/modules/qt.py +621 -0
- package/releng/meson/mesonbuild/modules/qt4.py +23 -0
- package/releng/meson/mesonbuild/modules/qt5.py +23 -0
- package/releng/meson/mesonbuild/modules/qt6.py +22 -0
- package/releng/meson/mesonbuild/modules/rust.py +355 -0
- package/releng/meson/mesonbuild/modules/simd.py +114 -0
- package/releng/meson/mesonbuild/modules/sourceset.py +291 -0
- package/releng/meson/mesonbuild/modules/wayland.py +151 -0
- package/releng/meson/mesonbuild/modules/windows.py +207 -0
- package/releng/meson/mesonbuild/mparser.py +1114 -0
- package/releng/meson/mesonbuild/msetup.py +365 -0
- package/releng/meson/mesonbuild/msubprojects.py +764 -0
- package/releng/meson/mesonbuild/mtest.py +2201 -0
- package/releng/meson/mesonbuild/munstable_coredata.py +107 -0
- package/releng/meson/mesonbuild/optinterpreter.py +276 -0
- package/releng/meson/mesonbuild/programs.py +367 -0
- package/releng/meson/mesonbuild/rewriter.py +1075 -0
- package/releng/meson/mesonbuild/scripts/__init__.py +10 -0
- package/releng/meson/mesonbuild/scripts/clangformat.py +55 -0
- package/releng/meson/mesonbuild/scripts/clangtidy.py +30 -0
- package/releng/meson/mesonbuild/scripts/cleantrees.py +35 -0
- package/releng/meson/mesonbuild/scripts/cmake_run_ctgt.py +103 -0
- package/releng/meson/mesonbuild/scripts/cmd_or_ps.ps1 +17 -0
- package/releng/meson/mesonbuild/scripts/copy.py +19 -0
- package/releng/meson/mesonbuild/scripts/coverage.py +214 -0
- package/releng/meson/mesonbuild/scripts/delwithsuffix.py +27 -0
- package/releng/meson/mesonbuild/scripts/depfixer.py +495 -0
- package/releng/meson/mesonbuild/scripts/depscan.py +198 -0
- package/releng/meson/mesonbuild/scripts/dirchanger.py +20 -0
- package/releng/meson/mesonbuild/scripts/env2mfile.py +402 -0
- package/releng/meson/mesonbuild/scripts/externalproject.py +106 -0
- package/releng/meson/mesonbuild/scripts/gettext.py +86 -0
- package/releng/meson/mesonbuild/scripts/gtkdochelper.py +286 -0
- package/releng/meson/mesonbuild/scripts/hotdochelper.py +40 -0
- package/releng/meson/mesonbuild/scripts/itstool.py +77 -0
- package/releng/meson/mesonbuild/scripts/meson_exe.py +115 -0
- package/releng/meson/mesonbuild/scripts/msgfmthelper.py +29 -0
- package/releng/meson/mesonbuild/scripts/pycompile.py +54 -0
- package/releng/meson/mesonbuild/scripts/python_info.py +121 -0
- package/releng/meson/mesonbuild/scripts/regen_checker.py +55 -0
- package/releng/meson/mesonbuild/scripts/run_tool.py +58 -0
- package/releng/meson/mesonbuild/scripts/scanbuild.py +57 -0
- package/releng/meson/mesonbuild/scripts/symbolextractor.py +322 -0
- package/releng/meson/mesonbuild/scripts/tags.py +44 -0
- package/releng/meson/mesonbuild/scripts/test_loaded_modules.py +14 -0
- package/releng/meson/mesonbuild/scripts/uninstall.py +41 -0
- package/releng/meson/mesonbuild/scripts/vcstagger.py +35 -0
- package/releng/meson/mesonbuild/scripts/yasm.py +24 -0
- package/releng/meson/mesonbuild/templates/__init__.py +0 -0
- package/releng/meson/mesonbuild/templates/cpptemplates.py +143 -0
- package/releng/meson/mesonbuild/templates/cstemplates.py +90 -0
- package/releng/meson/mesonbuild/templates/ctemplates.py +126 -0
- package/releng/meson/mesonbuild/templates/cudatemplates.py +143 -0
- package/releng/meson/mesonbuild/templates/dlangtemplates.py +109 -0
- package/releng/meson/mesonbuild/templates/fortrantemplates.py +101 -0
- package/releng/meson/mesonbuild/templates/javatemplates.py +94 -0
- package/releng/meson/mesonbuild/templates/mesontemplates.py +70 -0
- package/releng/meson/mesonbuild/templates/objcpptemplates.py +126 -0
- package/releng/meson/mesonbuild/templates/objctemplates.py +126 -0
- package/releng/meson/mesonbuild/templates/rusttemplates.py +79 -0
- package/releng/meson/mesonbuild/templates/samplefactory.py +41 -0
- package/releng/meson/mesonbuild/templates/sampleimpl.py +160 -0
- package/releng/meson/mesonbuild/templates/valatemplates.py +82 -0
- package/releng/meson/mesonbuild/utils/__init__.py +0 -0
- package/releng/meson/mesonbuild/utils/core.py +166 -0
- package/releng/meson/mesonbuild/utils/platform.py +27 -0
- package/releng/meson/mesonbuild/utils/posix.py +32 -0
- package/releng/meson/mesonbuild/utils/universal.py +2445 -0
- package/releng/meson/mesonbuild/utils/vsenv.py +126 -0
- package/releng/meson/mesonbuild/utils/win32.py +29 -0
- package/releng/meson/mesonbuild/wrap/__init__.py +59 -0
- package/releng/meson/mesonbuild/wrap/wrap.py +846 -0
- package/releng/meson/mesonbuild/wrap/wraptool.py +198 -0
- package/releng/meson-scripts/BSDmakefile +6 -0
- package/releng/meson-scripts/Makefile +16 -0
- package/releng/meson-scripts/configure +18 -0
- package/releng/meson-scripts/configure.bat +22 -0
- package/releng/meson-scripts/make.bat +23 -0
- package/releng/meson_configure.py +506 -0
- package/releng/meson_make.py +131 -0
- package/releng/mkdevkit.py +107 -0
- package/releng/mkfatmacho.py +54 -0
- package/releng/post-process-oabi.py +97 -0
- package/releng/progress.py +14 -0
- package/releng/sync-from-upstream.py +185 -0
- package/releng/tomlkit/tomlkit/__init__.py +59 -0
- package/releng/tomlkit/tomlkit/_compat.py +22 -0
- package/releng/tomlkit/tomlkit/_types.py +83 -0
- package/releng/tomlkit/tomlkit/_utils.py +158 -0
- package/releng/tomlkit/tomlkit/api.py +308 -0
- package/releng/tomlkit/tomlkit/container.py +875 -0
- package/releng/tomlkit/tomlkit/exceptions.py +227 -0
- package/releng/tomlkit/tomlkit/items.py +1967 -0
- package/releng/tomlkit/tomlkit/parser.py +1141 -0
- package/releng/tomlkit/tomlkit/py.typed +0 -0
- package/releng/tomlkit/tomlkit/source.py +180 -0
- package/releng/tomlkit/tomlkit/toml_char.py +52 -0
- package/releng/tomlkit/tomlkit/toml_document.py +7 -0
- package/releng/tomlkit/tomlkit/toml_file.py +58 -0
- package/releng/winenv.py +140 -0
- package/scripts/adjust-version.py +19 -0
- package/scripts/detect-version.py +40 -0
- package/scripts/fetch-abi-bits.py +343 -0
- package/scripts/install.js +23 -0
- package/scripts/package.py +15 -0
- package/src/addon.cc +76 -0
- package/src/application.cc +148 -0
- package/src/application.h +31 -0
- package/src/authentication.cc +174 -0
- package/src/authentication.h +24 -0
- package/src/bus.cc +167 -0
- package/src/bus.h +33 -0
- package/src/cancellable.cc +117 -0
- package/src/cancellable.h +31 -0
- package/src/child.cc +150 -0
- package/src/child.h +32 -0
- package/src/crash.cc +122 -0
- package/src/crash.h +30 -0
- package/src/device.cc +1302 -0
- package/src/device.h +55 -0
- package/src/device_manager.cc +362 -0
- package/src/device_manager.h +35 -0
- package/src/endpoint_parameters.cc +171 -0
- package/src/endpoint_parameters.h +28 -0
- package/src/glib_context.cc +62 -0
- package/src/glib_context.h +29 -0
- package/src/glib_object.cc +25 -0
- package/src/glib_object.h +37 -0
- package/src/iostream.cc +247 -0
- package/src/iostream.h +30 -0
- package/src/meson.build +26 -0
- package/src/operation.h +94 -0
- package/src/portal_membership.cc +100 -0
- package/src/portal_membership.h +26 -0
- package/src/portal_service.cc +401 -0
- package/src/portal_service.h +40 -0
- package/src/process.cc +135 -0
- package/src/process.h +30 -0
- package/src/relay.cc +139 -0
- package/src/relay.h +31 -0
- package/src/runtime.cc +443 -0
- package/src/runtime.h +64 -0
- package/src/script.cc +301 -0
- package/src/script.h +36 -0
- package/src/session.cc +860 -0
- package/src/session.h +42 -0
- package/src/signals.cc +334 -0
- package/src/signals.h +47 -0
- package/src/spawn.cc +95 -0
- package/src/spawn.h +27 -0
- package/src/usage_monitor.h +117 -0
- package/src/uv_context.cc +118 -0
- package/src/uv_context.h +40 -0
- package/src/win_delay_load_hook.cc +63 -0
- package/subprojects/frida-core.wrap +8 -0
- package/subprojects/nan.wrap +9 -0
- package/subprojects/packagefiles/nan.patch +13 -0
- package/test/data/index.ts +13 -0
- package/test/data/unixvictim-linux-x86 +0 -0
- package/test/data/unixvictim-linux-x86_64 +0 -0
- package/test/data/unixvictim-macos +0 -0
- package/test/device.ts +27 -0
- package/test/device_manager.ts +16 -0
- package/test/labrat.ts +32 -0
- package/test/script.ts +176 -0
- package/test/session.ts +73 -0
- package/tsconfig.json +18 -0
|
@@ -0,0 +1,663 @@
|
|
|
1
|
+
# SPDX-License-Identifier: Apache-2.0
|
|
2
|
+
# Copyright 2013-2018 The Meson development team
|
|
3
|
+
# Copyright © 2024 Intel Corporation
|
|
4
|
+
|
|
5
|
+
# This file contains the detection logic for external dependencies.
|
|
6
|
+
# Custom logic for several other packages are in separate files.
|
|
7
|
+
|
|
8
|
+
from __future__ import annotations
|
|
9
|
+
import copy
|
|
10
|
+
import os
|
|
11
|
+
import collections
|
|
12
|
+
import itertools
|
|
13
|
+
import typing as T
|
|
14
|
+
from enum import Enum
|
|
15
|
+
|
|
16
|
+
from .. import mlog, mesonlib
|
|
17
|
+
from ..compilers import clib_langs
|
|
18
|
+
from ..mesonlib import LibType, MachineChoice, MesonException, HoldableObject, OptionKey
|
|
19
|
+
from ..mesonlib import version_compare_many
|
|
20
|
+
#from ..interpreterbase import FeatureDeprecated, FeatureNew
|
|
21
|
+
|
|
22
|
+
if T.TYPE_CHECKING:
|
|
23
|
+
from ..compilers.compilers import Compiler
|
|
24
|
+
from ..environment import Environment
|
|
25
|
+
from ..interpreterbase import FeatureCheckBase
|
|
26
|
+
from ..build import (
|
|
27
|
+
CustomTarget, IncludeDirs, CustomTargetIndex, LibTypes,
|
|
28
|
+
StaticLibrary, StructuredSources, ExtractedObjects, GeneratedTypes
|
|
29
|
+
)
|
|
30
|
+
from ..interpreter.type_checking import PkgConfigDefineType
|
|
31
|
+
|
|
32
|
+
_MissingCompilerBase = Compiler
|
|
33
|
+
else:
|
|
34
|
+
_MissingCompilerBase = object
|
|
35
|
+
|
|
36
|
+
|
|
37
|
+
class DependencyException(MesonException):
|
|
38
|
+
'''Exceptions raised while trying to find dependencies'''
|
|
39
|
+
|
|
40
|
+
|
|
41
|
+
class MissingCompiler(_MissingCompilerBase):
|
|
42
|
+
"""Represent a None Compiler - when no tool chain is found.
|
|
43
|
+
replacing AttributeError with DependencyException"""
|
|
44
|
+
|
|
45
|
+
# These are needed in type checking mode to avoid errors, but we don't want
|
|
46
|
+
# the extra overhead at runtime
|
|
47
|
+
if T.TYPE_CHECKING:
|
|
48
|
+
def __init__(self) -> None:
|
|
49
|
+
pass
|
|
50
|
+
|
|
51
|
+
def get_optimization_args(self, optimization_level: str) -> T.List[str]:
|
|
52
|
+
return []
|
|
53
|
+
|
|
54
|
+
def get_output_args(self, outputname: str) -> T.List[str]:
|
|
55
|
+
return []
|
|
56
|
+
|
|
57
|
+
def sanity_check(self, work_dir: str, environment: 'Environment') -> None:
|
|
58
|
+
return None
|
|
59
|
+
|
|
60
|
+
def __getattr__(self, item: str) -> T.Any:
|
|
61
|
+
if item.startswith('__'):
|
|
62
|
+
raise AttributeError()
|
|
63
|
+
raise DependencyException('no toolchain found')
|
|
64
|
+
|
|
65
|
+
def __bool__(self) -> bool:
|
|
66
|
+
return False
|
|
67
|
+
|
|
68
|
+
|
|
69
|
+
class DependencyMethods(Enum):
|
|
70
|
+
# Auto means to use whatever dependency checking mechanisms in whatever order meson thinks is best.
|
|
71
|
+
AUTO = 'auto'
|
|
72
|
+
PKGCONFIG = 'pkg-config'
|
|
73
|
+
CMAKE = 'cmake'
|
|
74
|
+
# The dependency is provided by the standard library and does not need to be linked
|
|
75
|
+
BUILTIN = 'builtin'
|
|
76
|
+
# Just specify the standard link arguments, assuming the operating system provides the library.
|
|
77
|
+
SYSTEM = 'system'
|
|
78
|
+
# This is only supported on OSX - search the frameworks directory by name.
|
|
79
|
+
EXTRAFRAMEWORK = 'extraframework'
|
|
80
|
+
# Detect using the sysconfig module.
|
|
81
|
+
SYSCONFIG = 'sysconfig'
|
|
82
|
+
# Specify using a "program"-config style tool
|
|
83
|
+
CONFIG_TOOL = 'config-tool'
|
|
84
|
+
# For backwards compatibility
|
|
85
|
+
SDLCONFIG = 'sdlconfig'
|
|
86
|
+
CUPSCONFIG = 'cups-config'
|
|
87
|
+
PCAPCONFIG = 'pcap-config'
|
|
88
|
+
LIBWMFCONFIG = 'libwmf-config'
|
|
89
|
+
QMAKE = 'qmake'
|
|
90
|
+
# Misc
|
|
91
|
+
DUB = 'dub'
|
|
92
|
+
|
|
93
|
+
|
|
94
|
+
DependencyTypeName = T.NewType('DependencyTypeName', str)
|
|
95
|
+
|
|
96
|
+
|
|
97
|
+
class Dependency(HoldableObject):
|
|
98
|
+
|
|
99
|
+
@classmethod
|
|
100
|
+
def _process_include_type_kw(cls, kwargs: T.Dict[str, T.Any]) -> str:
|
|
101
|
+
if 'include_type' not in kwargs:
|
|
102
|
+
return 'preserve'
|
|
103
|
+
if not isinstance(kwargs['include_type'], str):
|
|
104
|
+
raise DependencyException('The include_type kwarg must be a string type')
|
|
105
|
+
if kwargs['include_type'] not in ['preserve', 'system', 'non-system']:
|
|
106
|
+
raise DependencyException("include_type may only be one of ['preserve', 'system', 'non-system']")
|
|
107
|
+
return kwargs['include_type']
|
|
108
|
+
|
|
109
|
+
def __init__(self, type_name: DependencyTypeName, kwargs: T.Dict[str, T.Any]) -> None:
|
|
110
|
+
# This allows two Dependencies to be compared even after being copied.
|
|
111
|
+
# The purpose is to allow the name to be changed, but still have a proper comparison
|
|
112
|
+
self.__id = id(self)
|
|
113
|
+
self.name = f'dep{id(self)}'
|
|
114
|
+
self.version: T.Optional[str] = None
|
|
115
|
+
self.language: T.Optional[str] = None # None means C-like
|
|
116
|
+
self.is_found = False
|
|
117
|
+
self.type_name = type_name
|
|
118
|
+
self.compile_args: T.List[str] = []
|
|
119
|
+
self.link_args: T.List[str] = []
|
|
120
|
+
# Raw -L and -l arguments without manual library searching
|
|
121
|
+
# If None, self.link_args will be used
|
|
122
|
+
self.raw_link_args: T.Optional[T.List[str]] = None
|
|
123
|
+
self.sources: T.List[T.Union[mesonlib.File, GeneratedTypes, 'StructuredSources']] = []
|
|
124
|
+
self.extra_files: T.List[mesonlib.File] = []
|
|
125
|
+
self.include_type = self._process_include_type_kw(kwargs)
|
|
126
|
+
self.ext_deps: T.List[Dependency] = []
|
|
127
|
+
self.d_features: T.DefaultDict[str, T.List[T.Any]] = collections.defaultdict(list)
|
|
128
|
+
self.featurechecks: T.List['FeatureCheckBase'] = []
|
|
129
|
+
self.feature_since: T.Optional[T.Tuple[str, str]] = None
|
|
130
|
+
|
|
131
|
+
def __eq__(self, other: object) -> bool:
|
|
132
|
+
if not isinstance(other, Dependency):
|
|
133
|
+
return NotImplemented
|
|
134
|
+
return self.__id == other.__id
|
|
135
|
+
|
|
136
|
+
def __hash__(self) -> int:
|
|
137
|
+
return self.__id
|
|
138
|
+
|
|
139
|
+
def __repr__(self) -> str:
|
|
140
|
+
return f'<{self.__class__.__name__} {self.name}: {self.is_found}>'
|
|
141
|
+
|
|
142
|
+
def is_built(self) -> bool:
|
|
143
|
+
return False
|
|
144
|
+
|
|
145
|
+
def summary_value(self) -> T.Union[str, mlog.AnsiDecorator, mlog.AnsiText]:
|
|
146
|
+
if not self.found():
|
|
147
|
+
return mlog.red('NO')
|
|
148
|
+
if not self.version:
|
|
149
|
+
return mlog.green('YES')
|
|
150
|
+
return mlog.AnsiText(mlog.green('YES'), ' ', mlog.cyan(self.version))
|
|
151
|
+
|
|
152
|
+
def get_compile_args(self) -> T.List[str]:
|
|
153
|
+
if self.include_type == 'system':
|
|
154
|
+
converted = []
|
|
155
|
+
for i in self.compile_args:
|
|
156
|
+
if i.startswith('-I') or i.startswith('/I'):
|
|
157
|
+
converted += ['-isystem' + i[2:]]
|
|
158
|
+
else:
|
|
159
|
+
converted += [i]
|
|
160
|
+
return converted
|
|
161
|
+
if self.include_type == 'non-system':
|
|
162
|
+
converted = []
|
|
163
|
+
for i in self.compile_args:
|
|
164
|
+
if i.startswith('-isystem'):
|
|
165
|
+
converted += ['-I' + i[8:]]
|
|
166
|
+
else:
|
|
167
|
+
converted += [i]
|
|
168
|
+
return converted
|
|
169
|
+
return self.compile_args
|
|
170
|
+
|
|
171
|
+
def get_all_compile_args(self) -> T.List[str]:
|
|
172
|
+
"""Get the compile arguments from this dependency and it's sub dependencies."""
|
|
173
|
+
return list(itertools.chain(self.get_compile_args(),
|
|
174
|
+
*(d.get_all_compile_args() for d in self.ext_deps)))
|
|
175
|
+
|
|
176
|
+
def get_link_args(self, language: T.Optional[str] = None, raw: bool = False) -> T.List[str]:
|
|
177
|
+
if raw and self.raw_link_args is not None:
|
|
178
|
+
return self.raw_link_args
|
|
179
|
+
return self.link_args
|
|
180
|
+
|
|
181
|
+
def get_all_link_args(self) -> T.List[str]:
|
|
182
|
+
"""Get the link arguments from this dependency and it's sub dependencies."""
|
|
183
|
+
return list(itertools.chain(self.get_link_args(),
|
|
184
|
+
*(d.get_all_link_args() for d in self.ext_deps)))
|
|
185
|
+
|
|
186
|
+
def found(self) -> bool:
|
|
187
|
+
return self.is_found
|
|
188
|
+
|
|
189
|
+
def get_sources(self) -> T.List[T.Union[mesonlib.File, GeneratedTypes, 'StructuredSources']]:
|
|
190
|
+
"""Source files that need to be added to the target.
|
|
191
|
+
As an example, gtest-all.cc when using GTest."""
|
|
192
|
+
return self.sources
|
|
193
|
+
|
|
194
|
+
def get_extra_files(self) -> T.List[mesonlib.File]:
|
|
195
|
+
"""Mostly for introspection and IDEs"""
|
|
196
|
+
return self.extra_files
|
|
197
|
+
|
|
198
|
+
def get_name(self) -> str:
|
|
199
|
+
return self.name
|
|
200
|
+
|
|
201
|
+
def get_version(self) -> str:
|
|
202
|
+
if self.version:
|
|
203
|
+
return self.version
|
|
204
|
+
else:
|
|
205
|
+
return 'unknown'
|
|
206
|
+
|
|
207
|
+
def get_include_dirs(self) -> T.List['IncludeDirs']:
|
|
208
|
+
return []
|
|
209
|
+
|
|
210
|
+
def get_include_type(self) -> str:
|
|
211
|
+
return self.include_type
|
|
212
|
+
|
|
213
|
+
def get_exe_args(self, compiler: 'Compiler') -> T.List[str]:
|
|
214
|
+
return []
|
|
215
|
+
|
|
216
|
+
def get_partial_dependency(self, *, compile_args: bool = False,
|
|
217
|
+
link_args: bool = False, links: bool = False,
|
|
218
|
+
includes: bool = False, sources: bool = False) -> 'Dependency':
|
|
219
|
+
"""Create a new dependency that contains part of the parent dependency.
|
|
220
|
+
|
|
221
|
+
The following options can be inherited:
|
|
222
|
+
links -- all link_with arguments
|
|
223
|
+
includes -- all include_directory and -I/-isystem calls
|
|
224
|
+
sources -- any source, header, or generated sources
|
|
225
|
+
compile_args -- any compile args
|
|
226
|
+
link_args -- any link args
|
|
227
|
+
|
|
228
|
+
Additionally the new dependency will have the version parameter of it's
|
|
229
|
+
parent (if any) and the requested values of any dependencies will be
|
|
230
|
+
added as well.
|
|
231
|
+
"""
|
|
232
|
+
raise RuntimeError('Unreachable code in partial_dependency called')
|
|
233
|
+
|
|
234
|
+
def _add_sub_dependency(self, deplist: T.Iterable[T.Callable[[], 'Dependency']]) -> bool:
|
|
235
|
+
"""Add an internal dependency from a list of possible dependencies.
|
|
236
|
+
|
|
237
|
+
This method is intended to make it easier to add additional
|
|
238
|
+
dependencies to another dependency internally.
|
|
239
|
+
|
|
240
|
+
Returns true if the dependency was successfully added, false
|
|
241
|
+
otherwise.
|
|
242
|
+
"""
|
|
243
|
+
for d in deplist:
|
|
244
|
+
dep = d()
|
|
245
|
+
if dep.is_found:
|
|
246
|
+
self.ext_deps.append(dep)
|
|
247
|
+
return True
|
|
248
|
+
return False
|
|
249
|
+
|
|
250
|
+
def get_variable(self, *, cmake: T.Optional[str] = None, pkgconfig: T.Optional[str] = None,
|
|
251
|
+
configtool: T.Optional[str] = None, internal: T.Optional[str] = None,
|
|
252
|
+
default_value: T.Optional[str] = None,
|
|
253
|
+
pkgconfig_define: PkgConfigDefineType = None) -> str:
|
|
254
|
+
if default_value is not None:
|
|
255
|
+
return default_value
|
|
256
|
+
raise DependencyException(f'No default provided for dependency {self!r}, which is not pkg-config, cmake, or config-tool based.')
|
|
257
|
+
|
|
258
|
+
def generate_system_dependency(self, include_type: str) -> 'Dependency':
|
|
259
|
+
new_dep = copy.deepcopy(self)
|
|
260
|
+
new_dep.include_type = self._process_include_type_kw({'include_type': include_type})
|
|
261
|
+
return new_dep
|
|
262
|
+
|
|
263
|
+
class InternalDependency(Dependency):
|
|
264
|
+
def __init__(self, version: str, incdirs: T.List['IncludeDirs'], compile_args: T.List[str],
|
|
265
|
+
link_args: T.List[str],
|
|
266
|
+
libraries: T.List[LibTypes],
|
|
267
|
+
whole_libraries: T.List[T.Union[StaticLibrary, CustomTarget, CustomTargetIndex]],
|
|
268
|
+
sources: T.Sequence[T.Union[mesonlib.File, GeneratedTypes, StructuredSources]],
|
|
269
|
+
extra_files: T.Sequence[mesonlib.File],
|
|
270
|
+
ext_deps: T.List[Dependency], variables: T.Dict[str, str],
|
|
271
|
+
d_module_versions: T.List[T.Union[str, int]], d_import_dirs: T.List['IncludeDirs'],
|
|
272
|
+
objects: T.List['ExtractedObjects']):
|
|
273
|
+
super().__init__(DependencyTypeName('internal'), {})
|
|
274
|
+
self.version = version
|
|
275
|
+
self.is_found = True
|
|
276
|
+
self.include_directories = incdirs
|
|
277
|
+
self.compile_args = compile_args
|
|
278
|
+
self.link_args = link_args
|
|
279
|
+
self.libraries = libraries
|
|
280
|
+
self.whole_libraries = whole_libraries
|
|
281
|
+
self.sources = list(sources)
|
|
282
|
+
self.extra_files = list(extra_files)
|
|
283
|
+
self.ext_deps = ext_deps
|
|
284
|
+
self.variables = variables
|
|
285
|
+
self.objects = objects
|
|
286
|
+
if d_module_versions:
|
|
287
|
+
self.d_features['versions'] = d_module_versions
|
|
288
|
+
if d_import_dirs:
|
|
289
|
+
self.d_features['import_dirs'] = d_import_dirs
|
|
290
|
+
|
|
291
|
+
def __deepcopy__(self, memo: T.Dict[int, 'InternalDependency']) -> 'InternalDependency':
|
|
292
|
+
result = self.__class__.__new__(self.__class__)
|
|
293
|
+
assert isinstance(result, InternalDependency)
|
|
294
|
+
memo[id(self)] = result
|
|
295
|
+
for k, v in self.__dict__.items():
|
|
296
|
+
if k in {'libraries', 'whole_libraries'}:
|
|
297
|
+
setattr(result, k, copy.copy(v))
|
|
298
|
+
else:
|
|
299
|
+
setattr(result, k, copy.deepcopy(v, memo))
|
|
300
|
+
return result
|
|
301
|
+
|
|
302
|
+
def summary_value(self) -> mlog.AnsiDecorator:
|
|
303
|
+
# Omit the version. Most of the time it will be just the project
|
|
304
|
+
# version, which is uninteresting in the summary.
|
|
305
|
+
return mlog.green('YES')
|
|
306
|
+
|
|
307
|
+
def is_built(self) -> bool:
|
|
308
|
+
if self.sources or self.libraries or self.whole_libraries:
|
|
309
|
+
return True
|
|
310
|
+
return any(d.is_built() for d in self.ext_deps)
|
|
311
|
+
|
|
312
|
+
def get_partial_dependency(self, *, compile_args: bool = False,
|
|
313
|
+
link_args: bool = False, links: bool = False,
|
|
314
|
+
includes: bool = False, sources: bool = False,
|
|
315
|
+
extra_files: bool = False) -> InternalDependency:
|
|
316
|
+
final_compile_args = self.compile_args.copy() if compile_args else []
|
|
317
|
+
final_link_args = self.link_args.copy() if link_args else []
|
|
318
|
+
final_libraries = self.libraries.copy() if links else []
|
|
319
|
+
final_whole_libraries = self.whole_libraries.copy() if links else []
|
|
320
|
+
final_sources = self.sources.copy() if sources else []
|
|
321
|
+
final_extra_files = self.extra_files.copy() if extra_files else []
|
|
322
|
+
final_includes = self.include_directories.copy() if includes else []
|
|
323
|
+
final_deps = [d.get_partial_dependency(
|
|
324
|
+
compile_args=compile_args, link_args=link_args, links=links,
|
|
325
|
+
includes=includes, sources=sources) for d in self.ext_deps]
|
|
326
|
+
return InternalDependency(
|
|
327
|
+
self.version, final_includes, final_compile_args,
|
|
328
|
+
final_link_args, final_libraries, final_whole_libraries,
|
|
329
|
+
final_sources, final_extra_files, final_deps, self.variables, [], [], [])
|
|
330
|
+
|
|
331
|
+
def get_include_dirs(self) -> T.List['IncludeDirs']:
|
|
332
|
+
return self.include_directories
|
|
333
|
+
|
|
334
|
+
def get_variable(self, *, cmake: T.Optional[str] = None, pkgconfig: T.Optional[str] = None,
|
|
335
|
+
configtool: T.Optional[str] = None, internal: T.Optional[str] = None,
|
|
336
|
+
default_value: T.Optional[str] = None,
|
|
337
|
+
pkgconfig_define: PkgConfigDefineType = None) -> str:
|
|
338
|
+
val = self.variables.get(internal, default_value)
|
|
339
|
+
if val is not None:
|
|
340
|
+
return val
|
|
341
|
+
raise DependencyException(f'Could not get an internal variable and no default provided for {self!r}')
|
|
342
|
+
|
|
343
|
+
def generate_link_whole_dependency(self) -> Dependency:
|
|
344
|
+
from ..build import SharedLibrary, CustomTarget, CustomTargetIndex
|
|
345
|
+
new_dep = copy.deepcopy(self)
|
|
346
|
+
for x in new_dep.libraries:
|
|
347
|
+
if isinstance(x, SharedLibrary):
|
|
348
|
+
raise MesonException('Cannot convert a dependency to link_whole when it contains a '
|
|
349
|
+
'SharedLibrary')
|
|
350
|
+
elif isinstance(x, (CustomTarget, CustomTargetIndex)) and x.links_dynamically():
|
|
351
|
+
raise MesonException('Cannot convert a dependency to link_whole when it contains a '
|
|
352
|
+
'CustomTarget or CustomTargetIndex which is a shared library')
|
|
353
|
+
|
|
354
|
+
# Mypy doesn't understand that the above is a TypeGuard
|
|
355
|
+
new_dep.whole_libraries += T.cast('T.List[T.Union[StaticLibrary, CustomTarget, CustomTargetIndex]]',
|
|
356
|
+
new_dep.libraries)
|
|
357
|
+
new_dep.libraries = []
|
|
358
|
+
return new_dep
|
|
359
|
+
|
|
360
|
+
class HasNativeKwarg:
|
|
361
|
+
def __init__(self, kwargs: T.Dict[str, T.Any]):
|
|
362
|
+
self.for_machine = self.get_for_machine_from_kwargs(kwargs)
|
|
363
|
+
|
|
364
|
+
def get_for_machine_from_kwargs(self, kwargs: T.Dict[str, T.Any]) -> MachineChoice:
|
|
365
|
+
return MachineChoice.BUILD if kwargs.get('native', False) else MachineChoice.HOST
|
|
366
|
+
|
|
367
|
+
class ExternalDependency(Dependency, HasNativeKwarg):
|
|
368
|
+
def __init__(self, type_name: DependencyTypeName, environment: 'Environment', kwargs: T.Dict[str, T.Any], language: T.Optional[str] = None):
|
|
369
|
+
Dependency.__init__(self, type_name, kwargs)
|
|
370
|
+
self.env = environment
|
|
371
|
+
self.name = type_name # default
|
|
372
|
+
self.is_found = False
|
|
373
|
+
self.language = language
|
|
374
|
+
version_reqs = kwargs.get('version', None)
|
|
375
|
+
if isinstance(version_reqs, str):
|
|
376
|
+
version_reqs = [version_reqs]
|
|
377
|
+
self.version_reqs: T.Optional[T.List[str]] = version_reqs
|
|
378
|
+
self.required = kwargs.get('required', True)
|
|
379
|
+
self.silent = kwargs.get('silent', False)
|
|
380
|
+
self.static = kwargs.get('static', self.env.coredata.get_option(OptionKey('prefer_static')))
|
|
381
|
+
self.libtype = LibType.STATIC if self.static else LibType.PREFER_SHARED
|
|
382
|
+
if not isinstance(self.static, bool):
|
|
383
|
+
raise DependencyException('Static keyword must be boolean')
|
|
384
|
+
# Is this dependency to be run on the build platform?
|
|
385
|
+
HasNativeKwarg.__init__(self, kwargs)
|
|
386
|
+
self.clib_compiler = detect_compiler(self.name, environment, self.for_machine, self.language)
|
|
387
|
+
|
|
388
|
+
def get_compiler(self) -> T.Union['MissingCompiler', 'Compiler']:
|
|
389
|
+
return self.clib_compiler
|
|
390
|
+
|
|
391
|
+
def get_partial_dependency(self, *, compile_args: bool = False,
|
|
392
|
+
link_args: bool = False, links: bool = False,
|
|
393
|
+
includes: bool = False, sources: bool = False) -> Dependency:
|
|
394
|
+
new = copy.copy(self)
|
|
395
|
+
if not compile_args:
|
|
396
|
+
new.compile_args = []
|
|
397
|
+
if not link_args:
|
|
398
|
+
new.link_args = []
|
|
399
|
+
if not sources:
|
|
400
|
+
new.sources = []
|
|
401
|
+
if not includes:
|
|
402
|
+
pass # TODO maybe filter compile_args?
|
|
403
|
+
if not sources:
|
|
404
|
+
new.sources = []
|
|
405
|
+
|
|
406
|
+
return new
|
|
407
|
+
|
|
408
|
+
def log_details(self) -> str:
|
|
409
|
+
return ''
|
|
410
|
+
|
|
411
|
+
def log_info(self) -> str:
|
|
412
|
+
return ''
|
|
413
|
+
|
|
414
|
+
@staticmethod
|
|
415
|
+
def log_tried() -> str:
|
|
416
|
+
return ''
|
|
417
|
+
|
|
418
|
+
# Check if dependency version meets the requirements
|
|
419
|
+
def _check_version(self) -> None:
|
|
420
|
+
if not self.is_found:
|
|
421
|
+
return
|
|
422
|
+
|
|
423
|
+
if self.version_reqs:
|
|
424
|
+
for_msg = ['for', mlog.bold(self.for_machine.get_lower_case_name()), 'machine']
|
|
425
|
+
|
|
426
|
+
# an unknown version can never satisfy any requirement
|
|
427
|
+
if not self.version:
|
|
428
|
+
self.is_found = False
|
|
429
|
+
found_msg: mlog.TV_LoggableList = []
|
|
430
|
+
found_msg.extend(['Dependency', mlog.bold(self.name)])
|
|
431
|
+
found_msg.extend(for_msg)
|
|
432
|
+
found_msg.append('found:')
|
|
433
|
+
found_msg.extend([mlog.red('NO'), 'unknown version, but need:', self.version_reqs])
|
|
434
|
+
mlog.log(*found_msg)
|
|
435
|
+
|
|
436
|
+
if self.required:
|
|
437
|
+
m = f'Unknown version, but need {self.version_reqs!r}.'
|
|
438
|
+
raise DependencyException(m)
|
|
439
|
+
|
|
440
|
+
else:
|
|
441
|
+
(self.is_found, not_found, found) = \
|
|
442
|
+
version_compare_many(self.version, self.version_reqs)
|
|
443
|
+
if not self.is_found:
|
|
444
|
+
found_msg = ['Dependency', mlog.bold(self.name)]
|
|
445
|
+
found_msg.extend(for_msg)
|
|
446
|
+
found_msg.append('found:')
|
|
447
|
+
found_msg += [mlog.red('NO'),
|
|
448
|
+
'found', mlog.normal_cyan(self.version), 'but need:',
|
|
449
|
+
mlog.bold(', '.join([f"'{e}'" for e in not_found]))]
|
|
450
|
+
if found:
|
|
451
|
+
found_msg += ['; matched:',
|
|
452
|
+
', '.join([f"'{e}'" for e in found])]
|
|
453
|
+
mlog.log(*found_msg)
|
|
454
|
+
|
|
455
|
+
if self.required:
|
|
456
|
+
m = 'Invalid version, need {!r} {!r} found {!r}.'
|
|
457
|
+
raise DependencyException(m.format(self.name, not_found, self.version))
|
|
458
|
+
return
|
|
459
|
+
|
|
460
|
+
|
|
461
|
+
class NotFoundDependency(Dependency):
|
|
462
|
+
def __init__(self, name: str, environment: 'Environment') -> None:
|
|
463
|
+
super().__init__(DependencyTypeName('not-found'), {})
|
|
464
|
+
self.env = environment
|
|
465
|
+
self.name = name
|
|
466
|
+
self.is_found = False
|
|
467
|
+
|
|
468
|
+
def get_partial_dependency(self, *, compile_args: bool = False,
|
|
469
|
+
link_args: bool = False, links: bool = False,
|
|
470
|
+
includes: bool = False, sources: bool = False) -> 'NotFoundDependency':
|
|
471
|
+
return copy.copy(self)
|
|
472
|
+
|
|
473
|
+
|
|
474
|
+
class ExternalLibrary(ExternalDependency):
|
|
475
|
+
def __init__(self, name: str, link_args: T.List[str], environment: 'Environment',
|
|
476
|
+
language: str, silent: bool = False) -> None:
|
|
477
|
+
super().__init__(DependencyTypeName('library'), environment, {}, language=language)
|
|
478
|
+
self.name = name
|
|
479
|
+
self.language = language
|
|
480
|
+
self.is_found = False
|
|
481
|
+
if link_args:
|
|
482
|
+
self.is_found = True
|
|
483
|
+
self.link_args = link_args
|
|
484
|
+
if not silent:
|
|
485
|
+
if self.is_found:
|
|
486
|
+
mlog.log('Library', mlog.bold(name), 'found:', mlog.green('YES'))
|
|
487
|
+
else:
|
|
488
|
+
mlog.log('Library', mlog.bold(name), 'found:', mlog.red('NO'))
|
|
489
|
+
|
|
490
|
+
def get_link_args(self, language: T.Optional[str] = None, raw: bool = False) -> T.List[str]:
|
|
491
|
+
'''
|
|
492
|
+
External libraries detected using a compiler must only be used with
|
|
493
|
+
compatible code. For instance, Vala libraries (.vapi files) cannot be
|
|
494
|
+
used with C code, and not all Rust library types can be linked with
|
|
495
|
+
C-like code. Note that C++ libraries *can* be linked with C code with
|
|
496
|
+
a C++ linker (and vice-versa).
|
|
497
|
+
'''
|
|
498
|
+
# Using a vala library in a non-vala target, or a non-vala library in a vala target
|
|
499
|
+
# XXX: This should be extended to other non-C linkers such as Rust
|
|
500
|
+
if (self.language == 'vala' and language != 'vala') or \
|
|
501
|
+
(language == 'vala' and self.language != 'vala'):
|
|
502
|
+
return []
|
|
503
|
+
return super().get_link_args(language=language, raw=raw)
|
|
504
|
+
|
|
505
|
+
def get_partial_dependency(self, *, compile_args: bool = False,
|
|
506
|
+
link_args: bool = False, links: bool = False,
|
|
507
|
+
includes: bool = False, sources: bool = False) -> 'ExternalLibrary':
|
|
508
|
+
# External library only has link_args, so ignore the rest of the
|
|
509
|
+
# interface.
|
|
510
|
+
new = copy.copy(self)
|
|
511
|
+
if not link_args:
|
|
512
|
+
new.link_args = []
|
|
513
|
+
return new
|
|
514
|
+
|
|
515
|
+
|
|
516
|
+
def get_leaf_external_dependencies(deps: T.List[Dependency]) -> T.List[Dependency]:
|
|
517
|
+
if not deps:
|
|
518
|
+
# Ensure that we always return a new instance
|
|
519
|
+
return deps.copy()
|
|
520
|
+
final_deps = []
|
|
521
|
+
while deps:
|
|
522
|
+
next_deps = []
|
|
523
|
+
for d in mesonlib.listify(deps):
|
|
524
|
+
if not isinstance(d, Dependency) or d.is_built():
|
|
525
|
+
raise DependencyException('Dependencies must be external dependencies')
|
|
526
|
+
final_deps.append(d)
|
|
527
|
+
next_deps.extend(d.ext_deps)
|
|
528
|
+
deps = next_deps
|
|
529
|
+
return final_deps
|
|
530
|
+
|
|
531
|
+
|
|
532
|
+
def sort_libpaths(libpaths: T.List[str], refpaths: T.List[str]) -> T.List[str]:
|
|
533
|
+
"""Sort <libpaths> according to <refpaths>
|
|
534
|
+
|
|
535
|
+
It is intended to be used to sort -L flags returned by pkg-config.
|
|
536
|
+
Pkg-config returns flags in random order which cannot be relied on.
|
|
537
|
+
"""
|
|
538
|
+
if len(refpaths) == 0:
|
|
539
|
+
return list(libpaths)
|
|
540
|
+
|
|
541
|
+
def key_func(libpath: str) -> T.Tuple[int, int]:
|
|
542
|
+
common_lengths: T.List[int] = []
|
|
543
|
+
for refpath in refpaths:
|
|
544
|
+
try:
|
|
545
|
+
common_path: str = os.path.commonpath([libpath, refpath])
|
|
546
|
+
except ValueError:
|
|
547
|
+
common_path = ''
|
|
548
|
+
common_lengths.append(len(common_path))
|
|
549
|
+
max_length = max(common_lengths)
|
|
550
|
+
max_index = common_lengths.index(max_length)
|
|
551
|
+
reversed_max_length = len(refpaths[max_index]) - max_length
|
|
552
|
+
return (max_index, reversed_max_length)
|
|
553
|
+
return sorted(libpaths, key=key_func)
|
|
554
|
+
|
|
555
|
+
def strip_system_libdirs(environment: 'Environment', for_machine: MachineChoice, link_args: T.List[str]) -> T.List[str]:
|
|
556
|
+
"""Remove -L<system path> arguments.
|
|
557
|
+
|
|
558
|
+
leaving these in will break builds where a user has a version of a library
|
|
559
|
+
in the system path, and a different version not in the system path if they
|
|
560
|
+
want to link against the non-system path version.
|
|
561
|
+
"""
|
|
562
|
+
exclude = {f'-L{p}' for p in environment.get_compiler_system_lib_dirs(for_machine)}
|
|
563
|
+
return [l for l in link_args if l not in exclude]
|
|
564
|
+
|
|
565
|
+
def strip_system_includedirs(environment: 'Environment', for_machine: MachineChoice, include_args: T.List[str]) -> T.List[str]:
|
|
566
|
+
"""Remove -I<system path> arguments.
|
|
567
|
+
|
|
568
|
+
leaving these in will break builds where user want dependencies with system
|
|
569
|
+
include-type used in rust.bindgen targets as if will cause system headers
|
|
570
|
+
to not be found.
|
|
571
|
+
"""
|
|
572
|
+
|
|
573
|
+
exclude = {f'-I{p}' for p in environment.get_compiler_system_include_dirs(for_machine)}
|
|
574
|
+
return [i for i in include_args if i not in exclude]
|
|
575
|
+
|
|
576
|
+
def process_method_kw(possible: T.Iterable[DependencyMethods], kwargs: T.Dict[str, T.Any]) -> T.List[DependencyMethods]:
|
|
577
|
+
method: T.Union[DependencyMethods, str] = kwargs.get('method', 'auto')
|
|
578
|
+
if isinstance(method, DependencyMethods):
|
|
579
|
+
return [method]
|
|
580
|
+
# TODO: try/except?
|
|
581
|
+
if method not in [e.value for e in DependencyMethods]:
|
|
582
|
+
raise DependencyException(f'method {method!r} is invalid')
|
|
583
|
+
method = DependencyMethods(method)
|
|
584
|
+
|
|
585
|
+
# Raise FeatureNew where appropriate
|
|
586
|
+
if method is DependencyMethods.CONFIG_TOOL:
|
|
587
|
+
# FIXME: needs to get a handle on the subproject
|
|
588
|
+
# FeatureNew.single_use('Configuration method "config-tool"', '0.44.0')
|
|
589
|
+
pass
|
|
590
|
+
# This sets per-tool config methods which are deprecated to to the new
|
|
591
|
+
# generic CONFIG_TOOL value.
|
|
592
|
+
if method in [DependencyMethods.SDLCONFIG, DependencyMethods.CUPSCONFIG,
|
|
593
|
+
DependencyMethods.PCAPCONFIG, DependencyMethods.LIBWMFCONFIG]:
|
|
594
|
+
# FIXME: needs to get a handle on the subproject
|
|
595
|
+
#FeatureDeprecated.single_use(f'Configuration method {method.value}', '0.44', 'Use "config-tool" instead.')
|
|
596
|
+
method = DependencyMethods.CONFIG_TOOL
|
|
597
|
+
if method is DependencyMethods.QMAKE:
|
|
598
|
+
# FIXME: needs to get a handle on the subproject
|
|
599
|
+
# FeatureDeprecated.single_use('Configuration method "qmake"', '0.58', 'Use "config-tool" instead.')
|
|
600
|
+
method = DependencyMethods.CONFIG_TOOL
|
|
601
|
+
|
|
602
|
+
# Set the detection method. If the method is set to auto, use any available method.
|
|
603
|
+
# If method is set to a specific string, allow only that detection method.
|
|
604
|
+
if method == DependencyMethods.AUTO:
|
|
605
|
+
methods = list(possible)
|
|
606
|
+
elif method in possible:
|
|
607
|
+
methods = [method]
|
|
608
|
+
else:
|
|
609
|
+
raise DependencyException(
|
|
610
|
+
'Unsupported detection method: {}, allowed methods are {}'.format(
|
|
611
|
+
method.value,
|
|
612
|
+
mlog.format_list([x.value for x in [DependencyMethods.AUTO] + list(possible)])))
|
|
613
|
+
|
|
614
|
+
return methods
|
|
615
|
+
|
|
616
|
+
def detect_compiler(name: str, env: 'Environment', for_machine: MachineChoice,
|
|
617
|
+
language: T.Optional[str]) -> T.Union['MissingCompiler', 'Compiler']:
|
|
618
|
+
"""Given a language and environment find the compiler used."""
|
|
619
|
+
compilers = env.coredata.compilers[for_machine]
|
|
620
|
+
|
|
621
|
+
# Set the compiler for this dependency if a language is specified,
|
|
622
|
+
# else try to pick something that looks usable.
|
|
623
|
+
if language:
|
|
624
|
+
if language not in compilers:
|
|
625
|
+
m = name.capitalize() + ' requires a {0} compiler, but ' \
|
|
626
|
+
'{0} is not in the list of project languages'
|
|
627
|
+
raise DependencyException(m.format(language.capitalize()))
|
|
628
|
+
return compilers[language]
|
|
629
|
+
else:
|
|
630
|
+
for lang in clib_langs:
|
|
631
|
+
try:
|
|
632
|
+
return compilers[lang]
|
|
633
|
+
except KeyError:
|
|
634
|
+
continue
|
|
635
|
+
return MissingCompiler()
|
|
636
|
+
|
|
637
|
+
|
|
638
|
+
class SystemDependency(ExternalDependency):
|
|
639
|
+
|
|
640
|
+
"""Dependency base for System type dependencies."""
|
|
641
|
+
|
|
642
|
+
def __init__(self, name: str, env: 'Environment', kwargs: T.Dict[str, T.Any],
|
|
643
|
+
language: T.Optional[str] = None) -> None:
|
|
644
|
+
super().__init__(DependencyTypeName('system'), env, kwargs, language=language)
|
|
645
|
+
self.name = name
|
|
646
|
+
|
|
647
|
+
@staticmethod
|
|
648
|
+
def log_tried() -> str:
|
|
649
|
+
return 'system'
|
|
650
|
+
|
|
651
|
+
|
|
652
|
+
class BuiltinDependency(ExternalDependency):
|
|
653
|
+
|
|
654
|
+
"""Dependency base for Builtin type dependencies."""
|
|
655
|
+
|
|
656
|
+
def __init__(self, name: str, env: 'Environment', kwargs: T.Dict[str, T.Any],
|
|
657
|
+
language: T.Optional[str] = None) -> None:
|
|
658
|
+
super().__init__(DependencyTypeName('builtin'), env, kwargs, language=language)
|
|
659
|
+
self.name = name
|
|
660
|
+
|
|
661
|
+
@staticmethod
|
|
662
|
+
def log_tried() -> str:
|
|
663
|
+
return 'builtin'
|