frida 16.2.0 → 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.
Files changed (386) hide show
  1. package/BSDmakefile +6 -0
  2. package/Makefile +16 -0
  3. package/README.md +14 -11
  4. package/configure +18 -0
  5. package/configure.bat +22 -0
  6. package/dist/native.js +0 -8
  7. package/lib/application.ts +98 -0
  8. package/lib/authentication.ts +3 -0
  9. package/lib/build.py +50 -0
  10. package/lib/bus.ts +30 -0
  11. package/lib/cancellable.ts +33 -0
  12. package/lib/child.ts +15 -0
  13. package/lib/crash.ts +11 -0
  14. package/lib/device.ts +329 -0
  15. package/lib/device_manager.ts +69 -0
  16. package/lib/endpoint_parameters.ts +56 -0
  17. package/lib/icon.ts +15 -0
  18. package/lib/index.ts +311 -0
  19. package/lib/iostream.ts +78 -0
  20. package/lib/meson.build +53 -0
  21. package/lib/native.ts +9 -0
  22. package/lib/portal_membership.ts +10 -0
  23. package/lib/portal_service.ts +105 -0
  24. package/lib/process.ts +57 -0
  25. package/lib/relay.ts +44 -0
  26. package/lib/script.ts +352 -0
  27. package/lib/session.ts +113 -0
  28. package/lib/signals.ts +45 -0
  29. package/lib/socket_address.ts +35 -0
  30. package/lib/spawn.ts +4 -0
  31. package/lib/system_parameters.ts +78 -0
  32. package/make.bat +23 -0
  33. package/meson.build +160 -0
  34. package/meson.options +11 -0
  35. package/package.json +27 -6
  36. package/releng/deps.py +1133 -0
  37. package/releng/deps.toml +391 -0
  38. package/releng/devkit-assets/frida-core-example-unix.c +188 -0
  39. package/releng/devkit-assets/frida-core-example-windows.c +197 -0
  40. package/releng/devkit-assets/frida-core-example.sln +28 -0
  41. package/releng/devkit-assets/frida-core-example.vcxproj +157 -0
  42. package/releng/devkit-assets/frida-core-example.vcxproj.filters +27 -0
  43. package/releng/devkit-assets/frida-gum-example-unix.c +122 -0
  44. package/releng/devkit-assets/frida-gum-example-windows.c +132 -0
  45. package/releng/devkit-assets/frida-gum-example.sln +28 -0
  46. package/releng/devkit-assets/frida-gum-example.vcxproj +157 -0
  47. package/releng/devkit-assets/frida-gum-example.vcxproj.filters +27 -0
  48. package/releng/devkit-assets/frida-gumjs-example-unix.c +84 -0
  49. package/releng/devkit-assets/frida-gumjs-example-windows.c +91 -0
  50. package/releng/devkit-assets/frida-gumjs-example.sln +28 -0
  51. package/releng/devkit-assets/frida-gumjs-example.vcxproj +157 -0
  52. package/releng/devkit-assets/frida-gumjs-example.vcxproj.filters +27 -0
  53. package/releng/devkit.py +535 -0
  54. package/releng/env.py +420 -0
  55. package/releng/env_android.py +150 -0
  56. package/releng/env_apple.py +176 -0
  57. package/releng/env_generic.py +373 -0
  58. package/releng/frida_version.py +69 -0
  59. package/releng/machine_file.py +44 -0
  60. package/releng/machine_spec.py +290 -0
  61. package/releng/meson/meson.py +27 -0
  62. package/releng/meson/mesonbuild/__init__.py +0 -0
  63. package/releng/meson/mesonbuild/_pathlib.py +63 -0
  64. package/releng/meson/mesonbuild/_typing.py +69 -0
  65. package/releng/meson/mesonbuild/arglist.py +321 -0
  66. package/releng/meson/mesonbuild/ast/__init__.py +23 -0
  67. package/releng/meson/mesonbuild/ast/interpreter.py +441 -0
  68. package/releng/meson/mesonbuild/ast/introspection.py +374 -0
  69. package/releng/meson/mesonbuild/ast/postprocess.py +109 -0
  70. package/releng/meson/mesonbuild/ast/printer.py +620 -0
  71. package/releng/meson/mesonbuild/ast/visitor.py +161 -0
  72. package/releng/meson/mesonbuild/backend/__init__.py +0 -0
  73. package/releng/meson/mesonbuild/backend/backends.py +2047 -0
  74. package/releng/meson/mesonbuild/backend/ninjabackend.py +3808 -0
  75. package/releng/meson/mesonbuild/backend/nonebackend.py +26 -0
  76. package/releng/meson/mesonbuild/backend/vs2010backend.py +2078 -0
  77. package/releng/meson/mesonbuild/backend/vs2012backend.py +35 -0
  78. package/releng/meson/mesonbuild/backend/vs2013backend.py +34 -0
  79. package/releng/meson/mesonbuild/backend/vs2015backend.py +35 -0
  80. package/releng/meson/mesonbuild/backend/vs2017backend.py +59 -0
  81. package/releng/meson/mesonbuild/backend/vs2019backend.py +54 -0
  82. package/releng/meson/mesonbuild/backend/vs2022backend.py +54 -0
  83. package/releng/meson/mesonbuild/backend/xcodebackend.py +1781 -0
  84. package/releng/meson/mesonbuild/build.py +3249 -0
  85. package/releng/meson/mesonbuild/cargo/__init__.py +5 -0
  86. package/releng/meson/mesonbuild/cargo/builder.py +238 -0
  87. package/releng/meson/mesonbuild/cargo/cfg.py +274 -0
  88. package/releng/meson/mesonbuild/cargo/interpreter.py +733 -0
  89. package/releng/meson/mesonbuild/cargo/manifest.py +227 -0
  90. package/releng/meson/mesonbuild/cargo/version.py +95 -0
  91. package/releng/meson/mesonbuild/cmake/__init__.py +28 -0
  92. package/releng/meson/mesonbuild/cmake/common.py +331 -0
  93. package/releng/meson/mesonbuild/cmake/data/__init__.py +0 -0
  94. package/releng/meson/mesonbuild/cmake/data/preload.cmake +82 -0
  95. package/releng/meson/mesonbuild/cmake/executor.py +241 -0
  96. package/releng/meson/mesonbuild/cmake/fileapi.py +324 -0
  97. package/releng/meson/mesonbuild/cmake/generator.py +186 -0
  98. package/releng/meson/mesonbuild/cmake/interpreter.py +1267 -0
  99. package/releng/meson/mesonbuild/cmake/toolchain.py +248 -0
  100. package/releng/meson/mesonbuild/cmake/traceparser.py +814 -0
  101. package/releng/meson/mesonbuild/cmake/tracetargets.py +161 -0
  102. package/releng/meson/mesonbuild/compilers/__init__.py +86 -0
  103. package/releng/meson/mesonbuild/compilers/asm.py +307 -0
  104. package/releng/meson/mesonbuild/compilers/c.py +788 -0
  105. package/releng/meson/mesonbuild/compilers/c_function_attributes.py +143 -0
  106. package/releng/meson/mesonbuild/compilers/compilers.py +1388 -0
  107. package/releng/meson/mesonbuild/compilers/cpp.py +1035 -0
  108. package/releng/meson/mesonbuild/compilers/cs.py +136 -0
  109. package/releng/meson/mesonbuild/compilers/cuda.py +806 -0
  110. package/releng/meson/mesonbuild/compilers/cython.py +91 -0
  111. package/releng/meson/mesonbuild/compilers/d.py +861 -0
  112. package/releng/meson/mesonbuild/compilers/detect.py +1396 -0
  113. package/releng/meson/mesonbuild/compilers/fortran.py +523 -0
  114. package/releng/meson/mesonbuild/compilers/java.py +113 -0
  115. package/releng/meson/mesonbuild/compilers/mixins/__init__.py +0 -0
  116. package/releng/meson/mesonbuild/compilers/mixins/arm.py +167 -0
  117. package/releng/meson/mesonbuild/compilers/mixins/ccrx.py +113 -0
  118. package/releng/meson/mesonbuild/compilers/mixins/clang.py +170 -0
  119. package/releng/meson/mesonbuild/compilers/mixins/clike.py +1330 -0
  120. package/releng/meson/mesonbuild/compilers/mixins/compcert.py +117 -0
  121. package/releng/meson/mesonbuild/compilers/mixins/elbrus.py +93 -0
  122. package/releng/meson/mesonbuild/compilers/mixins/emscripten.py +89 -0
  123. package/releng/meson/mesonbuild/compilers/mixins/gnu.py +629 -0
  124. package/releng/meson/mesonbuild/compilers/mixins/intel.py +167 -0
  125. package/releng/meson/mesonbuild/compilers/mixins/islinker.py +120 -0
  126. package/releng/meson/mesonbuild/compilers/mixins/metrowerks.py +279 -0
  127. package/releng/meson/mesonbuild/compilers/mixins/pgi.py +88 -0
  128. package/releng/meson/mesonbuild/compilers/mixins/ti.py +130 -0
  129. package/releng/meson/mesonbuild/compilers/mixins/visualstudio.py +458 -0
  130. package/releng/meson/mesonbuild/compilers/mixins/xc16.py +111 -0
  131. package/releng/meson/mesonbuild/compilers/objc.py +120 -0
  132. package/releng/meson/mesonbuild/compilers/objcpp.py +102 -0
  133. package/releng/meson/mesonbuild/compilers/rust.py +230 -0
  134. package/releng/meson/mesonbuild/compilers/swift.py +131 -0
  135. package/releng/meson/mesonbuild/compilers/vala.py +121 -0
  136. package/releng/meson/mesonbuild/coredata.py +1532 -0
  137. package/releng/meson/mesonbuild/dependencies/__init__.py +252 -0
  138. package/releng/meson/mesonbuild/dependencies/base.py +663 -0
  139. package/releng/meson/mesonbuild/dependencies/boost.py +1083 -0
  140. package/releng/meson/mesonbuild/dependencies/cmake.py +656 -0
  141. package/releng/meson/mesonbuild/dependencies/coarrays.py +80 -0
  142. package/releng/meson/mesonbuild/dependencies/configtool.py +163 -0
  143. package/releng/meson/mesonbuild/dependencies/cuda.py +295 -0
  144. package/releng/meson/mesonbuild/dependencies/data/CMakeLists.txt +102 -0
  145. package/releng/meson/mesonbuild/dependencies/data/CMakeListsLLVM.txt +204 -0
  146. package/releng/meson/mesonbuild/dependencies/data/CMakePathInfo.txt +31 -0
  147. package/releng/meson/mesonbuild/dependencies/data/__init__.py +0 -0
  148. package/releng/meson/mesonbuild/dependencies/detect.py +225 -0
  149. package/releng/meson/mesonbuild/dependencies/dev.py +707 -0
  150. package/releng/meson/mesonbuild/dependencies/dub.py +424 -0
  151. package/releng/meson/mesonbuild/dependencies/factory.py +146 -0
  152. package/releng/meson/mesonbuild/dependencies/framework.py +111 -0
  153. package/releng/meson/mesonbuild/dependencies/hdf5.py +168 -0
  154. package/releng/meson/mesonbuild/dependencies/misc.py +618 -0
  155. package/releng/meson/mesonbuild/dependencies/mpi.py +231 -0
  156. package/releng/meson/mesonbuild/dependencies/pkgconfig.py +570 -0
  157. package/releng/meson/mesonbuild/dependencies/platform.py +52 -0
  158. package/releng/meson/mesonbuild/dependencies/python.py +431 -0
  159. package/releng/meson/mesonbuild/dependencies/qt.py +484 -0
  160. package/releng/meson/mesonbuild/dependencies/scalapack.py +142 -0
  161. package/releng/meson/mesonbuild/dependencies/ui.py +281 -0
  162. package/releng/meson/mesonbuild/depfile.py +82 -0
  163. package/releng/meson/mesonbuild/envconfig.py +480 -0
  164. package/releng/meson/mesonbuild/environment.py +987 -0
  165. package/releng/meson/mesonbuild/interpreter/__init__.py +47 -0
  166. package/releng/meson/mesonbuild/interpreter/compiler.py +900 -0
  167. package/releng/meson/mesonbuild/interpreter/dependencyfallbacks.py +386 -0
  168. package/releng/meson/mesonbuild/interpreter/interpreter.py +3595 -0
  169. package/releng/meson/mesonbuild/interpreter/interpreterobjects.py +1096 -0
  170. package/releng/meson/mesonbuild/interpreter/kwargs.py +479 -0
  171. package/releng/meson/mesonbuild/interpreter/mesonmain.py +487 -0
  172. package/releng/meson/mesonbuild/interpreter/primitives/__init__.py +29 -0
  173. package/releng/meson/mesonbuild/interpreter/primitives/array.py +108 -0
  174. package/releng/meson/mesonbuild/interpreter/primitives/boolean.py +52 -0
  175. package/releng/meson/mesonbuild/interpreter/primitives/dict.py +88 -0
  176. package/releng/meson/mesonbuild/interpreter/primitives/integer.py +86 -0
  177. package/releng/meson/mesonbuild/interpreter/primitives/range.py +38 -0
  178. package/releng/meson/mesonbuild/interpreter/primitives/string.py +247 -0
  179. package/releng/meson/mesonbuild/interpreter/type_checking.py +853 -0
  180. package/releng/meson/mesonbuild/interpreterbase/__init__.py +126 -0
  181. package/releng/meson/mesonbuild/interpreterbase/_unholder.py +25 -0
  182. package/releng/meson/mesonbuild/interpreterbase/baseobjects.py +174 -0
  183. package/releng/meson/mesonbuild/interpreterbase/decorators.py +806 -0
  184. package/releng/meson/mesonbuild/interpreterbase/disabler.py +35 -0
  185. package/releng/meson/mesonbuild/interpreterbase/exceptions.py +22 -0
  186. package/releng/meson/mesonbuild/interpreterbase/helpers.py +67 -0
  187. package/releng/meson/mesonbuild/interpreterbase/interpreterbase.py +665 -0
  188. package/releng/meson/mesonbuild/interpreterbase/operator.py +32 -0
  189. package/releng/meson/mesonbuild/linkers/__init__.py +20 -0
  190. package/releng/meson/mesonbuild/linkers/base.py +39 -0
  191. package/releng/meson/mesonbuild/linkers/detect.py +229 -0
  192. package/releng/meson/mesonbuild/linkers/linkers.py +1614 -0
  193. package/releng/meson/mesonbuild/mcompile.py +380 -0
  194. package/releng/meson/mesonbuild/mconf.py +368 -0
  195. package/releng/meson/mesonbuild/mdevenv.py +234 -0
  196. package/releng/meson/mesonbuild/mdist.py +376 -0
  197. package/releng/meson/mesonbuild/mesondata.py +38 -0
  198. package/releng/meson/mesonbuild/mesonlib.py +23 -0
  199. package/releng/meson/mesonbuild/mesonmain.py +289 -0
  200. package/releng/meson/mesonbuild/minit.py +204 -0
  201. package/releng/meson/mesonbuild/minstall.py +864 -0
  202. package/releng/meson/mesonbuild/mintro.py +667 -0
  203. package/releng/meson/mesonbuild/mlog.py +542 -0
  204. package/releng/meson/mesonbuild/modules/__init__.py +270 -0
  205. package/releng/meson/mesonbuild/modules/cmake.py +442 -0
  206. package/releng/meson/mesonbuild/modules/cuda.py +377 -0
  207. package/releng/meson/mesonbuild/modules/dlang.py +117 -0
  208. package/releng/meson/mesonbuild/modules/external_project.py +306 -0
  209. package/releng/meson/mesonbuild/modules/fs.py +323 -0
  210. package/releng/meson/mesonbuild/modules/gnome.py +2215 -0
  211. package/releng/meson/mesonbuild/modules/hotdoc.py +487 -0
  212. package/releng/meson/mesonbuild/modules/i18n.py +405 -0
  213. package/releng/meson/mesonbuild/modules/icestorm.py +123 -0
  214. package/releng/meson/mesonbuild/modules/java.py +112 -0
  215. package/releng/meson/mesonbuild/modules/keyval.py +65 -0
  216. package/releng/meson/mesonbuild/modules/modtest.py +33 -0
  217. package/releng/meson/mesonbuild/modules/pkgconfig.py +744 -0
  218. package/releng/meson/mesonbuild/modules/python.py +556 -0
  219. package/releng/meson/mesonbuild/modules/python3.py +85 -0
  220. package/releng/meson/mesonbuild/modules/qt.py +621 -0
  221. package/releng/meson/mesonbuild/modules/qt4.py +23 -0
  222. package/releng/meson/mesonbuild/modules/qt5.py +23 -0
  223. package/releng/meson/mesonbuild/modules/qt6.py +22 -0
  224. package/releng/meson/mesonbuild/modules/rust.py +355 -0
  225. package/releng/meson/mesonbuild/modules/simd.py +114 -0
  226. package/releng/meson/mesonbuild/modules/sourceset.py +291 -0
  227. package/releng/meson/mesonbuild/modules/wayland.py +151 -0
  228. package/releng/meson/mesonbuild/modules/windows.py +207 -0
  229. package/releng/meson/mesonbuild/mparser.py +1114 -0
  230. package/releng/meson/mesonbuild/msetup.py +365 -0
  231. package/releng/meson/mesonbuild/msubprojects.py +764 -0
  232. package/releng/meson/mesonbuild/mtest.py +2201 -0
  233. package/releng/meson/mesonbuild/munstable_coredata.py +107 -0
  234. package/releng/meson/mesonbuild/optinterpreter.py +276 -0
  235. package/releng/meson/mesonbuild/programs.py +367 -0
  236. package/releng/meson/mesonbuild/rewriter.py +1075 -0
  237. package/releng/meson/mesonbuild/scripts/__init__.py +10 -0
  238. package/releng/meson/mesonbuild/scripts/clangformat.py +55 -0
  239. package/releng/meson/mesonbuild/scripts/clangtidy.py +30 -0
  240. package/releng/meson/mesonbuild/scripts/cleantrees.py +35 -0
  241. package/releng/meson/mesonbuild/scripts/cmake_run_ctgt.py +103 -0
  242. package/releng/meson/mesonbuild/scripts/cmd_or_ps.ps1 +17 -0
  243. package/releng/meson/mesonbuild/scripts/copy.py +19 -0
  244. package/releng/meson/mesonbuild/scripts/coverage.py +214 -0
  245. package/releng/meson/mesonbuild/scripts/delwithsuffix.py +27 -0
  246. package/releng/meson/mesonbuild/scripts/depfixer.py +495 -0
  247. package/releng/meson/mesonbuild/scripts/depscan.py +198 -0
  248. package/releng/meson/mesonbuild/scripts/dirchanger.py +20 -0
  249. package/releng/meson/mesonbuild/scripts/env2mfile.py +402 -0
  250. package/releng/meson/mesonbuild/scripts/externalproject.py +106 -0
  251. package/releng/meson/mesonbuild/scripts/gettext.py +86 -0
  252. package/releng/meson/mesonbuild/scripts/gtkdochelper.py +286 -0
  253. package/releng/meson/mesonbuild/scripts/hotdochelper.py +40 -0
  254. package/releng/meson/mesonbuild/scripts/itstool.py +77 -0
  255. package/releng/meson/mesonbuild/scripts/meson_exe.py +115 -0
  256. package/releng/meson/mesonbuild/scripts/msgfmthelper.py +29 -0
  257. package/releng/meson/mesonbuild/scripts/pycompile.py +54 -0
  258. package/releng/meson/mesonbuild/scripts/python_info.py +121 -0
  259. package/releng/meson/mesonbuild/scripts/regen_checker.py +55 -0
  260. package/releng/meson/mesonbuild/scripts/run_tool.py +58 -0
  261. package/releng/meson/mesonbuild/scripts/scanbuild.py +57 -0
  262. package/releng/meson/mesonbuild/scripts/symbolextractor.py +322 -0
  263. package/releng/meson/mesonbuild/scripts/tags.py +44 -0
  264. package/releng/meson/mesonbuild/scripts/test_loaded_modules.py +14 -0
  265. package/releng/meson/mesonbuild/scripts/uninstall.py +41 -0
  266. package/releng/meson/mesonbuild/scripts/vcstagger.py +35 -0
  267. package/releng/meson/mesonbuild/scripts/yasm.py +24 -0
  268. package/releng/meson/mesonbuild/templates/__init__.py +0 -0
  269. package/releng/meson/mesonbuild/templates/cpptemplates.py +143 -0
  270. package/releng/meson/mesonbuild/templates/cstemplates.py +90 -0
  271. package/releng/meson/mesonbuild/templates/ctemplates.py +126 -0
  272. package/releng/meson/mesonbuild/templates/cudatemplates.py +143 -0
  273. package/releng/meson/mesonbuild/templates/dlangtemplates.py +109 -0
  274. package/releng/meson/mesonbuild/templates/fortrantemplates.py +101 -0
  275. package/releng/meson/mesonbuild/templates/javatemplates.py +94 -0
  276. package/releng/meson/mesonbuild/templates/mesontemplates.py +70 -0
  277. package/releng/meson/mesonbuild/templates/objcpptemplates.py +126 -0
  278. package/releng/meson/mesonbuild/templates/objctemplates.py +126 -0
  279. package/releng/meson/mesonbuild/templates/rusttemplates.py +79 -0
  280. package/releng/meson/mesonbuild/templates/samplefactory.py +41 -0
  281. package/releng/meson/mesonbuild/templates/sampleimpl.py +160 -0
  282. package/releng/meson/mesonbuild/templates/valatemplates.py +82 -0
  283. package/releng/meson/mesonbuild/utils/__init__.py +0 -0
  284. package/releng/meson/mesonbuild/utils/core.py +166 -0
  285. package/releng/meson/mesonbuild/utils/platform.py +27 -0
  286. package/releng/meson/mesonbuild/utils/posix.py +32 -0
  287. package/releng/meson/mesonbuild/utils/universal.py +2445 -0
  288. package/releng/meson/mesonbuild/utils/vsenv.py +126 -0
  289. package/releng/meson/mesonbuild/utils/win32.py +29 -0
  290. package/releng/meson/mesonbuild/wrap/__init__.py +59 -0
  291. package/releng/meson/mesonbuild/wrap/wrap.py +846 -0
  292. package/releng/meson/mesonbuild/wrap/wraptool.py +198 -0
  293. package/releng/meson-scripts/BSDmakefile +6 -0
  294. package/releng/meson-scripts/Makefile +16 -0
  295. package/releng/meson-scripts/configure +18 -0
  296. package/releng/meson-scripts/configure.bat +22 -0
  297. package/releng/meson-scripts/make.bat +23 -0
  298. package/releng/meson_configure.py +506 -0
  299. package/releng/meson_make.py +131 -0
  300. package/releng/mkdevkit.py +107 -0
  301. package/releng/mkfatmacho.py +54 -0
  302. package/releng/post-process-oabi.py +97 -0
  303. package/releng/progress.py +14 -0
  304. package/releng/sync-from-upstream.py +185 -0
  305. package/releng/tomlkit/tomlkit/__init__.py +59 -0
  306. package/releng/tomlkit/tomlkit/_compat.py +22 -0
  307. package/releng/tomlkit/tomlkit/_types.py +83 -0
  308. package/releng/tomlkit/tomlkit/_utils.py +158 -0
  309. package/releng/tomlkit/tomlkit/api.py +308 -0
  310. package/releng/tomlkit/tomlkit/container.py +875 -0
  311. package/releng/tomlkit/tomlkit/exceptions.py +227 -0
  312. package/releng/tomlkit/tomlkit/items.py +1967 -0
  313. package/releng/tomlkit/tomlkit/parser.py +1141 -0
  314. package/releng/tomlkit/tomlkit/py.typed +0 -0
  315. package/releng/tomlkit/tomlkit/source.py +180 -0
  316. package/releng/tomlkit/tomlkit/toml_char.py +52 -0
  317. package/releng/tomlkit/tomlkit/toml_document.py +7 -0
  318. package/releng/tomlkit/tomlkit/toml_file.py +58 -0
  319. package/releng/winenv.py +140 -0
  320. package/scripts/adjust-version.py +19 -0
  321. package/scripts/detect-version.py +40 -0
  322. package/scripts/fetch-abi-bits.py +343 -0
  323. package/scripts/install.js +23 -0
  324. package/scripts/package.py +15 -0
  325. package/src/addon.cc +76 -0
  326. package/src/application.cc +148 -0
  327. package/src/application.h +31 -0
  328. package/src/authentication.cc +174 -0
  329. package/src/authentication.h +24 -0
  330. package/src/bus.cc +167 -0
  331. package/src/bus.h +33 -0
  332. package/src/cancellable.cc +117 -0
  333. package/src/cancellable.h +31 -0
  334. package/src/child.cc +150 -0
  335. package/src/child.h +32 -0
  336. package/src/crash.cc +122 -0
  337. package/src/crash.h +30 -0
  338. package/src/device.cc +1302 -0
  339. package/src/device.h +55 -0
  340. package/src/device_manager.cc +362 -0
  341. package/src/device_manager.h +35 -0
  342. package/src/endpoint_parameters.cc +171 -0
  343. package/src/endpoint_parameters.h +28 -0
  344. package/src/glib_context.cc +62 -0
  345. package/src/glib_context.h +29 -0
  346. package/src/glib_object.cc +25 -0
  347. package/src/glib_object.h +37 -0
  348. package/src/iostream.cc +247 -0
  349. package/src/iostream.h +30 -0
  350. package/src/meson.build +26 -0
  351. package/src/operation.h +94 -0
  352. package/src/portal_membership.cc +100 -0
  353. package/src/portal_membership.h +26 -0
  354. package/src/portal_service.cc +401 -0
  355. package/src/portal_service.h +40 -0
  356. package/src/process.cc +135 -0
  357. package/src/process.h +30 -0
  358. package/src/relay.cc +139 -0
  359. package/src/relay.h +31 -0
  360. package/src/runtime.cc +443 -0
  361. package/src/runtime.h +64 -0
  362. package/src/script.cc +301 -0
  363. package/src/script.h +36 -0
  364. package/src/session.cc +860 -0
  365. package/src/session.h +42 -0
  366. package/src/signals.cc +334 -0
  367. package/src/signals.h +47 -0
  368. package/src/spawn.cc +95 -0
  369. package/src/spawn.h +27 -0
  370. package/src/usage_monitor.h +117 -0
  371. package/src/uv_context.cc +118 -0
  372. package/src/uv_context.h +40 -0
  373. package/src/win_delay_load_hook.cc +63 -0
  374. package/subprojects/frida-core.wrap +8 -0
  375. package/subprojects/nan.wrap +9 -0
  376. package/subprojects/packagefiles/nan.patch +13 -0
  377. package/test/data/index.ts +13 -0
  378. package/test/data/unixvictim-linux-x86 +0 -0
  379. package/test/data/unixvictim-linux-x86_64 +0 -0
  380. package/test/data/unixvictim-macos +0 -0
  381. package/test/device.ts +27 -0
  382. package/test/device_manager.ts +16 -0
  383. package/test/labrat.ts +32 -0
  384. package/test/script.ts +176 -0
  385. package/test/session.ts +73 -0
  386. package/tsconfig.json +18 -0
@@ -0,0 +1,1035 @@
1
+ # SPDX-License-Identifier: Apache-2.0
2
+ # Copyright 2012-2017 The Meson development team
3
+
4
+ from __future__ import annotations
5
+
6
+ import copy
7
+ import functools
8
+ import os.path
9
+ import typing as T
10
+
11
+ from .. import coredata
12
+ from .. import mlog
13
+ from ..mesonlib import MesonException, version_compare, OptionKey
14
+
15
+ from .compilers import (
16
+ gnu_winlibs,
17
+ msvc_winlibs,
18
+ Compiler,
19
+ CompileCheckMode,
20
+ )
21
+ from .c_function_attributes import CXX_FUNC_ATTRIBUTES, C_FUNC_ATTRIBUTES
22
+ from .mixins.clike import CLikeCompiler
23
+ from .mixins.ccrx import CcrxCompiler
24
+ from .mixins.ti import TICompiler
25
+ from .mixins.arm import ArmCompiler, ArmclangCompiler
26
+ from .mixins.visualstudio import MSVCCompiler, ClangClCompiler
27
+ from .mixins.gnu import GnuCompiler, gnu_common_warning_args, gnu_cpp_warning_args
28
+ from .mixins.intel import IntelGnuLikeCompiler, IntelVisualStudioLikeCompiler
29
+ from .mixins.clang import ClangCompiler
30
+ from .mixins.elbrus import ElbrusCompiler
31
+ from .mixins.pgi import PGICompiler
32
+ from .mixins.emscripten import EmscriptenMixin
33
+ from .mixins.metrowerks import MetrowerksCompiler
34
+ from .mixins.metrowerks import mwccarm_instruction_set_args, mwcceppc_instruction_set_args
35
+
36
+ if T.TYPE_CHECKING:
37
+ from ..coredata import MutableKeyedOptionDictType, KeyedOptionDictType
38
+ from ..dependencies import Dependency
39
+ from ..envconfig import MachineInfo
40
+ from ..environment import Environment
41
+ from ..linkers.linkers import DynamicLinker
42
+ from ..mesonlib import MachineChoice
43
+ CompilerMixinBase = CLikeCompiler
44
+ else:
45
+ CompilerMixinBase = object
46
+
47
+ _ALL_STDS = ['c++98', 'c++0x', 'c++03', 'c++1y', 'c++1z', 'c++11', 'c++14', 'c++17', 'c++2a', 'c++20', 'c++23', 'c++26']
48
+ _ALL_STDS += [f'gnu{std[1:]}' for std in _ALL_STDS]
49
+ _ALL_STDS += ['vc++11', 'vc++14', 'vc++17', 'vc++20', 'vc++latest', 'c++latest']
50
+
51
+
52
+ def non_msvc_eh_options(eh: str, args: T.List[str]) -> None:
53
+ if eh == 'none':
54
+ args.append('-fno-exceptions')
55
+ elif eh in {'s', 'c'}:
56
+ mlog.warning(f'non-MSVC compilers do not support {eh} exception handling. '
57
+ 'You may want to set eh to \'default\'.', fatal=False)
58
+
59
+ class CPPCompiler(CLikeCompiler, Compiler):
60
+ def attribute_check_func(self, name: str) -> str:
61
+ try:
62
+ return CXX_FUNC_ATTRIBUTES.get(name, C_FUNC_ATTRIBUTES[name])
63
+ except KeyError:
64
+ raise MesonException(f'Unknown function attribute "{name}"')
65
+
66
+ language = 'cpp'
67
+
68
+ def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice, is_cross: bool,
69
+ info: 'MachineInfo',
70
+ linker: T.Optional['DynamicLinker'] = None,
71
+ full_version: T.Optional[str] = None):
72
+ # If a child ObjCPP class has already set it, don't set it ourselves
73
+ Compiler.__init__(self, ccache, exelist, version, for_machine, info,
74
+ is_cross=is_cross, linker=linker,
75
+ full_version=full_version)
76
+ CLikeCompiler.__init__(self)
77
+
78
+ @classmethod
79
+ def get_display_language(cls) -> str:
80
+ return 'C++'
81
+
82
+ def get_no_stdinc_args(self) -> T.List[str]:
83
+ return ['-nostdinc++']
84
+
85
+ def get_no_stdlib_link_args(self) -> T.List[str]:
86
+ return ['-nostdlib++']
87
+
88
+ def sanity_check(self, work_dir: str, environment: 'Environment') -> None:
89
+ code = 'class breakCCompiler;int main(void) { return 0; }\n'
90
+ return self._sanity_check_impl(work_dir, environment, 'sanitycheckcpp.cc', code)
91
+
92
+ def get_compiler_check_args(self, mode: CompileCheckMode) -> T.List[str]:
93
+ # -fpermissive allows non-conforming code to compile which is necessary
94
+ # for many C++ checks. Particularly, the has_header_symbol check is
95
+ # too strict without this and always fails.
96
+ return super().get_compiler_check_args(mode) + ['-fpermissive']
97
+
98
+ def has_header_symbol(self, hname: str, symbol: str, prefix: str,
99
+ env: 'Environment', *,
100
+ extra_args: T.Union[None, T.List[str], T.Callable[[CompileCheckMode], T.List[str]]] = None,
101
+ dependencies: T.Optional[T.List['Dependency']] = None) -> T.Tuple[bool, bool]:
102
+ # Check if it's a C-like symbol
103
+ found, cached = super().has_header_symbol(hname, symbol, prefix, env,
104
+ extra_args=extra_args,
105
+ dependencies=dependencies)
106
+ if found:
107
+ return True, cached
108
+ # Check if it's a class or a template
109
+ if extra_args is None:
110
+ extra_args = []
111
+ t = f'''{prefix}
112
+ #include <{hname}>
113
+ using {symbol};
114
+ int main(void) {{ return 0; }}'''
115
+ return self.compiles(t, env, extra_args=extra_args,
116
+ dependencies=dependencies)
117
+
118
+ def _test_cpp_std_arg(self, cpp_std_value: str) -> bool:
119
+ # Test whether the compiler understands a -std=XY argument
120
+ assert cpp_std_value.startswith('-std=')
121
+
122
+ # This test does not use has_multi_arguments() for two reasons:
123
+ # 1. has_multi_arguments() requires an env argument, which the compiler
124
+ # object does not have at this point.
125
+ # 2. even if it did have an env object, that might contain another more
126
+ # recent -std= argument, which might lead to a cascaded failure.
127
+ CPP_TEST = 'int i = static_cast<int>(0);'
128
+ with self.compile(CPP_TEST, extra_args=[cpp_std_value], mode=CompileCheckMode.COMPILE) as p:
129
+ if p.returncode == 0:
130
+ mlog.debug(f'Compiler accepts {cpp_std_value}:', 'YES')
131
+ return True
132
+ else:
133
+ mlog.debug(f'Compiler accepts {cpp_std_value}:', 'NO')
134
+ return False
135
+
136
+ @functools.lru_cache()
137
+ def _find_best_cpp_std(self, cpp_std: str) -> str:
138
+ # The initial version mapping approach to make falling back
139
+ # from '-std=c++14' to '-std=c++1y' was too brittle. For instance,
140
+ # Apple's Clang uses a different versioning scheme to upstream LLVM,
141
+ # making the whole detection logic awfully brittle. Instead, let's
142
+ # just see if feeding GCC or Clang our '-std=' setting works, and
143
+ # if not, try the fallback argument.
144
+ CPP_FALLBACKS = {
145
+ 'c++11': 'c++0x',
146
+ 'gnu++11': 'gnu++0x',
147
+ 'c++14': 'c++1y',
148
+ 'gnu++14': 'gnu++1y',
149
+ 'c++17': 'c++1z',
150
+ 'gnu++17': 'gnu++1z',
151
+ 'c++20': 'c++2a',
152
+ 'gnu++20': 'gnu++2a',
153
+ 'c++23': 'c++2b',
154
+ 'gnu++23': 'gnu++2b',
155
+ 'c++26': 'c++2c',
156
+ 'gnu++26': 'gnu++2c',
157
+ }
158
+
159
+ # Currently, remapping is only supported for Clang, Elbrus and GCC
160
+ assert self.id in frozenset(['clang', 'lcc', 'gcc', 'emscripten', 'armltdclang', 'intel-llvm'])
161
+
162
+ if cpp_std not in CPP_FALLBACKS:
163
+ # 'c++03' and 'c++98' don't have fallback types
164
+ return '-std=' + cpp_std
165
+
166
+ for i in (cpp_std, CPP_FALLBACKS[cpp_std]):
167
+ cpp_std_value = '-std=' + i
168
+ if self._test_cpp_std_arg(cpp_std_value):
169
+ return cpp_std_value
170
+
171
+ raise MesonException(f'C++ Compiler does not support -std={cpp_std}')
172
+
173
+ def get_options(self) -> 'MutableKeyedOptionDictType':
174
+ opts = super().get_options()
175
+ key = OptionKey('std', machine=self.for_machine, lang=self.language)
176
+ opts.update({
177
+ key: coredata.UserStdOption('C++', _ALL_STDS),
178
+ })
179
+ return opts
180
+
181
+
182
+ class _StdCPPLibMixin(CompilerMixinBase):
183
+
184
+ """Detect whether to use libc++ or libstdc++."""
185
+
186
+ @functools.lru_cache(None)
187
+ def language_stdlib_only_link_flags(self, env: Environment) -> T.List[str]:
188
+ """Detect the C++ stdlib and default search dirs
189
+
190
+ As an optimization, this method will cache the value, to avoid building the same values over and over
191
+
192
+ :param env: An Environment object
193
+ :raises MesonException: If a stdlib cannot be determined
194
+ """
195
+
196
+ # We need to apply the search prefix here, as these link arguments may
197
+ # be passed to a different compiler with a different set of default
198
+ # search paths, such as when using Clang for C/C++ and gfortran for
199
+ # fortran.
200
+ search_dirs = [f'-L{d}' for d in self.get_compiler_dirs(env, 'libraries')]
201
+
202
+ machine = env.machines[self.for_machine]
203
+ assert machine is not None, 'for mypy'
204
+
205
+ # https://stackoverflow.com/a/31658120
206
+ header = 'version' if self.has_header('<version>', '', env) else 'ciso646'
207
+ is_libcxx = self.has_header_symbol(header, '_LIBCPP_VERSION', '', env)[0]
208
+ lib = 'c++' if is_libcxx else 'stdc++'
209
+
210
+ if self.find_library(lib, env, []) is not None:
211
+ return search_dirs + [f'-l{lib}']
212
+
213
+ # TODO: maybe a bug exception?
214
+ raise MesonException('Could not detect either libc++ or libstdc++ as your C++ stdlib implementation.')
215
+
216
+
217
+ class ClangCPPCompiler(_StdCPPLibMixin, ClangCompiler, CPPCompiler):
218
+
219
+ _CPP23_VERSION = '>=12.0.0'
220
+ _CPP26_VERSION = '>=17.0.0'
221
+
222
+ def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice, is_cross: bool,
223
+ info: 'MachineInfo',
224
+ linker: T.Optional['DynamicLinker'] = None,
225
+ defines: T.Optional[T.Dict[str, str]] = None,
226
+ full_version: T.Optional[str] = None):
227
+ CPPCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross,
228
+ info, linker=linker, full_version=full_version)
229
+ ClangCompiler.__init__(self, defines)
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 = CPPCompiler.get_options(self)
239
+ key = OptionKey('key', machine=self.for_machine, lang=self.language)
240
+ self.update_options(
241
+ opts,
242
+ self.create_option(coredata.UserComboOption,
243
+ key.evolve('eh'),
244
+ 'C++ exception handling type.',
245
+ ['none', 'default', 'a', 's', 'sc'],
246
+ 'default'),
247
+ self.create_option(coredata.UserBooleanOption,
248
+ key.evolve('rtti'),
249
+ 'Enable RTTI',
250
+ True),
251
+ self.create_option(coredata.UserBooleanOption,
252
+ key.evolve('debugstl'),
253
+ 'STL debug mode',
254
+ False),
255
+ )
256
+ cppstd_choices = [
257
+ 'c++98', 'c++03', 'c++11', 'c++14', 'c++17', 'c++1z', 'c++2a', 'c++20',
258
+ ]
259
+ if version_compare(self.version, self._CPP23_VERSION):
260
+ cppstd_choices.append('c++23')
261
+ if version_compare(self.version, self._CPP26_VERSION):
262
+ cppstd_choices.append('c++26')
263
+ std_opt = opts[key.evolve('std')]
264
+ assert isinstance(std_opt, coredata.UserStdOption), 'for mypy'
265
+ std_opt.set_versions(cppstd_choices, gnu=True)
266
+ if self.info.is_windows() or self.info.is_cygwin():
267
+ self.update_options(
268
+ opts,
269
+ self.create_option(coredata.UserArrayOption,
270
+ key.evolve('winlibs'),
271
+ 'Standard Win libraries to link against',
272
+ gnu_winlibs),
273
+ )
274
+ return opts
275
+
276
+ def get_option_compile_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
277
+ args: T.List[str] = []
278
+ key = OptionKey('std', machine=self.for_machine, lang=self.language)
279
+ std = options[key]
280
+ if std.value != 'none':
281
+ args.append(self._find_best_cpp_std(std.value))
282
+
283
+ non_msvc_eh_options(options[key.evolve('eh')].value, args)
284
+
285
+ if options[key.evolve('debugstl')].value:
286
+ args.append('-D_GLIBCXX_DEBUG=1')
287
+
288
+ # We can't do _LIBCPP_DEBUG because it's unreliable unless libc++ was built with it too:
289
+ # https://discourse.llvm.org/t/building-a-program-with-d-libcpp-debug-1-against-a-libc-that-is-not-itself-built-with-that-define/59176/3
290
+ # Note that unlike _GLIBCXX_DEBUG, _MODE_DEBUG doesn't break ABI. It's just slow.
291
+ if version_compare(self.version, '>=18'):
292
+ args.append('-D_LIBCPP_HARDENING_MODE=_LIBCPP_HARDENING_MODE_DEBUG')
293
+
294
+ if not options[key.evolve('rtti')].value:
295
+ args.append('-fno-rtti')
296
+
297
+ return args
298
+
299
+ def get_option_link_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
300
+ if self.info.is_windows() or self.info.is_cygwin():
301
+ # without a typedict mypy can't understand this.
302
+ key = OptionKey('winlibs', machine=self.for_machine, lang=self.language)
303
+ libs = options[key].value.copy()
304
+ assert isinstance(libs, list)
305
+ for l in libs:
306
+ assert isinstance(l, str)
307
+ return libs
308
+ return []
309
+
310
+ def get_assert_args(self, disable: bool) -> T.List[str]:
311
+ args: T.List[str] = []
312
+ if disable:
313
+ return ['-DNDEBUG']
314
+
315
+ # Clang supports both libstdc++ and libc++
316
+ args.append('-D_GLIBCXX_ASSERTIONS=1')
317
+ if version_compare(self.version, '>=18'):
318
+ args.append('-D_LIBCPP_HARDENING_MODE=_LIBCPP_HARDENING_MODE_EXTENSIVE')
319
+ elif version_compare(self.version, '>=15'):
320
+ args.append('-D_LIBCPP_ENABLE_ASSERTIONS=1')
321
+
322
+ return args
323
+
324
+
325
+ class ArmLtdClangCPPCompiler(ClangCPPCompiler):
326
+
327
+ id = 'armltdclang'
328
+
329
+
330
+ class AppleClangCPPCompiler(ClangCPPCompiler):
331
+
332
+ _CPP23_VERSION = '>=13.0.0'
333
+ # TODO: We don't know which XCode version will include LLVM 17 yet, so
334
+ # use something absurd.
335
+ _CPP26_VERSION = '>=99.0.0'
336
+
337
+
338
+ class EmscriptenCPPCompiler(EmscriptenMixin, ClangCPPCompiler):
339
+
340
+ id = 'emscripten'
341
+
342
+ def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice, is_cross: bool,
343
+ info: 'MachineInfo',
344
+ linker: T.Optional['DynamicLinker'] = None,
345
+ defines: T.Optional[T.Dict[str, str]] = None,
346
+ full_version: T.Optional[str] = None):
347
+ if not is_cross:
348
+ raise MesonException('Emscripten compiler can only be used for cross compilation.')
349
+ if not version_compare(version, '>=1.39.19'):
350
+ raise MesonException('Meson requires Emscripten >= 1.39.19')
351
+ ClangCPPCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross,
352
+ info, linker=linker,
353
+ defines=defines, full_version=full_version)
354
+
355
+ def get_option_compile_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
356
+ args: T.List[str] = []
357
+ key = OptionKey('std', machine=self.for_machine, lang=self.language)
358
+ std = options[key]
359
+ if std.value != 'none':
360
+ args.append(self._find_best_cpp_std(std.value))
361
+ return args
362
+
363
+
364
+ class ArmclangCPPCompiler(ArmclangCompiler, CPPCompiler):
365
+ '''
366
+ Keil armclang
367
+ '''
368
+
369
+ def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice, is_cross: bool,
370
+ info: 'MachineInfo',
371
+ linker: T.Optional['DynamicLinker'] = None,
372
+ full_version: T.Optional[str] = None):
373
+ CPPCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross,
374
+ info, linker=linker, full_version=full_version)
375
+ ArmclangCompiler.__init__(self)
376
+ default_warn_args = ['-Wall', '-Winvalid-pch']
377
+ self.warn_args = {'0': [],
378
+ '1': default_warn_args,
379
+ '2': default_warn_args + ['-Wextra'],
380
+ '3': default_warn_args + ['-Wextra', '-Wpedantic'],
381
+ 'everything': ['-Weverything']}
382
+
383
+ def get_options(self) -> 'MutableKeyedOptionDictType':
384
+ opts = CPPCompiler.get_options(self)
385
+ key = OptionKey('std', machine=self.for_machine, lang=self.language)
386
+ self.update_options(
387
+ opts,
388
+ self.create_option(coredata.UserComboOption,
389
+ key.evolve('eh'),
390
+ 'C++ exception handling type.',
391
+ ['none', 'default', 'a', 's', 'sc'],
392
+ 'default'),
393
+ )
394
+ std_opt = opts[key]
395
+ assert isinstance(std_opt, coredata.UserStdOption), 'for mypy'
396
+ std_opt.set_versions(['c++98', 'c++03', 'c++11', 'c++14', 'c++17'], gnu=True)
397
+ return opts
398
+
399
+ def get_option_compile_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
400
+ args: T.List[str] = []
401
+ key = OptionKey('std', machine=self.for_machine, lang=self.language)
402
+ std = options[key]
403
+ if std.value != 'none':
404
+ args.append('-std=' + std.value)
405
+
406
+ non_msvc_eh_options(options[key.evolve('eh')].value, args)
407
+
408
+ return args
409
+
410
+ def get_option_link_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
411
+ return []
412
+
413
+
414
+ class GnuCPPCompiler(_StdCPPLibMixin, GnuCompiler, CPPCompiler):
415
+ def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice, is_cross: bool,
416
+ info: 'MachineInfo',
417
+ linker: T.Optional['DynamicLinker'] = None,
418
+ defines: T.Optional[T.Dict[str, str]] = None,
419
+ full_version: T.Optional[str] = None):
420
+ CPPCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross,
421
+ info, linker=linker, full_version=full_version)
422
+ GnuCompiler.__init__(self, defines)
423
+ default_warn_args = ['-Wall', '-Winvalid-pch']
424
+ self.warn_args = {'0': [],
425
+ '1': default_warn_args,
426
+ '2': default_warn_args + ['-Wextra'],
427
+ '3': default_warn_args + ['-Wextra', '-Wpedantic'],
428
+ 'everything': (default_warn_args + ['-Wextra', '-Wpedantic'] +
429
+ self.supported_warn_args(gnu_common_warning_args) +
430
+ self.supported_warn_args(gnu_cpp_warning_args))}
431
+
432
+ def get_options(self) -> 'MutableKeyedOptionDictType':
433
+ key = OptionKey('std', machine=self.for_machine, lang=self.language)
434
+ opts = CPPCompiler.get_options(self)
435
+ self.update_options(
436
+ opts,
437
+ self.create_option(coredata.UserComboOption,
438
+ key.evolve('eh'),
439
+ 'C++ exception handling type.',
440
+ ['none', 'default', 'a', 's', 'sc'],
441
+ 'default'),
442
+ self.create_option(coredata.UserBooleanOption,
443
+ key.evolve('rtti'),
444
+ 'Enable RTTI',
445
+ True),
446
+ self.create_option(coredata.UserBooleanOption,
447
+ key.evolve('debugstl'),
448
+ 'STL debug mode',
449
+ False),
450
+ )
451
+ cppstd_choices = [
452
+ 'c++98', 'c++03', 'c++11', 'c++14', 'c++17', 'c++1z',
453
+ 'c++2a', 'c++20',
454
+ ]
455
+ if version_compare(self.version, '>=11.0.0'):
456
+ cppstd_choices.append('c++23')
457
+ if version_compare(self.version, '>=14.0.0'):
458
+ cppstd_choices.append('c++26')
459
+ std_opt = opts[key]
460
+ assert isinstance(std_opt, coredata.UserStdOption), 'for mypy'
461
+ std_opt.set_versions(cppstd_choices, gnu=True)
462
+ if self.info.is_windows() or self.info.is_cygwin():
463
+ self.update_options(
464
+ opts,
465
+ self.create_option(coredata.UserArrayOption,
466
+ key.evolve('winlibs'),
467
+ 'Standard Win libraries to link against',
468
+ gnu_winlibs),
469
+ )
470
+ return opts
471
+
472
+ def get_option_compile_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
473
+ args: T.List[str] = []
474
+ key = OptionKey('std', machine=self.for_machine, lang=self.language)
475
+ std = options[key]
476
+ if std.value != 'none':
477
+ args.append(self._find_best_cpp_std(std.value))
478
+
479
+ non_msvc_eh_options(options[key.evolve('eh')].value, args)
480
+
481
+ if not options[key.evolve('rtti')].value:
482
+ args.append('-fno-rtti')
483
+
484
+ if options[key.evolve('debugstl')].value:
485
+ args.append('-D_GLIBCXX_DEBUG=1')
486
+ return args
487
+
488
+ def get_option_link_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
489
+ if self.info.is_windows() or self.info.is_cygwin():
490
+ # without a typedict mypy can't understand this.
491
+ key = OptionKey('winlibs', machine=self.for_machine, lang=self.language)
492
+ libs = options[key].value.copy()
493
+ assert isinstance(libs, list)
494
+ for l in libs:
495
+ assert isinstance(l, str)
496
+ return libs
497
+ return []
498
+
499
+ def get_assert_args(self, disable: bool) -> T.List[str]:
500
+ if disable:
501
+ return ['-DNDEBUG']
502
+
503
+ # XXX: This needs updating if/when GCC starts to support libc++.
504
+ # It currently only does so via an experimental configure arg.
505
+ return ['-D_GLIBCXX_ASSERTIONS=1']
506
+
507
+ def get_pch_use_args(self, pch_dir: str, header: str) -> T.List[str]:
508
+ return ['-fpch-preprocess', '-include', os.path.basename(header)]
509
+
510
+
511
+ class PGICPPCompiler(PGICompiler, CPPCompiler):
512
+ def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice, is_cross: bool,
513
+ info: 'MachineInfo',
514
+ linker: T.Optional['DynamicLinker'] = None,
515
+ full_version: T.Optional[str] = None):
516
+ CPPCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross,
517
+ info, linker=linker, full_version=full_version)
518
+ PGICompiler.__init__(self)
519
+
520
+
521
+ class NvidiaHPC_CPPCompiler(PGICompiler, CPPCompiler):
522
+
523
+ id = 'nvidia_hpc'
524
+
525
+ def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice, is_cross: bool,
526
+ info: 'MachineInfo',
527
+ linker: T.Optional['DynamicLinker'] = None,
528
+ full_version: T.Optional[str] = None):
529
+ CPPCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross,
530
+ info, linker=linker, full_version=full_version)
531
+ PGICompiler.__init__(self)
532
+
533
+
534
+ class ElbrusCPPCompiler(ElbrusCompiler, CPPCompiler):
535
+ def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice, is_cross: bool,
536
+ info: 'MachineInfo',
537
+ linker: T.Optional['DynamicLinker'] = None,
538
+ defines: T.Optional[T.Dict[str, str]] = None,
539
+ full_version: T.Optional[str] = None):
540
+ CPPCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross,
541
+ info, linker=linker, full_version=full_version)
542
+ ElbrusCompiler.__init__(self)
543
+
544
+ def get_options(self) -> 'MutableKeyedOptionDictType':
545
+ opts = CPPCompiler.get_options(self)
546
+
547
+ cpp_stds = ['c++98']
548
+ if version_compare(self.version, '>=1.20.00'):
549
+ cpp_stds += ['c++03', 'c++0x', 'c++11']
550
+ if version_compare(self.version, '>=1.21.00') and version_compare(self.version, '<1.22.00'):
551
+ cpp_stds += ['c++14', 'c++1y']
552
+ if version_compare(self.version, '>=1.22.00'):
553
+ cpp_stds += ['c++14']
554
+ if version_compare(self.version, '>=1.23.00'):
555
+ cpp_stds += ['c++1y']
556
+ if version_compare(self.version, '>=1.24.00'):
557
+ cpp_stds += ['c++1z', 'c++17']
558
+ if version_compare(self.version, '>=1.25.00'):
559
+ cpp_stds += ['c++2a']
560
+ if version_compare(self.version, '>=1.26.00'):
561
+ cpp_stds += ['c++20']
562
+
563
+ key = OptionKey('std', machine=self.for_machine, lang=self.language)
564
+ self.update_options(
565
+ opts,
566
+ self.create_option(coredata.UserComboOption,
567
+ key.evolve('eh'),
568
+ 'C++ exception handling type.',
569
+ ['none', 'default', 'a', 's', 'sc'],
570
+ 'default'),
571
+ self.create_option(coredata.UserBooleanOption,
572
+ key.evolve('debugstl'),
573
+ 'STL debug mode',
574
+ False),
575
+ )
576
+ std_opt = opts[key]
577
+ assert isinstance(std_opt, coredata.UserStdOption), 'for mypy'
578
+ std_opt.set_versions(cpp_stds, gnu=True)
579
+ return opts
580
+
581
+ # Elbrus C++ compiler does not have lchmod, but there is only linker warning, not compiler error.
582
+ # So we should explicitly fail at this case.
583
+ def has_function(self, funcname: str, prefix: str, env: 'Environment', *,
584
+ extra_args: T.Optional[T.List[str]] = None,
585
+ dependencies: T.Optional[T.List['Dependency']] = None) -> T.Tuple[bool, bool]:
586
+ if funcname == 'lchmod':
587
+ return False, False
588
+ else:
589
+ return super().has_function(funcname, prefix, env,
590
+ extra_args=extra_args,
591
+ dependencies=dependencies)
592
+
593
+ # Elbrus C++ compiler does not support RTTI, so don't check for it.
594
+ def get_option_compile_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
595
+ args: T.List[str] = []
596
+ key = OptionKey('std', machine=self.for_machine, lang=self.language)
597
+ std = options[key]
598
+ if std.value != 'none':
599
+ args.append(self._find_best_cpp_std(std.value))
600
+
601
+ non_msvc_eh_options(options[key.evolve('eh')].value, args)
602
+
603
+ if options[key.evolve('debugstl')].value:
604
+ args.append('-D_GLIBCXX_DEBUG=1')
605
+ return args
606
+
607
+
608
+ class IntelCPPCompiler(IntelGnuLikeCompiler, CPPCompiler):
609
+ def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice, is_cross: bool,
610
+ info: 'MachineInfo',
611
+ linker: T.Optional['DynamicLinker'] = None,
612
+ full_version: T.Optional[str] = None):
613
+ CPPCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross,
614
+ info, linker=linker, full_version=full_version)
615
+ IntelGnuLikeCompiler.__init__(self)
616
+ self.lang_header = 'c++-header'
617
+ default_warn_args = ['-Wall', '-w3', '-Wpch-messages']
618
+ self.warn_args = {'0': [],
619
+ '1': default_warn_args + ['-diag-disable:remark'],
620
+ '2': default_warn_args + ['-Wextra', '-diag-disable:remark'],
621
+ '3': default_warn_args + ['-Wextra', '-diag-disable:remark'],
622
+ 'everything': default_warn_args + ['-Wextra']}
623
+
624
+ def get_options(self) -> 'MutableKeyedOptionDictType':
625
+ opts = CPPCompiler.get_options(self)
626
+ # Every Unix compiler under the sun seems to accept -std=c++03,
627
+ # with the exception of ICC. Instead of preventing the user from
628
+ # globally requesting C++03, we transparently remap it to C++98
629
+ c_stds = ['c++98', 'c++03']
630
+ g_stds = ['gnu++98', 'gnu++03']
631
+ if version_compare(self.version, '>=15.0.0'):
632
+ c_stds += ['c++11', 'c++14']
633
+ g_stds += ['gnu++11']
634
+ if version_compare(self.version, '>=16.0.0'):
635
+ c_stds += ['c++17']
636
+ if version_compare(self.version, '>=17.0.0'):
637
+ g_stds += ['gnu++14']
638
+ if version_compare(self.version, '>=19.1.0'):
639
+ c_stds += ['c++2a']
640
+ g_stds += ['gnu++2a']
641
+
642
+ key = OptionKey('std', machine=self.for_machine, lang=self.language)
643
+ self.update_options(
644
+ opts,
645
+ self.create_option(coredata.UserComboOption,
646
+ key.evolve('eh'),
647
+ 'C++ exception handling type.',
648
+ ['none', 'default', 'a', 's', 'sc'],
649
+ 'default'),
650
+ self.create_option(coredata.UserBooleanOption,
651
+ key.evolve('rtti'),
652
+ 'Enable RTTI',
653
+ True),
654
+ self.create_option(coredata.UserBooleanOption,
655
+ key.evolve('debugstl'),
656
+ 'STL debug mode',
657
+ False),
658
+ )
659
+ std_opt = opts[key]
660
+ assert isinstance(std_opt, coredata.UserStdOption), 'for mypy'
661
+ std_opt.set_versions(c_stds + g_stds)
662
+ return opts
663
+
664
+ def get_option_compile_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
665
+ args: T.List[str] = []
666
+ key = OptionKey('std', machine=self.for_machine, lang=self.language)
667
+ std = options[key]
668
+ if std.value != 'none':
669
+ remap_cpp03 = {
670
+ 'c++03': 'c++98',
671
+ 'gnu++03': 'gnu++98'
672
+ }
673
+ args.append('-std=' + remap_cpp03.get(std.value, std.value))
674
+ if options[key.evolve('eh')].value == 'none':
675
+ args.append('-fno-exceptions')
676
+ if not options[key.evolve('rtti')].value:
677
+ args.append('-fno-rtti')
678
+ if options[key.evolve('debugstl')].value:
679
+ args.append('-D_GLIBCXX_DEBUG=1')
680
+ return args
681
+
682
+ def get_option_link_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
683
+ return []
684
+
685
+
686
+ class IntelLLVMCPPCompiler(ClangCPPCompiler):
687
+
688
+ id = 'intel-llvm'
689
+
690
+
691
+ class VisualStudioLikeCPPCompilerMixin(CompilerMixinBase):
692
+
693
+ """Mixin for C++ specific method overrides in MSVC-like compilers."""
694
+
695
+ VC_VERSION_MAP = {
696
+ 'none': (True, None),
697
+ 'vc++11': (True, 11),
698
+ 'vc++14': (True, 14),
699
+ 'vc++17': (True, 17),
700
+ 'vc++20': (True, 20),
701
+ 'vc++latest': (True, "latest"),
702
+ 'c++11': (False, 11),
703
+ 'c++14': (False, 14),
704
+ 'c++17': (False, 17),
705
+ 'c++20': (False, 20),
706
+ 'c++latest': (False, "latest"),
707
+ }
708
+
709
+ def get_option_link_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
710
+ # need a typeddict for this
711
+ key = OptionKey('winlibs', machine=self.for_machine, lang=self.language)
712
+ return T.cast('T.List[str]', options[key].value[:])
713
+
714
+ def _get_options_impl(self, opts: 'MutableKeyedOptionDictType', cpp_stds: T.List[str]) -> 'MutableKeyedOptionDictType':
715
+ key = OptionKey('std', machine=self.for_machine, lang=self.language)
716
+ self.update_options(
717
+ opts,
718
+ self.create_option(coredata.UserComboOption,
719
+ key.evolve('eh'),
720
+ 'C++ exception handling type.',
721
+ ['none', 'default', 'a', 's', 'sc'],
722
+ 'default'),
723
+ self.create_option(coredata.UserBooleanOption,
724
+ key.evolve('rtti'),
725
+ 'Enable RTTI',
726
+ True),
727
+ self.create_option(coredata.UserArrayOption,
728
+ key.evolve('winlibs'),
729
+ 'Windows libs to link against.',
730
+ msvc_winlibs),
731
+ )
732
+ std_opt = opts[key]
733
+ assert isinstance(std_opt, coredata.UserStdOption), 'for mypy'
734
+ std_opt.set_versions(cpp_stds)
735
+ return opts
736
+
737
+ def get_option_compile_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
738
+ args: T.List[str] = []
739
+ key = OptionKey('std', machine=self.for_machine, lang=self.language)
740
+
741
+ eh = options[key.evolve('eh')]
742
+ if eh.value == 'default':
743
+ args.append('/EHsc')
744
+ elif eh.value == 'none':
745
+ args.append('/EHs-c-')
746
+ else:
747
+ args.append('/EH' + eh.value)
748
+
749
+ if not options[key.evolve('rtti')].value:
750
+ args.append('/GR-')
751
+
752
+ permissive, ver = self.VC_VERSION_MAP[options[key].value]
753
+
754
+ if ver is not None:
755
+ args.append(f'/std:c++{ver}')
756
+
757
+ if not permissive:
758
+ args.append('/permissive-')
759
+
760
+ return args
761
+
762
+ def get_compiler_check_args(self, mode: CompileCheckMode) -> T.List[str]:
763
+ # XXX: this is a hack because so much GnuLike stuff is in the base CPPCompiler class.
764
+ return Compiler.get_compiler_check_args(self, mode)
765
+
766
+
767
+ class CPP11AsCPP14Mixin(CompilerMixinBase):
768
+
769
+ """Mixin class for VisualStudio and ClangCl to replace C++11 std with C++14.
770
+
771
+ This is a limitation of Clang and MSVC that ICL doesn't share.
772
+ """
773
+
774
+ def get_option_compile_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
775
+ # Note: there is no explicit flag for supporting C++11; we attempt to do the best we can
776
+ # which means setting the C++ standard version to C++14, in compilers that support it
777
+ # (i.e., after VS2015U3)
778
+ # if one is using anything before that point, one cannot set the standard.
779
+ key = OptionKey('std', machine=self.for_machine, lang=self.language)
780
+ if options[key].value in {'vc++11', 'c++11'}:
781
+ mlog.warning(self.id, 'does not support C++11;',
782
+ 'attempting best effort; setting the standard to C++14',
783
+ once=True, fatal=False)
784
+ # Don't mutate anything we're going to change, we need to use
785
+ # deepcopy since we're messing with members, and we can't simply
786
+ # copy the members because the option proxy doesn't support it.
787
+ options = copy.deepcopy(options)
788
+ if options[key].value == 'vc++11':
789
+ options[key].value = 'vc++14'
790
+ else:
791
+ options[key].value = 'c++14'
792
+ return super().get_option_compile_args(options)
793
+
794
+
795
+ class VisualStudioCPPCompiler(CPP11AsCPP14Mixin, VisualStudioLikeCPPCompilerMixin, MSVCCompiler, CPPCompiler):
796
+
797
+ id = 'msvc'
798
+
799
+ def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice,
800
+ is_cross: bool, info: 'MachineInfo', target: str,
801
+ linker: T.Optional['DynamicLinker'] = None,
802
+ full_version: T.Optional[str] = None):
803
+ CPPCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross,
804
+ info, linker=linker, full_version=full_version)
805
+ MSVCCompiler.__init__(self, target)
806
+
807
+ # By default, MSVC has a broken __cplusplus define that pretends to be c++98:
808
+ # https://docs.microsoft.com/en-us/cpp/build/reference/zc-cplusplus?view=msvc-160
809
+ # Pass the flag to enable a truthful define, if possible.
810
+ if version_compare(self.version, '>= 19.14.26428'):
811
+ self.always_args = self.always_args + ['/Zc:__cplusplus']
812
+
813
+ def get_options(self) -> 'MutableKeyedOptionDictType':
814
+ cpp_stds = ['none', 'c++11', 'vc++11']
815
+ # Visual Studio 2015 and later
816
+ if version_compare(self.version, '>=19'):
817
+ cpp_stds.extend(['c++14', 'c++latest', 'vc++latest'])
818
+ # Visual Studio 2017 and later
819
+ if version_compare(self.version, '>=19.11'):
820
+ cpp_stds.extend(['vc++14', 'c++17', 'vc++17'])
821
+ if version_compare(self.version, '>=19.29'):
822
+ cpp_stds.extend(['c++20', 'vc++20'])
823
+ return self._get_options_impl(super().get_options(), cpp_stds)
824
+
825
+ def get_option_compile_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
826
+ key = OptionKey('std', machine=self.for_machine, lang=self.language)
827
+ if options[key].value != 'none' and version_compare(self.version, '<19.00.24210'):
828
+ mlog.warning('This version of MSVC does not support cpp_std arguments', fatal=False)
829
+ options = copy.copy(options)
830
+ options[key].value = 'none'
831
+
832
+ args = super().get_option_compile_args(options)
833
+
834
+ if version_compare(self.version, '<19.11'):
835
+ try:
836
+ i = args.index('/permissive-')
837
+ except ValueError:
838
+ return args
839
+ del args[i]
840
+ return args
841
+
842
+ class ClangClCPPCompiler(CPP11AsCPP14Mixin, VisualStudioLikeCPPCompilerMixin, ClangClCompiler, CPPCompiler):
843
+
844
+ id = 'clang-cl'
845
+
846
+ def __init__(self, exelist: T.List[str], version: str, for_machine: MachineChoice,
847
+ is_cross: bool, info: 'MachineInfo', target: str,
848
+ linker: T.Optional['DynamicLinker'] = None,
849
+ full_version: T.Optional[str] = None):
850
+ CPPCompiler.__init__(self, [], exelist, version, for_machine, is_cross,
851
+ info, linker=linker, full_version=full_version)
852
+ ClangClCompiler.__init__(self, target)
853
+
854
+ def get_options(self) -> 'MutableKeyedOptionDictType':
855
+ cpp_stds = ['none', 'c++11', 'vc++11', 'c++14', 'vc++14', 'c++17', 'vc++17', 'c++20', 'vc++20', 'c++latest']
856
+ return self._get_options_impl(super().get_options(), cpp_stds)
857
+
858
+
859
+ class IntelClCPPCompiler(VisualStudioLikeCPPCompilerMixin, IntelVisualStudioLikeCompiler, CPPCompiler):
860
+
861
+ def __init__(self, exelist: T.List[str], version: str, for_machine: MachineChoice,
862
+ is_cross: bool, info: 'MachineInfo', target: str,
863
+ linker: T.Optional['DynamicLinker'] = None,
864
+ full_version: T.Optional[str] = None):
865
+ CPPCompiler.__init__(self, [], exelist, version, for_machine, is_cross,
866
+ info, linker=linker, full_version=full_version)
867
+ IntelVisualStudioLikeCompiler.__init__(self, target)
868
+
869
+ def get_options(self) -> 'MutableKeyedOptionDictType':
870
+ # This has only been tested with version 19.0,
871
+ cpp_stds = ['none', 'c++11', 'vc++11', 'c++14', 'vc++14', 'c++17', 'vc++17', 'c++latest']
872
+ return self._get_options_impl(super().get_options(), cpp_stds)
873
+
874
+ def get_compiler_check_args(self, mode: CompileCheckMode) -> T.List[str]:
875
+ # XXX: this is a hack because so much GnuLike stuff is in the base CPPCompiler class.
876
+ return IntelVisualStudioLikeCompiler.get_compiler_check_args(self, mode)
877
+
878
+
879
+ class IntelLLVMClCPPCompiler(IntelClCPPCompiler):
880
+
881
+ id = 'intel-llvm-cl'
882
+
883
+
884
+ class ArmCPPCompiler(ArmCompiler, CPPCompiler):
885
+ def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice, is_cross: bool,
886
+ info: 'MachineInfo',
887
+ linker: T.Optional['DynamicLinker'] = None,
888
+ full_version: T.Optional[str] = None):
889
+ CPPCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross,
890
+ info, linker=linker, full_version=full_version)
891
+ ArmCompiler.__init__(self)
892
+
893
+ def get_options(self) -> 'MutableKeyedOptionDictType':
894
+ opts = CPPCompiler.get_options(self)
895
+ std_opt = opts[OptionKey('std', machine=self.for_machine, lang=self.language)]
896
+ assert isinstance(std_opt, coredata.UserStdOption), 'for mypy'
897
+ std_opt.set_versions(['c++03', 'c++11'])
898
+ return opts
899
+
900
+ def get_option_compile_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
901
+ args: T.List[str] = []
902
+ key = OptionKey('std', machine=self.for_machine, lang=self.language)
903
+ std = options[key]
904
+ if std.value == 'c++11':
905
+ args.append('--cpp11')
906
+ elif std.value == 'c++03':
907
+ args.append('--cpp')
908
+ return args
909
+
910
+ def get_option_link_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
911
+ return []
912
+
913
+ def get_compiler_check_args(self, mode: CompileCheckMode) -> T.List[str]:
914
+ return []
915
+
916
+
917
+ class CcrxCPPCompiler(CcrxCompiler, CPPCompiler):
918
+ def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice, is_cross: bool,
919
+ info: 'MachineInfo',
920
+ linker: T.Optional['DynamicLinker'] = None,
921
+ full_version: T.Optional[str] = None):
922
+ CPPCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross,
923
+ info, linker=linker, full_version=full_version)
924
+ CcrxCompiler.__init__(self)
925
+
926
+ # Override CCompiler.get_always_args
927
+ def get_always_args(self) -> T.List[str]:
928
+ return ['-nologo', '-lang=cpp']
929
+
930
+ def get_option_compile_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
931
+ return []
932
+
933
+ def get_compile_only_args(self) -> T.List[str]:
934
+ return []
935
+
936
+ def get_output_args(self, outputname: str) -> T.List[str]:
937
+ return [f'-output=obj={outputname}']
938
+
939
+ def get_option_link_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
940
+ return []
941
+
942
+ def get_compiler_check_args(self, mode: CompileCheckMode) -> T.List[str]:
943
+ return []
944
+
945
+ class TICPPCompiler(TICompiler, CPPCompiler):
946
+ def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice, is_cross: bool,
947
+ info: 'MachineInfo',
948
+ linker: T.Optional['DynamicLinker'] = None,
949
+ full_version: T.Optional[str] = None):
950
+ CPPCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross,
951
+ info, linker=linker, full_version=full_version)
952
+ TICompiler.__init__(self)
953
+
954
+ def get_options(self) -> 'MutableKeyedOptionDictType':
955
+ opts = CPPCompiler.get_options(self)
956
+ std_opt = opts[OptionKey('std', machine=self.for_machine, lang=self.language)]
957
+ assert isinstance(std_opt, coredata.UserStdOption), 'for mypy'
958
+ std_opt.set_versions(['c++03'])
959
+ return opts
960
+
961
+ def get_option_compile_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
962
+ args: T.List[str] = []
963
+ key = OptionKey('std', machine=self.for_machine, lang=self.language)
964
+ std = options[key]
965
+ if std.value != 'none':
966
+ args.append('--' + std.value)
967
+ return args
968
+
969
+ def get_always_args(self) -> T.List[str]:
970
+ return []
971
+
972
+ def get_option_link_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
973
+ return []
974
+
975
+ class C2000CPPCompiler(TICPPCompiler):
976
+ # Required for backwards compat with projects created before ti-cgt support existed
977
+ id = 'c2000'
978
+
979
+ class C6000CPPCompiler(TICPPCompiler):
980
+ id = 'c6000'
981
+
982
+ class MetrowerksCPPCompilerARM(MetrowerksCompiler, CPPCompiler):
983
+ id = 'mwccarm'
984
+
985
+ def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice,
986
+ is_cross: bool, info: 'MachineInfo',
987
+ linker: T.Optional['DynamicLinker'] = None,
988
+ full_version: T.Optional[str] = None):
989
+ CPPCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross,
990
+ info, linker=linker, full_version=full_version)
991
+ MetrowerksCompiler.__init__(self)
992
+
993
+ def get_instruction_set_args(self, instruction_set: str) -> T.Optional[T.List[str]]:
994
+ return mwccarm_instruction_set_args.get(instruction_set, None)
995
+
996
+ def get_options(self) -> 'MutableKeyedOptionDictType':
997
+ opts = CPPCompiler.get_options(self)
998
+ key = OptionKey('std', machine=self.for_machine, lang=self.language)
999
+ opts[key].choices = ['none']
1000
+ return opts
1001
+
1002
+ def get_option_compile_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
1003
+ args: T.List[str] = []
1004
+ std = options[OptionKey('std', machine=self.for_machine, lang=self.language)]
1005
+ if std.value != 'none':
1006
+ args.append('-lang')
1007
+ args.append(std.value)
1008
+ return args
1009
+
1010
+ class MetrowerksCPPCompilerEmbeddedPowerPC(MetrowerksCompiler, CPPCompiler):
1011
+ id = 'mwcceppc'
1012
+
1013
+ def __init__(self, ccache: T.List[str], exelist: T.List[str], version: str, for_machine: MachineChoice,
1014
+ is_cross: bool, info: 'MachineInfo',
1015
+ linker: T.Optional['DynamicLinker'] = None,
1016
+ full_version: T.Optional[str] = None):
1017
+ CPPCompiler.__init__(self, ccache, exelist, version, for_machine, is_cross,
1018
+ info, linker=linker, full_version=full_version)
1019
+ MetrowerksCompiler.__init__(self)
1020
+
1021
+ def get_instruction_set_args(self, instruction_set: str) -> T.Optional[T.List[str]]:
1022
+ return mwcceppc_instruction_set_args.get(instruction_set, None)
1023
+
1024
+ def get_options(self) -> 'MutableKeyedOptionDictType':
1025
+ opts = CPPCompiler.get_options(self)
1026
+ key = OptionKey('std', machine=self.for_machine, lang=self.language)
1027
+ opts[key].choices = ['none']
1028
+ return opts
1029
+
1030
+ def get_option_compile_args(self, options: 'KeyedOptionDictType') -> T.List[str]:
1031
+ args: T.List[str] = []
1032
+ std = options[OptionKey('std', machine=self.for_machine, lang=self.language)]
1033
+ if std.value != 'none':
1034
+ args.append('-lang ' + std.value)
1035
+ return args