frida 16.2.1 → 16.2.3
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,788 @@
|
|
|
1
|
+
# SPDX-License-Identifier: Apache-2.0
|
|
2
|
+
# Copyright 2012-2020 The Meson development team
|
|
3
|
+
|
|
4
|
+
from __future__ import annotations
|
|
5
|
+
|
|
6
|
+
import os.path
|
|
7
|
+
import typing as T
|
|
8
|
+
|
|
9
|
+
from .. import coredata
|
|
10
|
+
from .. import mlog
|
|
11
|
+
from ..mesonlib import MesonException, version_compare, OptionKey
|
|
12
|
+
from .c_function_attributes import C_FUNC_ATTRIBUTES
|
|
13
|
+
from .mixins.clike import CLikeCompiler
|
|
14
|
+
from .mixins.ccrx import CcrxCompiler
|
|
15
|
+
from .mixins.xc16 import Xc16Compiler
|
|
16
|
+
from .mixins.compcert import CompCertCompiler
|
|
17
|
+
from .mixins.ti import TICompiler
|
|
18
|
+
from .mixins.arm import ArmCompiler, ArmclangCompiler
|
|
19
|
+
from .mixins.visualstudio import MSVCCompiler, ClangClCompiler
|
|
20
|
+
from .mixins.gnu import GnuCompiler
|
|
21
|
+
from .mixins.gnu import gnu_common_warning_args, gnu_c_warning_args
|
|
22
|
+
from .mixins.intel import IntelGnuLikeCompiler, IntelVisualStudioLikeCompiler
|
|
23
|
+
from .mixins.clang import ClangCompiler
|
|
24
|
+
from .mixins.elbrus import ElbrusCompiler
|
|
25
|
+
from .mixins.pgi import PGICompiler
|
|
26
|
+
from .mixins.emscripten import EmscriptenMixin
|
|
27
|
+
from .mixins.metrowerks import MetrowerksCompiler
|
|
28
|
+
from .mixins.metrowerks import mwccarm_instruction_set_args, mwcceppc_instruction_set_args
|
|
29
|
+
from .compilers import (
|
|
30
|
+
gnu_winlibs,
|
|
31
|
+
msvc_winlibs,
|
|
32
|
+
Compiler,
|
|
33
|
+
)
|
|
34
|
+
|
|
35
|
+
if T.TYPE_CHECKING:
|
|
36
|
+
from ..coredata import MutableKeyedOptionDictType, KeyedOptionDictType
|
|
37
|
+
from ..dependencies import Dependency
|
|
38
|
+
from ..envconfig import MachineInfo
|
|
39
|
+
from ..environment import Environment
|
|
40
|
+
from ..linkers.linkers import DynamicLinker
|
|
41
|
+
from ..mesonlib import MachineChoice
|
|
42
|
+
from .compilers import CompileCheckMode
|
|
43
|
+
|
|
44
|
+
CompilerMixinBase = Compiler
|
|
45
|
+
else:
|
|
46
|
+
CompilerMixinBase = object
|
|
47
|
+
|
|
48
|
+
_ALL_STDS = ['c89', 'c9x', 'c90', 'c99', 'c1x', 'c11', 'c17', 'c18', 'c2x', 'c23']
|
|
49
|
+
_ALL_STDS += [f'gnu{std[1:]}' for std in _ALL_STDS]
|
|
50
|
+
_ALL_STDS += ['iso9899:1990', 'iso9899:199409', 'iso9899:1999', 'iso9899:2011', 'iso9899:2017', 'iso9899:2018']
|
|
51
|
+
|
|
52
|
+
|
|
53
|
+
class CCompiler(CLikeCompiler, Compiler):
|
|
54
|
+
def attribute_check_func(self, name: str) -> str:
|
|
55
|
+
try:
|
|
56
|
+
return C_FUNC_ATTRIBUTES[name]
|
|
57
|
+
except KeyError:
|
|
58
|
+
raise MesonException(f'Unknown function attribute "{name}"')
|
|
59
|
+
|
|
60
|
+
language = 'c'
|
|
61
|
+
|
|
62
|
+
def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice, is_cross: bool,
|
|
63
|
+
info: 'MachineInfo',
|
|
64
|
+
linker: T.Optional['DynamicLinker'] = None,
|
|
65
|
+
full_version: T.Optional[str] = None):
|
|
66
|
+
# If a child ObjC or CPP class has already set it, don't set it ourselves
|
|
67
|
+
Compiler.__init__(self, ccache, exelist, version, for_machine, info,
|
|
68
|
+
is_cross=is_cross, full_version=full_version, linker=linker)
|
|
69
|
+
CLikeCompiler.__init__(self)
|
|
70
|
+
|
|
71
|
+
def get_no_stdinc_args(self) -> T.List[str]:
|
|
72
|
+
return ['-nostdinc']
|
|
73
|
+
|
|
74
|
+
def sanity_check(self, work_dir: str, environment: 'Environment') -> None:
|
|
75
|
+
code = 'int main(void) { int class=0; return class; }\n'
|
|
76
|
+
return self._sanity_check_impl(work_dir, environment, 'sanitycheckc.c', code)
|
|
77
|
+
|
|
78
|
+
def has_header_symbol(self, hname: str, symbol: str, prefix: str,
|
|
79
|
+
env: 'Environment', *,
|
|
80
|
+
extra_args: T.Union[None, T.List[str], T.Callable[['CompileCheckMode'], T.List[str]]] = None,
|
|
81
|
+
dependencies: T.Optional[T.List['Dependency']] = None) -> T.Tuple[bool, bool]:
|
|
82
|
+
fargs = {'prefix': prefix, 'header': hname, 'symbol': symbol}
|
|
83
|
+
t = '''{prefix}
|
|
84
|
+
#include <{header}>
|
|
85
|
+
int main(void) {{
|
|
86
|
+
/* If it's not defined as a macro, try to use as a symbol */
|
|
87
|
+
#ifndef {symbol}
|
|
88
|
+
{symbol};
|
|
89
|
+
#endif
|
|
90
|
+
return 0;
|
|
91
|
+
}}'''
|
|
92
|
+
return self.compiles(t.format(**fargs), env, extra_args=extra_args,
|
|
93
|
+
dependencies=dependencies)
|
|
94
|
+
|
|
95
|
+
def get_options(self) -> 'MutableKeyedOptionDictType':
|
|
96
|
+
opts = super().get_options()
|
|
97
|
+
key = OptionKey('std', machine=self.for_machine, lang=self.language)
|
|
98
|
+
opts.update({
|
|
99
|
+
key: coredata.UserStdOption('C', _ALL_STDS),
|
|
100
|
+
})
|
|
101
|
+
return opts
|
|
102
|
+
|
|
103
|
+
|
|
104
|
+
class _ClangCStds(CompilerMixinBase):
|
|
105
|
+
|
|
106
|
+
"""Mixin class for clang based compilers for setting C standards.
|
|
107
|
+
|
|
108
|
+
This is used by both ClangCCompiler and ClangClCompiler, as they share
|
|
109
|
+
the same versions
|
|
110
|
+
"""
|
|
111
|
+
|
|
112
|
+
_C17_VERSION = '>=6.0.0'
|
|
113
|
+
_C18_VERSION = '>=8.0.0'
|
|
114
|
+
_C2X_VERSION = '>=9.0.0'
|
|
115
|
+
_C23_VERSION = '>=18.0.0'
|
|
116
|
+
|
|
117
|
+
def get_options(self) -> 'MutableKeyedOptionDictType':
|
|
118
|
+
opts = super().get_options()
|
|
119
|
+
stds = ['c89', 'c99', 'c11']
|
|
120
|
+
# https://releases.llvm.org/6.0.0/tools/clang/docs/ReleaseNotes.html
|
|
121
|
+
# https://en.wikipedia.org/wiki/Xcode#Latest_versions
|
|
122
|
+
if version_compare(self.version, self._C17_VERSION):
|
|
123
|
+
stds += ['c17']
|
|
124
|
+
if version_compare(self.version, self._C18_VERSION):
|
|
125
|
+
stds += ['c18']
|
|
126
|
+
if version_compare(self.version, self._C2X_VERSION):
|
|
127
|
+
stds += ['c2x']
|
|
128
|
+
if version_compare(self.version, self._C23_VERSION):
|
|
129
|
+
stds += ['c23']
|
|
130
|
+
std_opt = opts[OptionKey('std', machine=self.for_machine, lang=self.language)]
|
|
131
|
+
assert isinstance(std_opt, coredata.UserStdOption), 'for mypy'
|
|
132
|
+
std_opt.set_versions(stds, gnu=True)
|
|
133
|
+
return opts
|
|
134
|
+
|
|
135
|
+
|
|
136
|
+
class ClangCCompiler(_ClangCStds, ClangCompiler, CCompiler):
|
|
137
|
+
|
|
138
|
+
def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice, is_cross: bool,
|
|
139
|
+
info: 'MachineInfo',
|
|
140
|
+
linker: T.Optional['DynamicLinker'] = None,
|
|
141
|
+
defines: T.Optional[T.Dict[str, str]] = None,
|
|
142
|
+
full_version: T.Optional[str] = None):
|
|
143
|
+
CCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross, info, linker=linker, full_version=full_version)
|
|
144
|
+
ClangCompiler.__init__(self, defines)
|
|
145
|
+
default_warn_args = ['-Wall', '-Winvalid-pch']
|
|
146
|
+
self.warn_args = {'0': [],
|
|
147
|
+
'1': default_warn_args,
|
|
148
|
+
'2': default_warn_args + ['-Wextra'],
|
|
149
|
+
'3': default_warn_args + ['-Wextra', '-Wpedantic'],
|
|
150
|
+
'everything': ['-Weverything']}
|
|
151
|
+
|
|
152
|
+
def get_options(self) -> 'MutableKeyedOptionDictType':
|
|
153
|
+
opts = super().get_options()
|
|
154
|
+
if self.info.is_windows() or self.info.is_cygwin():
|
|
155
|
+
self.update_options(
|
|
156
|
+
opts,
|
|
157
|
+
self.create_option(coredata.UserArrayOption,
|
|
158
|
+
OptionKey('winlibs', machine=self.for_machine, lang=self.language),
|
|
159
|
+
'Standard Win libraries to link against',
|
|
160
|
+
gnu_winlibs),
|
|
161
|
+
)
|
|
162
|
+
return opts
|
|
163
|
+
|
|
164
|
+
def get_option_compile_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
|
|
165
|
+
args = []
|
|
166
|
+
std = options[OptionKey('std', machine=self.for_machine, lang=self.language)]
|
|
167
|
+
if std.value != 'none':
|
|
168
|
+
args.append('-std=' + std.value)
|
|
169
|
+
return args
|
|
170
|
+
|
|
171
|
+
def get_option_link_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
|
|
172
|
+
if self.info.is_windows() or self.info.is_cygwin():
|
|
173
|
+
# without a typedict mypy can't understand this.
|
|
174
|
+
libs = options[OptionKey('winlibs', machine=self.for_machine, lang=self.language)].value.copy()
|
|
175
|
+
assert isinstance(libs, list)
|
|
176
|
+
for l in libs:
|
|
177
|
+
assert isinstance(l, str)
|
|
178
|
+
return libs
|
|
179
|
+
return []
|
|
180
|
+
|
|
181
|
+
|
|
182
|
+
class ArmLtdClangCCompiler(ClangCCompiler):
|
|
183
|
+
|
|
184
|
+
id = 'armltdclang'
|
|
185
|
+
|
|
186
|
+
|
|
187
|
+
class AppleClangCCompiler(ClangCCompiler):
|
|
188
|
+
|
|
189
|
+
"""Handle the differences between Apple Clang and Vanilla Clang.
|
|
190
|
+
|
|
191
|
+
Right now this just handles the differences between the versions that new
|
|
192
|
+
C standards were added.
|
|
193
|
+
"""
|
|
194
|
+
|
|
195
|
+
_C17_VERSION = '>=10.0.0'
|
|
196
|
+
_C18_VERSION = '>=11.0.0'
|
|
197
|
+
_C2X_VERSION = '>=11.0.0'
|
|
198
|
+
|
|
199
|
+
|
|
200
|
+
class EmscriptenCCompiler(EmscriptenMixin, ClangCCompiler):
|
|
201
|
+
|
|
202
|
+
id = 'emscripten'
|
|
203
|
+
|
|
204
|
+
def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice, is_cross: bool,
|
|
205
|
+
info: 'MachineInfo',
|
|
206
|
+
linker: T.Optional['DynamicLinker'] = None,
|
|
207
|
+
defines: T.Optional[T.Dict[str, str]] = None,
|
|
208
|
+
full_version: T.Optional[str] = None):
|
|
209
|
+
if not is_cross:
|
|
210
|
+
raise MesonException('Emscripten compiler can only be used for cross compilation.')
|
|
211
|
+
if not version_compare(version, '>=1.39.19'):
|
|
212
|
+
raise MesonException('Meson requires Emscripten >= 1.39.19')
|
|
213
|
+
ClangCCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross,
|
|
214
|
+
info, linker=linker,
|
|
215
|
+
defines=defines, full_version=full_version)
|
|
216
|
+
|
|
217
|
+
|
|
218
|
+
class ArmclangCCompiler(ArmclangCompiler, CCompiler):
|
|
219
|
+
'''
|
|
220
|
+
Keil armclang
|
|
221
|
+
'''
|
|
222
|
+
|
|
223
|
+
def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice, is_cross: bool,
|
|
224
|
+
info: 'MachineInfo',
|
|
225
|
+
linker: T.Optional['DynamicLinker'] = None,
|
|
226
|
+
full_version: T.Optional[str] = None):
|
|
227
|
+
CCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross,
|
|
228
|
+
info, linker=linker, full_version=full_version)
|
|
229
|
+
ArmclangCompiler.__init__(self)
|
|
230
|
+
default_warn_args = ['-Wall', '-Winvalid-pch']
|
|
231
|
+
self.warn_args = {'0': [],
|
|
232
|
+
'1': default_warn_args,
|
|
233
|
+
'2': default_warn_args + ['-Wextra'],
|
|
234
|
+
'3': default_warn_args + ['-Wextra', '-Wpedantic'],
|
|
235
|
+
'everything': ['-Weverything']}
|
|
236
|
+
|
|
237
|
+
def get_options(self) -> 'MutableKeyedOptionDictType':
|
|
238
|
+
opts = CCompiler.get_options(self)
|
|
239
|
+
std_opt = opts[OptionKey('std', machine=self.for_machine, lang=self.language)]
|
|
240
|
+
assert isinstance(std_opt, coredata.UserStdOption), 'for mypy'
|
|
241
|
+
std_opt.set_versions(['c90', 'c99', 'c11'], gnu=True)
|
|
242
|
+
return opts
|
|
243
|
+
|
|
244
|
+
def get_option_compile_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
|
|
245
|
+
args = []
|
|
246
|
+
std = options[OptionKey('std', machine=self.for_machine, lang=self.language)]
|
|
247
|
+
if std.value != 'none':
|
|
248
|
+
args.append('-std=' + std.value)
|
|
249
|
+
return args
|
|
250
|
+
|
|
251
|
+
def get_option_link_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
|
|
252
|
+
return []
|
|
253
|
+
|
|
254
|
+
|
|
255
|
+
class GnuCCompiler(GnuCompiler, CCompiler):
|
|
256
|
+
|
|
257
|
+
_C18_VERSION = '>=8.0.0'
|
|
258
|
+
_C2X_VERSION = '>=9.0.0'
|
|
259
|
+
_C23_VERSION = '>=14.0.0'
|
|
260
|
+
_INVALID_PCH_VERSION = ">=3.4.0"
|
|
261
|
+
|
|
262
|
+
def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice, is_cross: bool,
|
|
263
|
+
info: 'MachineInfo',
|
|
264
|
+
linker: T.Optional['DynamicLinker'] = None,
|
|
265
|
+
defines: T.Optional[T.Dict[str, str]] = None,
|
|
266
|
+
full_version: T.Optional[str] = None):
|
|
267
|
+
CCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross, info, linker=linker, full_version=full_version)
|
|
268
|
+
GnuCompiler.__init__(self, defines)
|
|
269
|
+
default_warn_args = ['-Wall']
|
|
270
|
+
if version_compare(self.version, self._INVALID_PCH_VERSION):
|
|
271
|
+
default_warn_args += ['-Winvalid-pch']
|
|
272
|
+
self.warn_args = {'0': [],
|
|
273
|
+
'1': default_warn_args,
|
|
274
|
+
'2': default_warn_args + ['-Wextra'],
|
|
275
|
+
'3': default_warn_args + ['-Wextra', '-Wpedantic'],
|
|
276
|
+
'everything': (default_warn_args + ['-Wextra', '-Wpedantic'] +
|
|
277
|
+
self.supported_warn_args(gnu_common_warning_args) +
|
|
278
|
+
self.supported_warn_args(gnu_c_warning_args))}
|
|
279
|
+
|
|
280
|
+
def get_options(self) -> 'MutableKeyedOptionDictType':
|
|
281
|
+
opts = CCompiler.get_options(self)
|
|
282
|
+
stds = ['c89', 'c99', 'c11']
|
|
283
|
+
if version_compare(self.version, self._C18_VERSION):
|
|
284
|
+
stds += ['c17', 'c18']
|
|
285
|
+
if version_compare(self.version, self._C2X_VERSION):
|
|
286
|
+
stds += ['c2x']
|
|
287
|
+
if version_compare(self.version, self._C23_VERSION):
|
|
288
|
+
stds += ['c23']
|
|
289
|
+
key = OptionKey('std', machine=self.for_machine, lang=self.language)
|
|
290
|
+
std_opt = opts[key]
|
|
291
|
+
assert isinstance(std_opt, coredata.UserStdOption), 'for mypy'
|
|
292
|
+
std_opt.set_versions(stds, gnu=True)
|
|
293
|
+
if self.info.is_windows() or self.info.is_cygwin():
|
|
294
|
+
self.update_options(
|
|
295
|
+
opts,
|
|
296
|
+
self.create_option(coredata.UserArrayOption,
|
|
297
|
+
key.evolve('winlibs'),
|
|
298
|
+
'Standard Win libraries to link against',
|
|
299
|
+
gnu_winlibs),
|
|
300
|
+
)
|
|
301
|
+
return opts
|
|
302
|
+
|
|
303
|
+
def get_option_compile_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
|
|
304
|
+
args = []
|
|
305
|
+
std = options[OptionKey('std', lang=self.language, machine=self.for_machine)]
|
|
306
|
+
if std.value != 'none':
|
|
307
|
+
args.append('-std=' + std.value)
|
|
308
|
+
return args
|
|
309
|
+
|
|
310
|
+
def get_option_link_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
|
|
311
|
+
if self.info.is_windows() or self.info.is_cygwin():
|
|
312
|
+
# without a typeddict mypy can't figure this out
|
|
313
|
+
libs: T.List[str] = options[OptionKey('winlibs', lang=self.language, machine=self.for_machine)].value.copy()
|
|
314
|
+
assert isinstance(libs, list)
|
|
315
|
+
for l in libs:
|
|
316
|
+
assert isinstance(l, str)
|
|
317
|
+
return libs
|
|
318
|
+
return []
|
|
319
|
+
|
|
320
|
+
def get_pch_use_args(self, pch_dir: str, header: str) -> T.List[str]:
|
|
321
|
+
return ['-fpch-preprocess', '-include', os.path.basename(header)]
|
|
322
|
+
|
|
323
|
+
|
|
324
|
+
class PGICCompiler(PGICompiler, CCompiler):
|
|
325
|
+
def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice, is_cross: bool,
|
|
326
|
+
info: 'MachineInfo',
|
|
327
|
+
linker: T.Optional['DynamicLinker'] = None,
|
|
328
|
+
full_version: T.Optional[str] = None):
|
|
329
|
+
CCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross,
|
|
330
|
+
info, linker=linker, full_version=full_version)
|
|
331
|
+
PGICompiler.__init__(self)
|
|
332
|
+
|
|
333
|
+
|
|
334
|
+
class NvidiaHPC_CCompiler(PGICompiler, CCompiler):
|
|
335
|
+
|
|
336
|
+
id = 'nvidia_hpc'
|
|
337
|
+
|
|
338
|
+
def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice, is_cross: bool,
|
|
339
|
+
info: 'MachineInfo',
|
|
340
|
+
linker: T.Optional['DynamicLinker'] = None,
|
|
341
|
+
full_version: T.Optional[str] = None):
|
|
342
|
+
CCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross,
|
|
343
|
+
info, linker=linker, full_version=full_version)
|
|
344
|
+
PGICompiler.__init__(self)
|
|
345
|
+
|
|
346
|
+
|
|
347
|
+
class ElbrusCCompiler(ElbrusCompiler, CCompiler):
|
|
348
|
+
def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice, is_cross: bool,
|
|
349
|
+
info: 'MachineInfo',
|
|
350
|
+
linker: T.Optional['DynamicLinker'] = None,
|
|
351
|
+
defines: T.Optional[T.Dict[str, str]] = None,
|
|
352
|
+
full_version: T.Optional[str] = None):
|
|
353
|
+
CCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross,
|
|
354
|
+
info, linker=linker, full_version=full_version)
|
|
355
|
+
ElbrusCompiler.__init__(self)
|
|
356
|
+
|
|
357
|
+
def get_options(self) -> 'MutableKeyedOptionDictType':
|
|
358
|
+
opts = CCompiler.get_options(self)
|
|
359
|
+
stds = ['c89', 'c9x', 'c99', 'gnu89', 'gnu9x', 'gnu99']
|
|
360
|
+
stds += ['iso9899:1990', 'iso9899:199409', 'iso9899:1999']
|
|
361
|
+
if version_compare(self.version, '>=1.20.00'):
|
|
362
|
+
stds += ['c11', 'gnu11']
|
|
363
|
+
if version_compare(self.version, '>=1.21.00') and version_compare(self.version, '<1.22.00'):
|
|
364
|
+
stds += ['c90', 'c1x', 'gnu90', 'gnu1x', 'iso9899:2011']
|
|
365
|
+
if version_compare(self.version, '>=1.23.00'):
|
|
366
|
+
stds += ['c90', 'c1x', 'gnu90', 'gnu1x', 'iso9899:2011']
|
|
367
|
+
if version_compare(self.version, '>=1.26.00'):
|
|
368
|
+
stds += ['c17', 'c18', 'iso9899:2017', 'iso9899:2018', 'gnu17', 'gnu18']
|
|
369
|
+
std_opt = opts[OptionKey('std', machine=self.for_machine, lang=self.language)]
|
|
370
|
+
assert isinstance(std_opt, coredata.UserStdOption), 'for mypy'
|
|
371
|
+
std_opt.set_versions(stds)
|
|
372
|
+
return opts
|
|
373
|
+
|
|
374
|
+
# Elbrus C compiler does not have lchmod, but there is only linker warning, not compiler error.
|
|
375
|
+
# So we should explicitly fail at this case.
|
|
376
|
+
def has_function(self, funcname: str, prefix: str, env: 'Environment', *,
|
|
377
|
+
extra_args: T.Optional[T.List[str]] = None,
|
|
378
|
+
dependencies: T.Optional[T.List['Dependency']] = None) -> T.Tuple[bool, bool]:
|
|
379
|
+
if funcname == 'lchmod':
|
|
380
|
+
return False, False
|
|
381
|
+
else:
|
|
382
|
+
return super().has_function(funcname, prefix, env,
|
|
383
|
+
extra_args=extra_args,
|
|
384
|
+
dependencies=dependencies)
|
|
385
|
+
|
|
386
|
+
|
|
387
|
+
class IntelCCompiler(IntelGnuLikeCompiler, CCompiler):
|
|
388
|
+
def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice, is_cross: bool,
|
|
389
|
+
info: 'MachineInfo',
|
|
390
|
+
linker: T.Optional['DynamicLinker'] = None,
|
|
391
|
+
full_version: T.Optional[str] = None):
|
|
392
|
+
CCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross,
|
|
393
|
+
info, linker=linker, full_version=full_version)
|
|
394
|
+
IntelGnuLikeCompiler.__init__(self)
|
|
395
|
+
self.lang_header = 'c-header'
|
|
396
|
+
default_warn_args = ['-Wall', '-w3']
|
|
397
|
+
self.warn_args = {'0': [],
|
|
398
|
+
'1': default_warn_args + ['-diag-disable:remark'],
|
|
399
|
+
'2': default_warn_args + ['-Wextra', '-diag-disable:remark'],
|
|
400
|
+
'3': default_warn_args + ['-Wextra', '-diag-disable:remark'],
|
|
401
|
+
'everything': default_warn_args + ['-Wextra']}
|
|
402
|
+
|
|
403
|
+
def get_options(self) -> 'MutableKeyedOptionDictType':
|
|
404
|
+
opts = CCompiler.get_options(self)
|
|
405
|
+
stds = ['c89', 'c99']
|
|
406
|
+
if version_compare(self.version, '>=16.0.0'):
|
|
407
|
+
stds += ['c11']
|
|
408
|
+
std_opt = opts[OptionKey('std', machine=self.for_machine, lang=self.language)]
|
|
409
|
+
assert isinstance(std_opt, coredata.UserStdOption), 'for mypy'
|
|
410
|
+
std_opt.set_versions(stds, gnu=True)
|
|
411
|
+
return opts
|
|
412
|
+
|
|
413
|
+
def get_option_compile_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
|
|
414
|
+
args = []
|
|
415
|
+
std = options[OptionKey('std', machine=self.for_machine, lang=self.language)]
|
|
416
|
+
if std.value != 'none':
|
|
417
|
+
args.append('-std=' + std.value)
|
|
418
|
+
return args
|
|
419
|
+
|
|
420
|
+
|
|
421
|
+
class IntelLLVMCCompiler(ClangCCompiler):
|
|
422
|
+
|
|
423
|
+
id = 'intel-llvm'
|
|
424
|
+
|
|
425
|
+
|
|
426
|
+
class VisualStudioLikeCCompilerMixin(CompilerMixinBase):
|
|
427
|
+
|
|
428
|
+
"""Shared methods that apply to MSVC-like C compilers."""
|
|
429
|
+
|
|
430
|
+
def get_options(self) -> MutableKeyedOptionDictType:
|
|
431
|
+
return self.update_options(
|
|
432
|
+
super().get_options(),
|
|
433
|
+
self.create_option(
|
|
434
|
+
coredata.UserArrayOption,
|
|
435
|
+
OptionKey('winlibs', machine=self.for_machine, lang=self.language),
|
|
436
|
+
'Windows libs to link against.',
|
|
437
|
+
msvc_winlibs,
|
|
438
|
+
),
|
|
439
|
+
)
|
|
440
|
+
|
|
441
|
+
def get_option_link_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
|
|
442
|
+
# need a TypeDict to make this work
|
|
443
|
+
key = OptionKey('winlibs', machine=self.for_machine, lang=self.language)
|
|
444
|
+
libs = options[key].value.copy()
|
|
445
|
+
assert isinstance(libs, list)
|
|
446
|
+
for l in libs:
|
|
447
|
+
assert isinstance(l, str)
|
|
448
|
+
return libs
|
|
449
|
+
|
|
450
|
+
|
|
451
|
+
class VisualStudioCCompiler(MSVCCompiler, VisualStudioLikeCCompilerMixin, CCompiler):
|
|
452
|
+
|
|
453
|
+
_C11_VERSION = '>=19.28'
|
|
454
|
+
_C17_VERSION = '>=19.28'
|
|
455
|
+
|
|
456
|
+
def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice,
|
|
457
|
+
is_cross: bool, info: 'MachineInfo', target: str,
|
|
458
|
+
linker: T.Optional['DynamicLinker'] = None,
|
|
459
|
+
full_version: T.Optional[str] = None):
|
|
460
|
+
CCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross,
|
|
461
|
+
info, linker=linker,
|
|
462
|
+
full_version=full_version)
|
|
463
|
+
MSVCCompiler.__init__(self, target)
|
|
464
|
+
|
|
465
|
+
def get_options(self) -> 'MutableKeyedOptionDictType':
|
|
466
|
+
opts = super().get_options()
|
|
467
|
+
stds = ['c89', 'c99']
|
|
468
|
+
if version_compare(self.version, self._C11_VERSION):
|
|
469
|
+
stds += ['c11']
|
|
470
|
+
if version_compare(self.version, self._C17_VERSION):
|
|
471
|
+
stds += ['c17', 'c18']
|
|
472
|
+
std_opt = opts[OptionKey('std', machine=self.for_machine, lang=self.language)]
|
|
473
|
+
assert isinstance(std_opt, coredata.UserStdOption), 'for mypy'
|
|
474
|
+
std_opt.set_versions(stds, gnu=True, gnu_deprecated=True)
|
|
475
|
+
return opts
|
|
476
|
+
|
|
477
|
+
def get_option_compile_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
|
|
478
|
+
args = []
|
|
479
|
+
std = options[OptionKey('std', machine=self.for_machine, lang=self.language)]
|
|
480
|
+
# As of MVSC 16.8, /std:c11 and /std:c17 are the only valid C standard options.
|
|
481
|
+
if std.value in {'c11'}:
|
|
482
|
+
args.append('/std:c11')
|
|
483
|
+
elif std.value in {'c17', 'c18'}:
|
|
484
|
+
args.append('/std:c17')
|
|
485
|
+
return args
|
|
486
|
+
|
|
487
|
+
|
|
488
|
+
class ClangClCCompiler(_ClangCStds, ClangClCompiler, VisualStudioLikeCCompilerMixin, CCompiler):
|
|
489
|
+
def __init__(self, exelist: T.List[str], version: str, for_machine: MachineChoice,
|
|
490
|
+
is_cross: bool, info: 'MachineInfo', target: str,
|
|
491
|
+
linker: T.Optional['DynamicLinker'] = None,
|
|
492
|
+
full_version: T.Optional[str] = None):
|
|
493
|
+
CCompiler.__init__(self, [], exelist, version, for_machine, is_cross,
|
|
494
|
+
info, linker=linker,
|
|
495
|
+
full_version=full_version)
|
|
496
|
+
ClangClCompiler.__init__(self, target)
|
|
497
|
+
|
|
498
|
+
def get_option_compile_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
|
|
499
|
+
key = OptionKey('std', machine=self.for_machine, lang=self.language)
|
|
500
|
+
std = options[key].value
|
|
501
|
+
if std != "none":
|
|
502
|
+
return [f'/clang:-std={std}']
|
|
503
|
+
return []
|
|
504
|
+
|
|
505
|
+
|
|
506
|
+
class IntelClCCompiler(IntelVisualStudioLikeCompiler, VisualStudioLikeCCompilerMixin, CCompiler):
|
|
507
|
+
|
|
508
|
+
"""Intel "ICL" compiler abstraction."""
|
|
509
|
+
|
|
510
|
+
def __init__(self, exelist: T.List[str], version: str, for_machine: MachineChoice,
|
|
511
|
+
is_cross: bool, info: 'MachineInfo', target: str,
|
|
512
|
+
linker: T.Optional['DynamicLinker'] = None,
|
|
513
|
+
full_version: T.Optional[str] = None):
|
|
514
|
+
CCompiler.__init__(self, [], exelist, version, for_machine, is_cross,
|
|
515
|
+
info, linker=linker,
|
|
516
|
+
full_version=full_version)
|
|
517
|
+
IntelVisualStudioLikeCompiler.__init__(self, target)
|
|
518
|
+
|
|
519
|
+
def get_options(self) -> 'MutableKeyedOptionDictType':
|
|
520
|
+
opts = super().get_options()
|
|
521
|
+
std_opt = opts[OptionKey('std', machine=self.for_machine, lang=self.language)]
|
|
522
|
+
assert isinstance(std_opt, coredata.UserStdOption), 'for mypy'
|
|
523
|
+
std_opt.set_versions(['c89', 'c99', 'c11'])
|
|
524
|
+
return opts
|
|
525
|
+
|
|
526
|
+
def get_option_compile_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
|
|
527
|
+
args = []
|
|
528
|
+
key = OptionKey('std', machine=self.for_machine, lang=self.language)
|
|
529
|
+
std = options[key]
|
|
530
|
+
if std.value == 'c89':
|
|
531
|
+
mlog.log("ICL doesn't explicitly implement c89, setting the standard to 'none', which is close.", once=True)
|
|
532
|
+
elif std.value != 'none':
|
|
533
|
+
args.append('/Qstd:' + std.value)
|
|
534
|
+
return args
|
|
535
|
+
|
|
536
|
+
|
|
537
|
+
class IntelLLVMClCCompiler(IntelClCCompiler):
|
|
538
|
+
|
|
539
|
+
id = 'intel-llvm-cl'
|
|
540
|
+
|
|
541
|
+
|
|
542
|
+
class ArmCCompiler(ArmCompiler, CCompiler):
|
|
543
|
+
def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice,
|
|
544
|
+
is_cross: bool, info: 'MachineInfo',
|
|
545
|
+
linker: T.Optional['DynamicLinker'] = None,
|
|
546
|
+
full_version: T.Optional[str] = None):
|
|
547
|
+
CCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross,
|
|
548
|
+
info, linker=linker,
|
|
549
|
+
full_version=full_version)
|
|
550
|
+
ArmCompiler.__init__(self)
|
|
551
|
+
|
|
552
|
+
def get_options(self) -> 'MutableKeyedOptionDictType':
|
|
553
|
+
opts = CCompiler.get_options(self)
|
|
554
|
+
std_opt = opts[OptionKey('std', machine=self.for_machine, lang=self.language)]
|
|
555
|
+
assert isinstance(std_opt, coredata.UserStdOption), 'for mypy'
|
|
556
|
+
std_opt.set_versions(['c89', 'c99', 'c11'])
|
|
557
|
+
return opts
|
|
558
|
+
|
|
559
|
+
def get_option_compile_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
|
|
560
|
+
args = []
|
|
561
|
+
key = OptionKey('std', machine=self.for_machine, lang=self.language)
|
|
562
|
+
std = options[key]
|
|
563
|
+
if std.value != 'none':
|
|
564
|
+
args.append('--' + std.value)
|
|
565
|
+
return args
|
|
566
|
+
|
|
567
|
+
|
|
568
|
+
class CcrxCCompiler(CcrxCompiler, CCompiler):
|
|
569
|
+
def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice,
|
|
570
|
+
is_cross: bool, info: 'MachineInfo',
|
|
571
|
+
linker: T.Optional['DynamicLinker'] = None,
|
|
572
|
+
full_version: T.Optional[str] = None):
|
|
573
|
+
CCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross,
|
|
574
|
+
info, linker=linker, full_version=full_version)
|
|
575
|
+
CcrxCompiler.__init__(self)
|
|
576
|
+
|
|
577
|
+
# Override CCompiler.get_always_args
|
|
578
|
+
def get_always_args(self) -> T.List[str]:
|
|
579
|
+
return ['-nologo']
|
|
580
|
+
|
|
581
|
+
def get_options(self) -> 'MutableKeyedOptionDictType':
|
|
582
|
+
opts = CCompiler.get_options(self)
|
|
583
|
+
std_opt = opts[OptionKey('std', machine=self.for_machine, lang=self.language)]
|
|
584
|
+
assert isinstance(std_opt, coredata.UserStdOption), 'for mypy'
|
|
585
|
+
std_opt.set_versions(['c89', 'c99'])
|
|
586
|
+
return opts
|
|
587
|
+
|
|
588
|
+
def get_no_stdinc_args(self) -> T.List[str]:
|
|
589
|
+
return []
|
|
590
|
+
|
|
591
|
+
def get_option_compile_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
|
|
592
|
+
args = []
|
|
593
|
+
key = OptionKey('std', machine=self.for_machine, lang=self.language)
|
|
594
|
+
std = options[key]
|
|
595
|
+
if std.value == 'c89':
|
|
596
|
+
args.append('-lang=c')
|
|
597
|
+
elif std.value == 'c99':
|
|
598
|
+
args.append('-lang=c99')
|
|
599
|
+
return args
|
|
600
|
+
|
|
601
|
+
def get_compile_only_args(self) -> T.List[str]:
|
|
602
|
+
return []
|
|
603
|
+
|
|
604
|
+
def get_no_optimization_args(self) -> T.List[str]:
|
|
605
|
+
return ['-optimize=0']
|
|
606
|
+
|
|
607
|
+
def get_output_args(self, target: str) -> T.List[str]:
|
|
608
|
+
return [f'-output=obj={target}']
|
|
609
|
+
|
|
610
|
+
def get_werror_args(self) -> T.List[str]:
|
|
611
|
+
return ['-change_message=error']
|
|
612
|
+
|
|
613
|
+
def get_include_args(self, path: str, is_system: bool) -> T.List[str]:
|
|
614
|
+
if path == '':
|
|
615
|
+
path = '.'
|
|
616
|
+
return ['-include=' + path]
|
|
617
|
+
|
|
618
|
+
|
|
619
|
+
class Xc16CCompiler(Xc16Compiler, CCompiler):
|
|
620
|
+
def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice,
|
|
621
|
+
is_cross: bool, info: 'MachineInfo',
|
|
622
|
+
linker: T.Optional['DynamicLinker'] = None,
|
|
623
|
+
full_version: T.Optional[str] = None):
|
|
624
|
+
CCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross,
|
|
625
|
+
info, linker=linker, full_version=full_version)
|
|
626
|
+
Xc16Compiler.__init__(self)
|
|
627
|
+
|
|
628
|
+
def get_options(self) -> 'MutableKeyedOptionDictType':
|
|
629
|
+
opts = CCompiler.get_options(self)
|
|
630
|
+
std_opt = opts[OptionKey('std', machine=self.for_machine, lang=self.language)]
|
|
631
|
+
assert isinstance(std_opt, coredata.UserStdOption), 'for mypy'
|
|
632
|
+
std_opt.set_versions(['c89', 'c99'], gnu=True)
|
|
633
|
+
return opts
|
|
634
|
+
|
|
635
|
+
def get_no_stdinc_args(self) -> T.List[str]:
|
|
636
|
+
return []
|
|
637
|
+
|
|
638
|
+
def get_option_compile_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
|
|
639
|
+
args = []
|
|
640
|
+
key = OptionKey('std', machine=self.for_machine, lang=self.language)
|
|
641
|
+
std = options[key]
|
|
642
|
+
if std.value != 'none':
|
|
643
|
+
args.append('-ansi')
|
|
644
|
+
args.append('-std=' + std.value)
|
|
645
|
+
return args
|
|
646
|
+
|
|
647
|
+
def get_compile_only_args(self) -> T.List[str]:
|
|
648
|
+
return []
|
|
649
|
+
|
|
650
|
+
def get_no_optimization_args(self) -> T.List[str]:
|
|
651
|
+
return ['-O0']
|
|
652
|
+
|
|
653
|
+
def get_output_args(self, target: str) -> T.List[str]:
|
|
654
|
+
return [f'-o{target}']
|
|
655
|
+
|
|
656
|
+
def get_werror_args(self) -> T.List[str]:
|
|
657
|
+
return ['-change_message=error']
|
|
658
|
+
|
|
659
|
+
def get_include_args(self, path: str, is_system: bool) -> T.List[str]:
|
|
660
|
+
if path == '':
|
|
661
|
+
path = '.'
|
|
662
|
+
return ['-I' + path]
|
|
663
|
+
|
|
664
|
+
class CompCertCCompiler(CompCertCompiler, CCompiler):
|
|
665
|
+
def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice,
|
|
666
|
+
is_cross: bool, info: 'MachineInfo',
|
|
667
|
+
linker: T.Optional['DynamicLinker'] = None,
|
|
668
|
+
full_version: T.Optional[str] = None):
|
|
669
|
+
CCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross,
|
|
670
|
+
info, linker=linker, full_version=full_version)
|
|
671
|
+
CompCertCompiler.__init__(self)
|
|
672
|
+
|
|
673
|
+
def get_options(self) -> 'MutableKeyedOptionDictType':
|
|
674
|
+
opts = CCompiler.get_options(self)
|
|
675
|
+
std_opt = opts[OptionKey('std', machine=self.for_machine, lang=self.language)]
|
|
676
|
+
assert isinstance(std_opt, coredata.UserStdOption), 'for mypy'
|
|
677
|
+
std_opt.set_versions(['c89', 'c99'])
|
|
678
|
+
return opts
|
|
679
|
+
|
|
680
|
+
def get_option_compile_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
|
|
681
|
+
return []
|
|
682
|
+
|
|
683
|
+
def get_no_optimization_args(self) -> T.List[str]:
|
|
684
|
+
return ['-O0']
|
|
685
|
+
|
|
686
|
+
def get_output_args(self, target: str) -> T.List[str]:
|
|
687
|
+
return [f'-o{target}']
|
|
688
|
+
|
|
689
|
+
def get_werror_args(self) -> T.List[str]:
|
|
690
|
+
return ['-Werror']
|
|
691
|
+
|
|
692
|
+
def get_include_args(self, path: str, is_system: bool) -> T.List[str]:
|
|
693
|
+
if path == '':
|
|
694
|
+
path = '.'
|
|
695
|
+
return ['-I' + path]
|
|
696
|
+
|
|
697
|
+
class TICCompiler(TICompiler, CCompiler):
|
|
698
|
+
def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice,
|
|
699
|
+
is_cross: bool, info: 'MachineInfo',
|
|
700
|
+
linker: T.Optional['DynamicLinker'] = None,
|
|
701
|
+
full_version: T.Optional[str] = None):
|
|
702
|
+
CCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross,
|
|
703
|
+
info, linker=linker, full_version=full_version)
|
|
704
|
+
TICompiler.__init__(self)
|
|
705
|
+
|
|
706
|
+
# Override CCompiler.get_always_args
|
|
707
|
+
def get_always_args(self) -> T.List[str]:
|
|
708
|
+
return []
|
|
709
|
+
|
|
710
|
+
def get_options(self) -> 'MutableKeyedOptionDictType':
|
|
711
|
+
opts = CCompiler.get_options(self)
|
|
712
|
+
std_opt = opts[OptionKey('std', machine=self.for_machine, lang=self.language)]
|
|
713
|
+
assert isinstance(std_opt, coredata.UserStdOption), 'for mypy'
|
|
714
|
+
std_opt.set_versions(['c89', 'c99', 'c11'])
|
|
715
|
+
return opts
|
|
716
|
+
|
|
717
|
+
def get_no_stdinc_args(self) -> T.List[str]:
|
|
718
|
+
return []
|
|
719
|
+
|
|
720
|
+
def get_option_compile_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
|
|
721
|
+
args = []
|
|
722
|
+
key = OptionKey('std', machine=self.for_machine, lang=self.language)
|
|
723
|
+
std = options[key]
|
|
724
|
+
if std.value != 'none':
|
|
725
|
+
args.append('--' + std.value)
|
|
726
|
+
return args
|
|
727
|
+
|
|
728
|
+
class C2000CCompiler(TICCompiler):
|
|
729
|
+
# Required for backwards compat with projects created before ti-cgt support existed
|
|
730
|
+
id = 'c2000'
|
|
731
|
+
|
|
732
|
+
class C6000CCompiler(TICCompiler):
|
|
733
|
+
id = 'c6000'
|
|
734
|
+
|
|
735
|
+
class MetrowerksCCompilerARM(MetrowerksCompiler, CCompiler):
|
|
736
|
+
id = 'mwccarm'
|
|
737
|
+
|
|
738
|
+
def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice,
|
|
739
|
+
is_cross: bool, info: 'MachineInfo',
|
|
740
|
+
linker: T.Optional['DynamicLinker'] = None,
|
|
741
|
+
full_version: T.Optional[str] = None):
|
|
742
|
+
CCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross,
|
|
743
|
+
info, linker=linker, full_version=full_version)
|
|
744
|
+
MetrowerksCompiler.__init__(self)
|
|
745
|
+
|
|
746
|
+
def get_instruction_set_args(self, instruction_set: str) -> T.Optional[T.List[str]]:
|
|
747
|
+
return mwccarm_instruction_set_args.get(instruction_set, None)
|
|
748
|
+
|
|
749
|
+
def get_options(self) -> 'MutableKeyedOptionDictType':
|
|
750
|
+
opts = CCompiler.get_options(self)
|
|
751
|
+
c_stds = ['c99']
|
|
752
|
+
opts[OptionKey('std', machine=self.for_machine, lang=self.language)].choices = ['none'] + c_stds
|
|
753
|
+
return opts
|
|
754
|
+
|
|
755
|
+
def get_option_compile_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
|
|
756
|
+
args = []
|
|
757
|
+
std = options[OptionKey('std', machine=self.for_machine, lang=self.language)]
|
|
758
|
+
if std.value != 'none':
|
|
759
|
+
args.append('-lang')
|
|
760
|
+
args.append(std.value)
|
|
761
|
+
return args
|
|
762
|
+
|
|
763
|
+
class MetrowerksCCompilerEmbeddedPowerPC(MetrowerksCompiler, CCompiler):
|
|
764
|
+
id = 'mwcceppc'
|
|
765
|
+
|
|
766
|
+
def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice,
|
|
767
|
+
is_cross: bool, info: 'MachineInfo',
|
|
768
|
+
linker: T.Optional['DynamicLinker'] = None,
|
|
769
|
+
full_version: T.Optional[str] = None):
|
|
770
|
+
CCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross,
|
|
771
|
+
info, linker=linker, full_version=full_version)
|
|
772
|
+
MetrowerksCompiler.__init__(self)
|
|
773
|
+
|
|
774
|
+
def get_instruction_set_args(self, instruction_set: str) -> T.Optional[T.List[str]]:
|
|
775
|
+
return mwcceppc_instruction_set_args.get(instruction_set, None)
|
|
776
|
+
|
|
777
|
+
def get_options(self) -> 'MutableKeyedOptionDictType':
|
|
778
|
+
opts = CCompiler.get_options(self)
|
|
779
|
+
c_stds = ['c99']
|
|
780
|
+
opts[OptionKey('std', machine=self.for_machine, lang=self.language)].choices = ['none'] + c_stds
|
|
781
|
+
return opts
|
|
782
|
+
|
|
783
|
+
def get_option_compile_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
|
|
784
|
+
args = []
|
|
785
|
+
std = options[OptionKey('std', machine=self.for_machine, lang=self.language)]
|
|
786
|
+
if std.value != 'none':
|
|
787
|
+
args.append('-lang ' + std.value)
|
|
788
|
+
return args
|