@triniwiz/nativescript-masonkit 1.0.0-alpha.5 → 1.0.0-alpha.6

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 (345) hide show
  1. package/common.d.ts +7 -9
  2. package/common.js +277 -552
  3. package/common.js.map +1 -1
  4. package/helpers.d.ts +32 -10
  5. package/helpers.js +772 -286
  6. package/helpers.js.map +1 -1
  7. package/index.android.d.ts +6 -2
  8. package/index.android.js +21 -3
  9. package/index.android.js.map +1 -1
  10. package/index.d.ts +64 -7
  11. package/index.ios.d.ts +9 -6
  12. package/index.ios.js +39 -25
  13. package/index.ios.js.map +1 -1
  14. package/package.json +1 -1
  15. package/platforms/android/include.gradle +18 -1
  16. package/platforms/android/masonkit-release.aar +0 -0
  17. package/platforms/ios/Mason.xcframework/ios-arm64/Mason.framework/Headers/Mason-Swift.h +108 -64
  18. package/platforms/ios/Mason.xcframework/ios-arm64/Mason.framework/Headers/mason_native.h +47 -20
  19. package/platforms/ios/Mason.xcframework/ios-arm64/Mason.framework/Info.plist +0 -0
  20. package/platforms/ios/Mason.xcframework/ios-arm64/Mason.framework/Mason +0 -0
  21. package/platforms/ios/Mason.xcframework/ios-arm64/Mason.framework/Modules/Mason.swiftmodule/Project/arm64-apple-ios.swiftsourceinfo +0 -0
  22. package/platforms/ios/Mason.xcframework/ios-arm64/Mason.framework/Modules/Mason.swiftmodule/arm64-apple-ios.abi.json +10744 -1631
  23. package/platforms/ios/Mason.xcframework/ios-arm64/Mason.framework/Modules/Mason.swiftmodule/arm64-apple-ios.private.swiftinterface +58 -21
  24. package/platforms/ios/Mason.xcframework/ios-arm64/Mason.framework/Modules/Mason.swiftmodule/arm64-apple-ios.swiftdoc +0 -0
  25. package/platforms/ios/Mason.xcframework/ios-arm64/Mason.framework/Modules/Mason.swiftmodule/arm64-apple-ios.swiftinterface +58 -21
  26. package/platforms/ios/Mason.xcframework/ios-arm64/dSYMs/Mason.framework.dSYM/Contents/Resources/DWARF/Mason +0 -0
  27. package/platforms/ios/Mason.xcframework/ios-arm64_x86_64-simulator/Mason.framework/Headers/Mason-Swift.h +216 -128
  28. package/platforms/ios/Mason.xcframework/ios-arm64_x86_64-simulator/Mason.framework/Headers/mason_native.h +47 -20
  29. package/platforms/ios/Mason.xcframework/ios-arm64_x86_64-simulator/Mason.framework/Info.plist +0 -0
  30. package/platforms/ios/Mason.xcframework/ios-arm64_x86_64-simulator/Mason.framework/Mason +0 -0
  31. package/platforms/ios/Mason.xcframework/ios-arm64_x86_64-simulator/Mason.framework/Modules/Mason.swiftmodule/Project/arm64-apple-ios-simulator.swiftsourceinfo +0 -0
  32. package/platforms/ios/Mason.xcframework/ios-arm64_x86_64-simulator/Mason.framework/Modules/Mason.swiftmodule/Project/x86_64-apple-ios-simulator.swiftsourceinfo +0 -0
  33. package/platforms/ios/Mason.xcframework/ios-arm64_x86_64-simulator/Mason.framework/Modules/Mason.swiftmodule/arm64-apple-ios-simulator.abi.json +10744 -1631
  34. package/platforms/ios/Mason.xcframework/ios-arm64_x86_64-simulator/Mason.framework/Modules/Mason.swiftmodule/arm64-apple-ios-simulator.private.swiftinterface +58 -21
  35. package/platforms/ios/Mason.xcframework/ios-arm64_x86_64-simulator/Mason.framework/Modules/Mason.swiftmodule/arm64-apple-ios-simulator.swiftdoc +0 -0
  36. package/platforms/ios/Mason.xcframework/ios-arm64_x86_64-simulator/Mason.framework/Modules/Mason.swiftmodule/arm64-apple-ios-simulator.swiftinterface +58 -21
  37. package/platforms/ios/Mason.xcframework/ios-arm64_x86_64-simulator/Mason.framework/Modules/Mason.swiftmodule/x86_64-apple-ios-simulator.abi.json +10744 -1631
  38. package/platforms/ios/Mason.xcframework/ios-arm64_x86_64-simulator/Mason.framework/Modules/Mason.swiftmodule/x86_64-apple-ios-simulator.private.swiftinterface +58 -21
  39. package/platforms/ios/Mason.xcframework/ios-arm64_x86_64-simulator/Mason.framework/Modules/Mason.swiftmodule/x86_64-apple-ios-simulator.swiftdoc +0 -0
  40. package/platforms/ios/Mason.xcframework/ios-arm64_x86_64-simulator/Mason.framework/Modules/Mason.swiftmodule/x86_64-apple-ios-simulator.swiftinterface +58 -21
  41. package/platforms/ios/Mason.xcframework/ios-arm64_x86_64-simulator/Mason.framework/_CodeSignature/CodeResources +43 -43
  42. package/platforms/ios/Mason.xcframework/ios-arm64_x86_64-simulator/dSYMs/Mason.framework.dSYM/Contents/Resources/DWARF/Mason +0 -0
  43. package/platforms/ios/build.xcconfig +1 -2
  44. package/platforms/ios/src/MasonV8Module.h +583 -0
  45. package/platforms/ios/src/MasonV8Module.mm +1005 -0
  46. package/platforms/ios/src/{include → cpp/include}/mason_native.h +47 -20
  47. package/platforms/ios/src/cpp/include/robin_hood.h +2544 -0
  48. package/platforms/ios/src/module.modulemap +2 -2
  49. package/platforms/new_native_src/cpp/Caches.cpp +36 -0
  50. package/platforms/new_native_src/cpp/Caches.h +42 -0
  51. package/platforms/new_native_src/cpp/Common.h +34 -0
  52. package/platforms/new_native_src/cpp/ConcurrentMap.h +57 -0
  53. package/platforms/new_native_src/cpp/Helpers.cpp +101 -0
  54. package/platforms/new_native_src/cpp/Helpers.h +364 -0
  55. package/platforms/new_native_src/cpp/MasonImpl.cpp +68 -0
  56. package/platforms/new_native_src/cpp/MasonImpl.h +40 -0
  57. package/platforms/new_native_src/cpp/MasonNodeImpl.cpp +89 -0
  58. package/platforms/new_native_src/cpp/MasonNodeImpl.h +47 -0
  59. package/platforms/new_native_src/cpp/MasonStyleImpl.cpp +2181 -0
  60. package/platforms/new_native_src/cpp/MasonStyleImpl.h +420 -0
  61. package/platforms/{ios/Mason.xcframework/ios-arm64/Mason.framework/PrivateHeaders → new_native_src/cpp/include}/mason_native.h +464 -168
  62. package/platforms/new_native_src/cpp/include/robin_hood.h +2544 -0
  63. package/pods/Headers/include/APIDesign.md +72 -0
  64. package/pods/Headers/include/DEPS +10 -0
  65. package/pods/Headers/include/DIR_METADATA +11 -0
  66. package/pods/Headers/include/OWNERS +23 -0
  67. package/pods/Headers/include/cppgc/DEPS +8 -0
  68. package/pods/Headers/include/cppgc/OWNERS +2 -0
  69. package/pods/Headers/include/cppgc/README.md +133 -0
  70. package/pods/Headers/include/cppgc/allocation.h +310 -0
  71. package/pods/Headers/include/cppgc/common.h +29 -0
  72. package/pods/Headers/include/cppgc/cross-thread-persistent.h +465 -0
  73. package/pods/Headers/include/cppgc/custom-space.h +97 -0
  74. package/pods/Headers/include/cppgc/default-platform.h +67 -0
  75. package/pods/Headers/include/cppgc/ephemeron-pair.h +30 -0
  76. package/pods/Headers/include/cppgc/explicit-management.h +100 -0
  77. package/pods/Headers/include/cppgc/garbage-collected.h +106 -0
  78. package/pods/Headers/include/cppgc/heap-consistency.h +266 -0
  79. package/pods/Headers/include/cppgc/heap-state.h +82 -0
  80. package/pods/Headers/include/cppgc/heap-statistics.h +120 -0
  81. package/pods/Headers/include/cppgc/heap.h +206 -0
  82. package/pods/Headers/include/cppgc/internal/api-constants.h +55 -0
  83. package/pods/Headers/include/cppgc/internal/atomic-entry-flag.h +48 -0
  84. package/pods/Headers/include/cppgc/internal/caged-heap-local-data.h +79 -0
  85. package/pods/Headers/include/cppgc/internal/compiler-specific.h +38 -0
  86. package/pods/Headers/include/cppgc/internal/finalizer-trait.h +93 -0
  87. package/pods/Headers/include/cppgc/internal/gc-info.h +156 -0
  88. package/pods/Headers/include/cppgc/internal/logging.h +50 -0
  89. package/pods/Headers/include/cppgc/internal/name-trait.h +122 -0
  90. package/pods/Headers/include/cppgc/internal/persistent-node.h +216 -0
  91. package/pods/Headers/include/cppgc/internal/pointer-policies.h +186 -0
  92. package/pods/Headers/include/cppgc/internal/write-barrier.h +435 -0
  93. package/pods/Headers/include/cppgc/liveness-broker.h +77 -0
  94. package/pods/Headers/include/cppgc/macros.h +26 -0
  95. package/pods/Headers/include/cppgc/member.h +291 -0
  96. package/pods/Headers/include/cppgc/name-provider.h +65 -0
  97. package/pods/Headers/include/cppgc/object-size-trait.h +58 -0
  98. package/pods/Headers/include/cppgc/persistent.h +370 -0
  99. package/pods/Headers/include/cppgc/platform.h +156 -0
  100. package/pods/Headers/include/cppgc/prefinalizer.h +75 -0
  101. package/pods/Headers/include/cppgc/process-heap-statistics.h +36 -0
  102. package/pods/Headers/include/cppgc/sentinel-pointer.h +32 -0
  103. package/pods/Headers/include/cppgc/source-location.h +92 -0
  104. package/pods/Headers/include/cppgc/testing.h +106 -0
  105. package/pods/Headers/include/cppgc/trace-trait.h +116 -0
  106. package/pods/Headers/include/cppgc/type-traits.h +240 -0
  107. package/pods/Headers/include/cppgc/visitor.h +379 -0
  108. package/pods/Headers/include/js_protocol-1.2.json +936 -0
  109. package/pods/Headers/include/js_protocol-1.3.json +1112 -0
  110. package/pods/Headers/include/js_protocol.pdl +1709 -0
  111. package/pods/Headers/include/libffi/arm64/ffi.h +524 -0
  112. package/pods/Headers/include/libffi/arm64/ffitarget.h +92 -0
  113. package/pods/Headers/include/libffi/x86_64/ffi.h +524 -0
  114. package/pods/Headers/include/libffi/x86_64/ffitarget.h +147 -0
  115. package/pods/Headers/include/libffi.h +12 -0
  116. package/pods/Headers/include/libplatform/DEPS +9 -0
  117. package/pods/Headers/include/libplatform/libplatform-export.h +29 -0
  118. package/pods/Headers/include/libplatform/libplatform.h +106 -0
  119. package/pods/Headers/include/libplatform/v8-tracing.h +333 -0
  120. package/pods/Headers/include/v8-array-buffer.h +433 -0
  121. package/pods/Headers/include/v8-callbacks.h +397 -0
  122. package/pods/Headers/include/v8-container.h +129 -0
  123. package/pods/Headers/include/v8-context.h +407 -0
  124. package/pods/Headers/include/v8-cppgc.h +215 -0
  125. package/pods/Headers/include/v8-data.h +80 -0
  126. package/pods/Headers/include/v8-date.h +43 -0
  127. package/pods/Headers/include/v8-debug.h +168 -0
  128. package/pods/Headers/include/v8-embedder-heap.h +218 -0
  129. package/pods/Headers/include/v8-embedder-state-scope.h +51 -0
  130. package/pods/Headers/include/v8-exception.h +217 -0
  131. package/pods/Headers/include/v8-extension.h +62 -0
  132. package/pods/Headers/include/v8-external.h +37 -0
  133. package/pods/Headers/include/v8-fast-api-calls.h +939 -0
  134. package/pods/Headers/include/v8-forward.h +81 -0
  135. package/pods/Headers/include/v8-function-callback.h +475 -0
  136. package/pods/Headers/include/v8-function.h +125 -0
  137. package/pods/Headers/include/v8-initialization.h +315 -0
  138. package/pods/Headers/include/v8-inspector-protocol.h +13 -0
  139. package/pods/Headers/include/v8-inspector.h +376 -0
  140. package/pods/Headers/include/v8-internal.h +661 -0
  141. package/pods/Headers/include/v8-isolate.h +1709 -0
  142. package/pods/Headers/include/v8-json.h +47 -0
  143. package/pods/Headers/include/v8-local-handle.h +455 -0
  144. package/pods/Headers/include/v8-locker.h +149 -0
  145. package/pods/Headers/include/v8-maybe.h +137 -0
  146. package/pods/Headers/include/v8-memory-span.h +43 -0
  147. package/pods/Headers/include/v8-message.h +216 -0
  148. package/pods/Headers/include/v8-metrics.h +255 -0
  149. package/pods/Headers/include/v8-microtask-queue.h +152 -0
  150. package/pods/Headers/include/v8-microtask.h +28 -0
  151. package/pods/Headers/include/v8-object.h +775 -0
  152. package/pods/Headers/include/v8-persistent-handle.h +590 -0
  153. package/pods/Headers/include/v8-platform.h +1092 -0
  154. package/pods/Headers/include/v8-primitive-object.h +118 -0
  155. package/pods/Headers/include/v8-primitive.h +866 -0
  156. package/pods/Headers/include/v8-profiler.h +1198 -0
  157. package/pods/Headers/include/v8-promise.h +174 -0
  158. package/pods/Headers/include/v8-proxy.h +50 -0
  159. package/pods/Headers/include/v8-regexp.h +105 -0
  160. package/pods/Headers/include/v8-script.h +748 -0
  161. package/pods/Headers/include/v8-snapshot.h +196 -0
  162. package/pods/Headers/include/v8-statistics.h +217 -0
  163. package/pods/Headers/include/v8-template.h +1079 -0
  164. package/pods/Headers/include/v8-traced-handle.h +420 -0
  165. package/pods/Headers/include/v8-typed-array.h +282 -0
  166. package/pods/Headers/include/v8-unwinder-state.h +31 -0
  167. package/pods/Headers/include/v8-unwinder.h +132 -0
  168. package/pods/Headers/include/v8-util.h +658 -0
  169. package/pods/Headers/include/v8-value-serializer-version.h +24 -0
  170. package/pods/Headers/include/v8-value-serializer.h +279 -0
  171. package/pods/Headers/include/v8-value.h +526 -0
  172. package/pods/Headers/include/v8-version-string.h +38 -0
  173. package/pods/Headers/include/v8-version.h +20 -0
  174. package/pods/Headers/include/v8-wasm-trap-handler-posix.h +31 -0
  175. package/pods/Headers/include/v8-wasm-trap-handler-win.h +28 -0
  176. package/pods/Headers/include/v8-wasm.h +257 -0
  177. package/pods/Headers/include/v8-weak-callback-info.h +86 -0
  178. package/pods/Headers/include/v8.h +88 -0
  179. package/pods/Headers/include/v8config.h +605 -0
  180. package/pods/Headers/inspector/InspectorServer.h +20 -0
  181. package/pods/Headers/inspector/JsV8InspectorClient.h +66 -0
  182. package/pods/Headers/inspector/base/trace_event/common/trace_event_common.h +1123 -0
  183. package/pods/Headers/inspector/base64.h +9 -0
  184. package/pods/Headers/inspector/src/base/address-region.h +95 -0
  185. package/pods/Headers/inspector/src/base/atomic-utils.h +219 -0
  186. package/pods/Headers/inspector/src/base/atomicops.h +332 -0
  187. package/pods/Headers/inspector/src/base/atomicops_internals_atomicword_compat.h +89 -0
  188. package/pods/Headers/inspector/src/base/base-export.h +31 -0
  189. package/pods/Headers/inspector/src/base/bits.h +343 -0
  190. package/pods/Headers/inspector/src/base/build_config.h +234 -0
  191. package/pods/Headers/inspector/src/base/compiler-specific.h +136 -0
  192. package/pods/Headers/inspector/src/base/export-template.h +163 -0
  193. package/pods/Headers/inspector/src/base/flags.h +130 -0
  194. package/pods/Headers/inspector/src/base/immediate-crash.h +162 -0
  195. package/pods/Headers/inspector/src/base/lazy-instance.h +258 -0
  196. package/pods/Headers/inspector/src/base/logging.h +417 -0
  197. package/pods/Headers/inspector/src/base/macros.h +423 -0
  198. package/pods/Headers/inspector/src/base/memory.h +89 -0
  199. package/pods/Headers/inspector/src/base/once.h +108 -0
  200. package/pods/Headers/inspector/src/base/optional.h +882 -0
  201. package/pods/Headers/inspector/src/base/platform/mutex.h +370 -0
  202. package/pods/Headers/inspector/src/base/platform/platform.h +476 -0
  203. package/pods/Headers/inspector/src/base/platform/semaphore.h +108 -0
  204. package/pods/Headers/inspector/src/base/platform/v8-time.h +513 -0
  205. package/pods/Headers/inspector/src/base/platform/wrappers.h +73 -0
  206. package/pods/Headers/inspector/src/base/safe_conversions.h +389 -0
  207. package/pods/Headers/inspector/src/base/safe_conversions_impl.h +822 -0
  208. package/pods/Headers/inspector/src/base/template-utils.h +113 -0
  209. package/pods/Headers/inspector/src/base/v8-fallthrough.h +21 -0
  210. package/pods/Headers/inspector/src/common/checks.h +38 -0
  211. package/pods/Headers/inspector/src/common/globals.h +1842 -0
  212. package/pods/Headers/inspector/src/debug/debug-interface.h +667 -0
  213. package/pods/Headers/inspector/src/debug/interface-types.h +175 -0
  214. package/pods/Headers/inspector/src/init/v8.h +52 -0
  215. package/pods/Headers/inspector/src/inspector/custom-preview.h +24 -0
  216. package/pods/Headers/inspector/src/inspector/injected-script.h +251 -0
  217. package/pods/Headers/inspector/src/inspector/inspected-context.h +79 -0
  218. package/pods/Headers/inspector/src/inspector/protocol/CSS.h +2148 -0
  219. package/pods/Headers/inspector/src/inspector/protocol/Console.h +211 -0
  220. package/pods/Headers/inspector/src/inspector/protocol/DOM.h +1008 -0
  221. package/pods/Headers/inspector/src/inspector/protocol/Debugger.h +892 -0
  222. package/pods/Headers/inspector/src/inspector/protocol/Forward.h +75 -0
  223. package/pods/Headers/inspector/src/inspector/protocol/HeapProfiler.h +346 -0
  224. package/pods/Headers/inspector/src/inspector/protocol/Log.h +342 -0
  225. package/pods/Headers/inspector/src/inspector/protocol/Network.h +2528 -0
  226. package/pods/Headers/inspector/src/inspector/protocol/Overlay.h +281 -0
  227. package/pods/Headers/inspector/src/inspector/protocol/Page.h +1189 -0
  228. package/pods/Headers/inspector/src/inspector/protocol/Profiler.h +1001 -0
  229. package/pods/Headers/inspector/src/inspector/protocol/Protocol.h +617 -0
  230. package/pods/Headers/inspector/src/inspector/protocol/Runtime.h +1696 -0
  231. package/pods/Headers/inspector/src/inspector/protocol/Schema.h +146 -0
  232. package/pods/Headers/inspector/src/inspector/protocol/Security.h +793 -0
  233. package/pods/Headers/inspector/src/inspector/remote-object-id.h +54 -0
  234. package/pods/Headers/inspector/src/inspector/search-util.h +26 -0
  235. package/pods/Headers/inspector/src/inspector/string-16.h +180 -0
  236. package/pods/Headers/inspector/src/inspector/string-util.h +128 -0
  237. package/pods/Headers/inspector/src/inspector/v8-console-agent-impl.h +48 -0
  238. package/pods/Headers/inspector/src/inspector/v8-console-message.h +147 -0
  239. package/pods/Headers/inspector/src/inspector/v8-console.h +173 -0
  240. package/pods/Headers/inspector/src/inspector/v8-css-agent-impl.h +62 -0
  241. package/pods/Headers/inspector/src/inspector/v8-debugger-agent-impl.h +248 -0
  242. package/pods/Headers/inspector/src/inspector/v8-debugger-id.h +44 -0
  243. package/pods/Headers/inspector/src/inspector/v8-debugger-script.h +123 -0
  244. package/pods/Headers/inspector/src/inspector/v8-debugger.h +257 -0
  245. package/pods/Headers/inspector/src/inspector/v8-dom-agent-impl.h +91 -0
  246. package/pods/Headers/inspector/src/inspector/v8-heap-profiler-agent-impl.h +80 -0
  247. package/pods/Headers/inspector/src/inspector/v8-inspector-impl.h +191 -0
  248. package/pods/Headers/inspector/src/inspector/v8-inspector-session-impl.h +156 -0
  249. package/pods/Headers/inspector/src/inspector/v8-log-agent-impl.h +34 -0
  250. package/pods/Headers/inspector/src/inspector/v8-network-agent-impl.h +71 -0
  251. package/pods/Headers/inspector/src/inspector/v8-ns-debugger-agent-impl.h +24 -0
  252. package/pods/Headers/inspector/src/inspector/v8-overlay-agent-impl.h +70 -0
  253. package/pods/Headers/inspector/src/inspector/v8-page-agent-impl.h +88 -0
  254. package/pods/Headers/inspector/src/inspector/v8-profiler-agent-impl.h +104 -0
  255. package/pods/Headers/inspector/src/inspector/v8-regex.h +38 -0
  256. package/pods/Headers/inspector/src/inspector/v8-runtime-agent-impl.h +157 -0
  257. package/pods/Headers/inspector/src/inspector/v8-schema-agent-impl.h +38 -0
  258. package/pods/Headers/inspector/src/inspector/v8-stack-trace-impl.h +164 -0
  259. package/pods/Headers/inspector/src/inspector/v8-string-conversions.h +17 -0
  260. package/pods/Headers/inspector/src/inspector/v8-value-utils.h +23 -0
  261. package/pods/Headers/inspector/src/inspector/value-mirror.h +87 -0
  262. package/pods/Headers/inspector/src/libplatform/default-platform.h +92 -0
  263. package/pods/Headers/inspector/src/logging/tracing-flags.h +50 -0
  264. package/pods/Headers/inspector/src/numbers/conversions.h +183 -0
  265. package/pods/Headers/inspector/src/tracing/trace-event.h +664 -0
  266. package/pods/Headers/inspector/src/utils/allocation.h +367 -0
  267. package/pods/Headers/inspector/src/utils/vector.h +324 -0
  268. package/pods/Headers/inspector/third_party/inspector_protocol/crdtp/cbor.h +305 -0
  269. package/pods/Headers/inspector/third_party/inspector_protocol/crdtp/dispatch.h +314 -0
  270. package/pods/Headers/inspector/third_party/inspector_protocol/crdtp/error_support.h +62 -0
  271. package/pods/Headers/inspector/third_party/inspector_protocol/crdtp/export.h +6 -0
  272. package/pods/Headers/inspector/third_party/inspector_protocol/crdtp/find_by_first.h +58 -0
  273. package/pods/Headers/inspector/third_party/inspector_protocol/crdtp/frontend_channel.h +47 -0
  274. package/pods/Headers/inspector/third_party/inspector_protocol/crdtp/glue.h +80 -0
  275. package/pods/Headers/inspector/third_party/inspector_protocol/crdtp/json.h +52 -0
  276. package/pods/Headers/inspector/third_party/inspector_protocol/crdtp/json_platform.h +26 -0
  277. package/pods/Headers/inspector/third_party/inspector_protocol/crdtp/maybe.h +104 -0
  278. package/pods/Headers/inspector/third_party/inspector_protocol/crdtp/parser_handler.h +39 -0
  279. package/pods/Headers/inspector/third_party/inspector_protocol/crdtp/protocol_core.h +406 -0
  280. package/pods/Headers/inspector/third_party/inspector_protocol/crdtp/serializable.h +32 -0
  281. package/pods/Headers/inspector/third_party/inspector_protocol/crdtp/serializer_traits.h +158 -0
  282. package/pods/Headers/inspector/third_party/inspector_protocol/crdtp/span.h +99 -0
  283. package/pods/Headers/inspector/third_party/inspector_protocol/crdtp/status.h +139 -0
  284. package/pods/Headers/inspector/utils.h +32 -0
  285. package/pods/Headers/inspector/v8-inspector-platform.h +44 -0
  286. package/pods/Headers/jsi/decorator.h +762 -0
  287. package/pods/Headers/jsi/instrumentation.h +117 -0
  288. package/pods/Headers/jsi/jsi-inl.h +322 -0
  289. package/pods/Headers/jsi/jsi.h +1387 -0
  290. package/pods/Headers/jsi/jsilib.h +59 -0
  291. package/pods/Headers/jsi/threadsafe.h +79 -0
  292. package/pods/Headers/runtime/ArgConverter.h +61 -0
  293. package/pods/Headers/runtime/ArrayAdapter.h +13 -0
  294. package/pods/Headers/runtime/Caches.h +98 -0
  295. package/pods/Headers/runtime/ClassBuilder.h +61 -0
  296. package/pods/Headers/runtime/Common.h +9 -0
  297. package/pods/Headers/runtime/ConcurrentMap.h +55 -0
  298. package/pods/Headers/runtime/ConcurrentQueue.h +28 -0
  299. package/pods/Headers/runtime/Console.h +27 -0
  300. package/pods/Headers/runtime/Constants.h +15 -0
  301. package/pods/Headers/runtime/DataWrapper.h +671 -0
  302. package/pods/Headers/runtime/DictionaryAdapter.h +13 -0
  303. package/pods/Headers/runtime/ExtVector.h +21 -0
  304. package/pods/Headers/runtime/FFICall.h +105 -0
  305. package/pods/Headers/runtime/FastEnumerationAdapter.h +13 -0
  306. package/pods/Headers/runtime/FunctionReference.h +18 -0
  307. package/pods/Headers/runtime/Helpers.h +84 -0
  308. package/pods/Headers/runtime/InlineFunctions.h +16 -0
  309. package/pods/Headers/runtime/Interop.h +202 -0
  310. package/pods/Headers/runtime/KnownUnknownClassPair.h +35 -0
  311. package/pods/Headers/runtime/Metadata.h +981 -0
  312. package/pods/Headers/runtime/MetadataBuilder.h +72 -0
  313. package/pods/Headers/runtime/MetadataInlines.h +157 -0
  314. package/pods/Headers/runtime/ModuleInternal.h +59 -0
  315. package/pods/Headers/runtime/NSDataAdapter.h +13 -0
  316. package/pods/Headers/runtime/NativeScriptException.h +27 -0
  317. package/pods/Headers/runtime/ObjectManager.h +31 -0
  318. package/pods/Headers/runtime/OneByteStringResource.h +21 -0
  319. package/pods/Headers/runtime/Pointer.h +26 -0
  320. package/pods/Headers/runtime/PromiseProxy.h +15 -0
  321. package/pods/Headers/runtime/Reference.h +38 -0
  322. package/pods/Headers/runtime/Runtime.h +67 -0
  323. package/pods/Headers/runtime/RuntimeConfig.h +17 -0
  324. package/pods/Headers/runtime/SetTimeout.h +34 -0
  325. package/pods/Headers/runtime/SimpleAllocator.h +23 -0
  326. package/pods/Headers/runtime/StringHasher.h +315 -0
  327. package/pods/Headers/runtime/SymbolIterator.h +18 -0
  328. package/pods/Headers/runtime/SymbolLoader.h +27 -0
  329. package/pods/Headers/runtime/TNSDerivedClass.h +8 -0
  330. package/pods/Headers/runtime/TSHelpers.h +15 -0
  331. package/pods/Headers/runtime/Tasks.h +19 -0
  332. package/pods/Headers/runtime/UnmanagedType.h +21 -0
  333. package/pods/Headers/runtime/WeakRef.h +15 -0
  334. package/pods/Headers/runtime/Worker.h +26 -0
  335. package/pods/Headers/runtime/robin_hood.h +2184 -0
  336. package/pods/Headers/v8runtime/HostProxy.h +71 -0
  337. package/pods/Headers/v8runtime/JSIV8ValueConverter.h +70 -0
  338. package/pods/Headers/v8runtime/V8PointerValue.h +44 -0
  339. package/pods/Headers/v8runtime/V8Runtime.h +215 -0
  340. package/pods/Headers/v8runtime/V8RuntimeConfig.h +26 -0
  341. package/pods/Headers/v8runtime/V8RuntimeFactory.h +21 -0
  342. package/pods/NativeScript.podspec +68 -0
  343. package/platforms/ios/Mason.xcframework/ios-arm64_x86_64-simulator/Mason.framework/PrivateHeaders/mason_native.h +0 -676
  344. package/platforms/ios/src/JSIModule.h +0 -217
  345. package/platforms/ios/src/JSIModule.mm +0 -2788
@@ -0,0 +1,305 @@
1
+ // Copyright 2019 The Chromium Authors. All rights reserved.
2
+ // Use of this source code is governed by a BSD-style license that can be
3
+ // found in the LICENSE file.
4
+
5
+ #ifndef V8_CRDTP_CBOR_H_
6
+ #define V8_CRDTP_CBOR_H_
7
+
8
+ #include <cstddef>
9
+ #include <cstdint>
10
+ #include <memory>
11
+ #include <string>
12
+ #include <vector>
13
+
14
+ #include "export.h"
15
+ #include "parser_handler.h"
16
+ #include "span.h"
17
+
18
+ namespace v8_crdtp {
19
+ namespace cbor {
20
+ // The binary encoding for the inspector protocol follows the CBOR specification
21
+ // (RFC 7049). Additional constraints:
22
+ // - Only indefinite length maps and arrays are supported.
23
+ // - Maps and arrays are wrapped with an envelope, that is, a
24
+ // CBOR tag with value 24 followed by a byte string specifying
25
+ // the byte length of the enclosed map / array. The byte string
26
+ // must use a 32 bit wide length.
27
+ // - At the top level, a message must be an indefinite length map
28
+ // wrapped by an envelope.
29
+ // - Maximal size for messages is 2^32 (4 GB).
30
+ // - For scalars, we support only the int32_t range, encoded as
31
+ // UNSIGNED/NEGATIVE (major types 0 / 1).
32
+ // - UTF16 strings, including with unbalanced surrogate pairs, are encoded
33
+ // as CBOR BYTE_STRING (major type 2). For such strings, the number of
34
+ // bytes encoded must be even.
35
+ // - UTF8 strings (major type 3) are supported.
36
+ // - 7 bit US-ASCII strings must always be encoded as UTF8 strings, never
37
+ // as UTF16 strings.
38
+ // - Arbitrary byte arrays, in the inspector protocol called 'binary',
39
+ // are encoded as BYTE_STRING (major type 2), prefixed with a byte
40
+ // indicating base64 when rendered as JSON.
41
+
42
+ // =============================================================================
43
+ // Detecting CBOR content
44
+ // =============================================================================
45
+
46
+ // The first byte for an envelope, which we use for wrapping dictionaries
47
+ // and arrays; and the byte that indicates a byte string with 32 bit length.
48
+ // These two bytes start an envelope, and thereby also any CBOR message
49
+ // produced or consumed by this protocol. See also |EnvelopeEncoder| below.
50
+ uint8_t InitialByteForEnvelope();
51
+ uint8_t InitialByteFor32BitLengthByteString();
52
+
53
+ // Checks whether |msg| is a cbor message.
54
+ bool IsCBORMessage(span<uint8_t> msg);
55
+
56
+ // Performs a leightweight check of |msg|.
57
+ // Disallows:
58
+ // - Empty message
59
+ // - Not starting with the two bytes 0xd8, 0x5a
60
+ // - Empty envelope (all length bytes are 0)
61
+ // - Not starting with a map after the envelope stanza
62
+ // DevTools messages should pass this check.
63
+ Status CheckCBORMessage(span<uint8_t> msg);
64
+
65
+ // =============================================================================
66
+ // Encoding individual CBOR items
67
+ // =============================================================================
68
+
69
+ // Some constants for CBOR tokens that only take a single byte on the wire.
70
+ uint8_t EncodeTrue();
71
+ uint8_t EncodeFalse();
72
+ uint8_t EncodeNull();
73
+ uint8_t EncodeIndefiniteLengthArrayStart();
74
+ uint8_t EncodeIndefiniteLengthMapStart();
75
+ uint8_t EncodeStop();
76
+
77
+ // Encodes |value| as |UNSIGNED| (major type 0) iff >= 0, or |NEGATIVE|
78
+ // (major type 1) iff < 0.
79
+ void EncodeInt32(int32_t value, std::vector<uint8_t>* out);
80
+
81
+ // Encodes a UTF16 string as a BYTE_STRING (major type 2). Each utf16
82
+ // character in |in| is emitted with most significant byte first,
83
+ // appending to |out|.
84
+ void EncodeString16(span<uint16_t> in, std::vector<uint8_t>* out);
85
+
86
+ // Encodes a UTF8 string |in| as STRING (major type 3).
87
+ void EncodeString8(span<uint8_t> in, std::vector<uint8_t>* out);
88
+
89
+ // Encodes the given |latin1| string as STRING8.
90
+ // If any non-ASCII character is present, it will be represented
91
+ // as a 2 byte UTF8 sequence.
92
+ void EncodeFromLatin1(span<uint8_t> latin1, std::vector<uint8_t>* out);
93
+
94
+ // Encodes the given |utf16| string as STRING8 if it's entirely US-ASCII.
95
+ // Otherwise, encodes as STRING16.
96
+ void EncodeFromUTF16(span<uint16_t> utf16, std::vector<uint8_t>* out);
97
+
98
+ // Encodes arbitrary binary data in |in| as a BYTE_STRING (major type 2) with
99
+ // definitive length, prefixed with tag 22 indicating expected conversion to
100
+ // base64 (see RFC 7049, Table 3 and Section 2.4.4.2).
101
+ void EncodeBinary(span<uint8_t> in, std::vector<uint8_t>* out);
102
+
103
+ // Encodes / decodes a double as Major type 7 (SIMPLE_VALUE),
104
+ // with additional info = 27, followed by 8 bytes in big endian.
105
+ void EncodeDouble(double value, std::vector<uint8_t>* out);
106
+
107
+ // =============================================================================
108
+ // cbor::EnvelopeEncoder - for wrapping submessages
109
+ // =============================================================================
110
+
111
+ // An envelope indicates the byte length of a wrapped item.
112
+ // We use this for maps and array, which allows the decoder
113
+ // to skip such (nested) values whole sale.
114
+ // It's implemented as a CBOR tag (major type 6) with additional
115
+ // info = 24, followed by a byte string with a 32 bit length value;
116
+ // so the maximal structure that we can wrap is 2^32 bits long.
117
+ // See also: https://tools.ietf.org/html/rfc7049#section-2.4.4.1
118
+ class EnvelopeEncoder {
119
+ public:
120
+ // Emits the envelope start bytes and records the position for the
121
+ // byte size in |byte_size_pos_|. Also emits empty bytes for the
122
+ // byte sisze so that encoding can continue.
123
+ void EncodeStart(std::vector<uint8_t>* out);
124
+ // This records the current size in |out| at position byte_size_pos_.
125
+ // Returns true iff successful.
126
+ bool EncodeStop(std::vector<uint8_t>* out);
127
+
128
+ private:
129
+ size_t byte_size_pos_ = 0;
130
+ };
131
+
132
+ // =============================================================================
133
+ // cbor::NewCBOREncoder - for encoding from a streaming parser
134
+ // =============================================================================
135
+
136
+ // This can be used to convert to CBOR, by passing the return value to a parser
137
+ // that drives it. The handler will encode into |out|, and iff an error occurs
138
+ // it will set |status| to an error and clear |out|. Otherwise, |status.ok()|
139
+ // will be |true|.
140
+ std::unique_ptr<ParserHandler> NewCBOREncoder(std::vector<uint8_t>* out,
141
+ Status* status);
142
+
143
+ // =============================================================================
144
+ // cbor::CBORTokenizer - for parsing individual CBOR items
145
+ // =============================================================================
146
+
147
+ // Tags for the tokens within a CBOR message that CBORTokenizer understands.
148
+ // Note that this is not the same terminology as the CBOR spec (RFC 7049),
149
+ // but rather, our adaptation. For instance, we lump unsigned and signed
150
+ // major type into INT32 here (and disallow values outside the int32_t range).
151
+ enum class CBORTokenTag {
152
+ // Encountered an error in the structure of the message. Consult
153
+ // status() for details.
154
+ ERROR_VALUE,
155
+ // Booleans and NULL.
156
+ TRUE_VALUE,
157
+ FALSE_VALUE,
158
+ NULL_VALUE,
159
+ // An int32_t (signed 32 bit integer).
160
+ INT32,
161
+ // A double (64 bit floating point).
162
+ DOUBLE,
163
+ // A UTF8 string.
164
+ STRING8,
165
+ // A UTF16 string.
166
+ STRING16,
167
+ // A binary string.
168
+ BINARY,
169
+ // Starts an indefinite length map; after the map start we expect
170
+ // alternating keys and values, followed by STOP.
171
+ MAP_START,
172
+ // Starts an indefinite length array; after the array start we
173
+ // expect values, followed by STOP.
174
+ ARRAY_START,
175
+ // Ends a map or an array.
176
+ STOP,
177
+ // An envelope indicator, wrapping a map or array.
178
+ // Internally this carries the byte length of the wrapped
179
+ // map or array. While CBORTokenizer::Next() will read / skip the entire
180
+ // envelope, CBORTokenizer::EnterEnvelope() reads the tokens
181
+ // inside of it.
182
+ ENVELOPE,
183
+ // We've reached the end there is nothing else to read.
184
+ DONE,
185
+ };
186
+
187
+ // The major types from RFC 7049 Section 2.1.
188
+ enum class MajorType {
189
+ UNSIGNED = 0,
190
+ NEGATIVE = 1,
191
+ BYTE_STRING = 2,
192
+ STRING = 3,
193
+ ARRAY = 4,
194
+ MAP = 5,
195
+ TAG = 6,
196
+ SIMPLE_VALUE = 7
197
+ };
198
+
199
+ // CBORTokenizer segments a CBOR message, presenting the tokens therein as
200
+ // numbers, strings, etc. This is not a complete CBOR parser, but makes it much
201
+ // easier to implement one (e.g. ParseCBOR, above). It can also be used to parse
202
+ // messages partially.
203
+ class CBORTokenizer {
204
+ public:
205
+ explicit CBORTokenizer(span<uint8_t> bytes);
206
+ ~CBORTokenizer();
207
+
208
+ // Identifies the current token that we're looking at,
209
+ // or ERROR_VALUE (in which ase ::Status() has details)
210
+ // or DONE (if we're past the last token).
211
+ CBORTokenTag TokenTag() const;
212
+
213
+ // Advances to the next token.
214
+ void Next();
215
+ // Can only be called if TokenTag() == CBORTokenTag::ENVELOPE.
216
+ // While Next() would skip past the entire envelope / what it's
217
+ // wrapping, EnterEnvelope positions the cursor inside of the envelope,
218
+ // letting the client explore the nested structure.
219
+ void EnterEnvelope();
220
+
221
+ // If TokenTag() is CBORTokenTag::ERROR_VALUE, then Status().error describes
222
+ // the error more precisely; otherwise it'll be set to Error::OK.
223
+ // In either case, Status().pos is the current position.
224
+ struct Status Status() const;
225
+
226
+ // The following methods retrieve the token values. They can only
227
+ // be called if TokenTag() matches.
228
+
229
+ // To be called only if ::TokenTag() == CBORTokenTag::INT32.
230
+ int32_t GetInt32() const;
231
+
232
+ // To be called only if ::TokenTag() == CBORTokenTag::DOUBLE.
233
+ double GetDouble() const;
234
+
235
+ // To be called only if ::TokenTag() == CBORTokenTag::STRING8.
236
+ span<uint8_t> GetString8() const;
237
+
238
+ // Wire representation for STRING16 is low byte first (little endian).
239
+ // To be called only if ::TokenTag() == CBORTokenTag::STRING16.
240
+ span<uint8_t> GetString16WireRep() const;
241
+
242
+ // To be called only if ::TokenTag() == CBORTokenTag::BINARY.
243
+ span<uint8_t> GetBinary() const;
244
+
245
+ // To be called only if ::TokenTag() == CBORTokenTag::ENVELOPE.
246
+ // Returns the envelope including its payload; message which
247
+ // can be passed to the CBORTokenizer constructor, which will
248
+ // then see the envelope token first (looking at it a second time,
249
+ // basically).
250
+ span<uint8_t> GetEnvelope() const;
251
+
252
+ // To be called only if ::TokenTag() == CBORTokenTag::ENVELOPE.
253
+ // Returns only the payload inside the envelope, e.g., a map
254
+ // or an array. This is not a complete message by our
255
+ // IsCBORMessage definition, since it doesn't include the
256
+ // enclosing envelope (the header, basically).
257
+ span<uint8_t> GetEnvelopeContents() const;
258
+
259
+ private:
260
+ void ReadNextToken(bool enter_envelope);
261
+ void SetToken(CBORTokenTag token, size_t token_byte_length);
262
+ void SetError(Error error);
263
+
264
+ span<uint8_t> bytes_;
265
+ CBORTokenTag token_tag_;
266
+ struct Status status_;
267
+ size_t token_byte_length_;
268
+ MajorType token_start_type_;
269
+ uint64_t token_start_internal_value_;
270
+ };
271
+
272
+ // =============================================================================
273
+ // cbor::ParseCBOR - for receiving streaming parser events for CBOR messages
274
+ // =============================================================================
275
+
276
+ // Parses a CBOR encoded message from |bytes|, sending events to
277
+ // |out|. If an error occurs, sends |out->HandleError|, and parsing stops.
278
+ // The client is responsible for discarding the already received information in
279
+ // that case.
280
+ void ParseCBOR(span<uint8_t> bytes, ParserHandler* out);
281
+
282
+ // =============================================================================
283
+ // cbor::AppendString8EntryToMap - for limited in-place editing of messages
284
+ // =============================================================================
285
+
286
+ // Modifies the |cbor| message by appending a new key/value entry at the end
287
+ // of the map. Patches up the envelope size; Status.ok() iff successful.
288
+ // If not successful, |cbor| may be corrupted after this call.
289
+ Status AppendString8EntryToCBORMap(span<uint8_t> string8_key,
290
+ span<uint8_t> string8_value,
291
+ std::vector<uint8_t>* cbor);
292
+
293
+ namespace internals { // Exposed only for writing tests.
294
+ size_t ReadTokenStart(span<uint8_t> bytes,
295
+ cbor::MajorType* type,
296
+ uint64_t* value);
297
+
298
+ void WriteTokenStart(cbor::MajorType type,
299
+ uint64_t value,
300
+ std::vector<uint8_t>* encoded);
301
+ } // namespace internals
302
+ } // namespace cbor
303
+ } // namespace v8_crdtp
304
+
305
+ #endif // V8_CRDTP_CBOR_H_
@@ -0,0 +1,314 @@
1
+ // Copyright 2020 The Chromium Authors. All rights reserved.
2
+ // Use of this source code is governed by a BSD-style license that can be
3
+ // found in the LICENSE file.
4
+
5
+ #ifndef V8_CRDTP_DISPATCH_H_
6
+ #define V8_CRDTP_DISPATCH_H_
7
+
8
+ #include <cassert>
9
+ #include <cstdint>
10
+ #include <functional>
11
+ #include <string>
12
+ #include <unordered_set>
13
+ #include "export.h"
14
+ #include "serializable.h"
15
+ #include "span.h"
16
+ #include "status.h"
17
+
18
+ namespace v8_crdtp {
19
+ class DeserializerState;
20
+ class ErrorSupport;
21
+ class FrontendChannel;
22
+ namespace cbor {
23
+ class CBORTokenizer;
24
+ } // namespace cbor
25
+
26
+ // =============================================================================
27
+ // DispatchResponse - Error status and chaining / fall through
28
+ // =============================================================================
29
+ enum class DispatchCode {
30
+ SUCCESS = 1,
31
+ FALL_THROUGH = 2,
32
+ // For historical reasons, these error codes correspond to commonly used
33
+ // XMLRPC codes (e.g. see METHOD_NOT_FOUND in
34
+ // https://github.com/python/cpython/blob/master/Lib/xmlrpc/client.py).
35
+ PARSE_ERROR = -32700,
36
+ INVALID_REQUEST = -32600,
37
+ METHOD_NOT_FOUND = -32601,
38
+ INVALID_PARAMS = -32602,
39
+ INTERNAL_ERROR = -32603,
40
+ SERVER_ERROR = -32000,
41
+ };
42
+
43
+ // Information returned by command handlers. Usually returned after command
44
+ // execution attempts.
45
+ class DispatchResponse {
46
+ public:
47
+ const std::string& Message() const { return message_; }
48
+
49
+ DispatchCode Code() const { return code_; }
50
+
51
+ bool IsSuccess() const { return code_ == DispatchCode::SUCCESS; }
52
+ bool IsFallThrough() const { return code_ == DispatchCode::FALL_THROUGH; }
53
+ bool IsError() const { return code_ < DispatchCode::SUCCESS; }
54
+
55
+ static DispatchResponse Success();
56
+ static DispatchResponse FallThrough();
57
+
58
+ // Indicates that a message could not be parsed. E.g., malformed JSON.
59
+ static DispatchResponse ParseError(std::string message);
60
+
61
+ // Indicates that a request is lacking required top-level properties
62
+ // ('id', 'method'), has top-level properties of the wrong type, or has
63
+ // unknown top-level properties.
64
+ static DispatchResponse InvalidRequest(std::string message);
65
+
66
+ // Indicates that a protocol method such as "Page.bringToFront" could not be
67
+ // dispatched because it's not known to the (domain) dispatcher.
68
+ static DispatchResponse MethodNotFound(std::string message);
69
+
70
+ // Indicates that the params sent to a domain handler are invalid.
71
+ static DispatchResponse InvalidParams(std::string message);
72
+
73
+ // Used for application level errors, e.g. within protocol agents.
74
+ static DispatchResponse InternalError();
75
+
76
+ // Used for application level errors, e.g. within protocol agents.
77
+ static DispatchResponse ServerError(std::string message);
78
+
79
+ private:
80
+ DispatchResponse() = default;
81
+ DispatchCode code_;
82
+ std::string message_;
83
+ };
84
+
85
+ // =============================================================================
86
+ // Dispatchable - a shallow parser for CBOR encoded DevTools messages
87
+ // =============================================================================
88
+
89
+ // This parser extracts only the known top-level fields from a CBOR encoded map;
90
+ // method, id, sessionId, and params.
91
+ class Dispatchable {
92
+ public:
93
+ // This constructor parses the |serialized| message. If successful,
94
+ // |ok()| will yield |true|, and |Method()|, |SessionId()|, |CallId()|,
95
+ // |Params()| can be used to access, the extracted contents. Otherwise,
96
+ // |ok()| will yield |false|, and |DispatchError()| can be
97
+ // used to send a response or notification to the client.
98
+ explicit Dispatchable(span<uint8_t> serialized);
99
+
100
+ // The serialized message that we just parsed.
101
+ span<uint8_t> Serialized() const { return serialized_; }
102
+
103
+ // Yields true if parsing was successful. This is cheaper than calling
104
+ // ::DispatchError().
105
+ bool ok() const;
106
+
107
+ // If !ok(), returns a DispatchResponse with appropriate code and error
108
+ // which can be sent to the client as a response or notification.
109
+ DispatchResponse DispatchError() const;
110
+
111
+ // Top level field: the command to be executed, fully qualified by
112
+ // domain. E.g. "Page.createIsolatedWorld".
113
+ span<uint8_t> Method() const { return method_; }
114
+ // Used to identify protocol connections attached to a specific
115
+ // target. See Target.attachToTarget, Target.setAutoAttach.
116
+ span<uint8_t> SessionId() const { return session_id_; }
117
+ // The call id, a sequence number that's used in responses to indicate
118
+ // the request to which the response belongs.
119
+ int32_t CallId() const { return call_id_; }
120
+ bool HasCallId() const { return has_call_id_; }
121
+ // The payload of the request in CBOR format. The |Dispatchable| parser does
122
+ // not parse into this; it only provides access to its raw contents here.
123
+ span<uint8_t> Params() const { return params_; }
124
+
125
+ private:
126
+ bool MaybeParseProperty(cbor::CBORTokenizer* tokenizer);
127
+ bool MaybeParseCallId(cbor::CBORTokenizer* tokenizer);
128
+ bool MaybeParseMethod(cbor::CBORTokenizer* tokenizer);
129
+ bool MaybeParseParams(cbor::CBORTokenizer* tokenizer);
130
+ bool MaybeParseSessionId(cbor::CBORTokenizer* tokenizer);
131
+
132
+ span<uint8_t> serialized_;
133
+
134
+ Status status_;
135
+
136
+ bool has_call_id_ = false;
137
+ int32_t call_id_;
138
+ span<uint8_t> method_;
139
+ bool params_seen_ = false;
140
+ span<uint8_t> params_;
141
+ span<uint8_t> session_id_;
142
+ };
143
+
144
+ // =============================================================================
145
+ // Helpers for creating protocol cresponses and notifications.
146
+ // =============================================================================
147
+
148
+ // The resulting notifications can be sent to a protocol client,
149
+ // usually via a FrontendChannel (see frontend_channel.h).
150
+
151
+ std::unique_ptr<Serializable> CreateErrorResponse(
152
+ int callId,
153
+ DispatchResponse dispatch_response,
154
+ const ErrorSupport* errors = nullptr);
155
+
156
+ std::unique_ptr<Serializable> CreateErrorNotification(
157
+ DispatchResponse dispatch_response);
158
+
159
+ std::unique_ptr<Serializable> CreateResponse(
160
+ int callId,
161
+ std::unique_ptr<Serializable> params);
162
+
163
+ std::unique_ptr<Serializable> CreateNotification(
164
+ const char* method,
165
+ std::unique_ptr<Serializable> params = nullptr);
166
+
167
+ // =============================================================================
168
+ // DomainDispatcher - Dispatching betwen protocol methods within a domain.
169
+ // =============================================================================
170
+
171
+ // This class is subclassed by |DomainDispatcherImpl|, which we generate per
172
+ // DevTools domain. It contains routines called from the generated code,
173
+ // e.g. ::MaybeReportInvalidParams, which are optimized for small code size.
174
+ // The most important method is ::Dispatch, which implements method dispatch
175
+ // by command name lookup.
176
+ class DomainDispatcher {
177
+ public:
178
+ class WeakPtr {
179
+ public:
180
+ explicit WeakPtr(DomainDispatcher*);
181
+ ~WeakPtr();
182
+ DomainDispatcher* get() { return dispatcher_; }
183
+ void dispose() { dispatcher_ = nullptr; }
184
+
185
+ private:
186
+ DomainDispatcher* dispatcher_;
187
+ };
188
+
189
+ class Callback {
190
+ public:
191
+ virtual ~Callback();
192
+ void dispose();
193
+
194
+ protected:
195
+ // |method| must point at static storage (a C++ string literal in practice).
196
+ Callback(std::unique_ptr<WeakPtr> backend_impl,
197
+ int call_id,
198
+ span<uint8_t> method,
199
+ span<uint8_t> message);
200
+
201
+ void sendIfActive(std::unique_ptr<Serializable> partialMessage,
202
+ const DispatchResponse& response);
203
+ void fallThroughIfActive();
204
+
205
+ private:
206
+ std::unique_ptr<WeakPtr> backend_impl_;
207
+ int call_id_;
208
+ // Subclasses of this class are instantiated from generated code which
209
+ // passes a string literal for the method name to the constructor. So the
210
+ // storage for |method| is the binary of the running process.
211
+ span<uint8_t> method_;
212
+ std::vector<uint8_t> message_;
213
+ };
214
+
215
+ explicit DomainDispatcher(FrontendChannel*);
216
+ virtual ~DomainDispatcher();
217
+
218
+ // Given a |command_name| without domain qualification, looks up the
219
+ // corresponding method. If the method is not found, returns nullptr.
220
+ // Otherwise, Returns a closure that will parse the provided
221
+ // Dispatchable.params() to a protocol object and execute the
222
+ // apprpropriate method. If the parsing fails it will issue an
223
+ // error response on the frontend channel, otherwise it will execute the
224
+ // command.
225
+ virtual std::function<void(const Dispatchable&)> Dispatch(
226
+ span<uint8_t> command_name) = 0;
227
+
228
+ // Sends a response to the client via the channel.
229
+ void sendResponse(int call_id,
230
+ const DispatchResponse&,
231
+ std::unique_ptr<Serializable> result = nullptr);
232
+
233
+ // Returns true if |errors| contains errors *and* reports these errors
234
+ // as a response on the frontend channel. Called from generated code,
235
+ // optimized for code size of the callee.
236
+ bool MaybeReportInvalidParams(const Dispatchable& dispatchable,
237
+ const ErrorSupport& errors);
238
+ bool MaybeReportInvalidParams(const Dispatchable& dispatchable,
239
+ const DeserializerState& state);
240
+
241
+ FrontendChannel* channel() { return frontend_channel_; }
242
+
243
+ void clearFrontend();
244
+
245
+ std::unique_ptr<WeakPtr> weakPtr();
246
+
247
+ private:
248
+ FrontendChannel* frontend_channel_;
249
+ std::unordered_set<WeakPtr*> weak_ptrs_;
250
+ };
251
+
252
+ // =============================================================================
253
+ // UberDispatcher - dispatches between domains (backends).
254
+ // =============================================================================
255
+ class UberDispatcher {
256
+ public:
257
+ // Return type for ::Dispatch.
258
+ class DispatchResult {
259
+ public:
260
+ DispatchResult(bool method_found, std::function<void()> runnable);
261
+
262
+ // Indicates whether the method was found, that is, it could be dispatched
263
+ // to a backend registered with this dispatcher.
264
+ bool MethodFound() const { return method_found_; }
265
+
266
+ // Runs the dispatched result. This will send the appropriate error
267
+ // responses if the method wasn't found or if something went wrong during
268
+ // parameter parsing.
269
+ void Run();
270
+
271
+ private:
272
+ bool method_found_;
273
+ std::function<void()> runnable_;
274
+ };
275
+
276
+ // |frontend_hannel| can't be nullptr.
277
+ explicit UberDispatcher(FrontendChannel* frontend_channel);
278
+ virtual ~UberDispatcher();
279
+
280
+ // Dispatches the provided |dispatchable| considering all redirects and domain
281
+ // handlers registered with this uber dispatcher. Also see |DispatchResult|.
282
+ // |dispatchable.ok()| must hold - callers must check this separately and
283
+ // deal with errors.
284
+ DispatchResult Dispatch(const Dispatchable& dispatchable) const;
285
+
286
+ // Invoked from generated code for wiring domain backends; that is,
287
+ // connecting domain handlers to an uber dispatcher.
288
+ // See <domain-namespace>::Dispatcher::Wire(UberDispatcher*,Backend*).
289
+ FrontendChannel* channel() const {
290
+ assert(frontend_channel_);
291
+ return frontend_channel_;
292
+ }
293
+
294
+ // Invoked from generated code for wiring domain backends; that is,
295
+ // connecting domain handlers to an uber dispatcher.
296
+ // See <domain-namespace>::Dispatcher::Wire(UberDispatcher*,Backend*).
297
+ void WireBackend(span<uint8_t> domain,
298
+ const std::vector<std::pair<span<uint8_t>, span<uint8_t>>>&,
299
+ std::unique_ptr<DomainDispatcher> dispatcher);
300
+
301
+ private:
302
+ DomainDispatcher* findDispatcher(span<uint8_t> method);
303
+ FrontendChannel* const frontend_channel_;
304
+ // Pairs of ascii strings of the form ("Domain1.method1","Domain2.method2")
305
+ // indicating that the first element of each pair redirects to the second.
306
+ // Sorted by first element.
307
+ std::vector<std::pair<span<uint8_t>, span<uint8_t>>> redirects_;
308
+ // Domain dispatcher instances, sorted by their domain name.
309
+ std::vector<std::pair<span<uint8_t>, std::unique_ptr<DomainDispatcher>>>
310
+ dispatchers_;
311
+ };
312
+ } // namespace v8_crdtp
313
+
314
+ #endif // V8_CRDTP_DISPATCH_H_
@@ -0,0 +1,62 @@
1
+ // Copyright 2020 The Chromium Authors. All rights reserved.
2
+ // Use of this source code is governed by a BSD-style license that can be
3
+ // found in the LICENSE file.
4
+
5
+ #ifndef V8_CRDTP_ERROR_SUPPORT_H_
6
+ #define V8_CRDTP_ERROR_SUPPORT_H_
7
+
8
+ #include <cstdint>
9
+ #include <string>
10
+ #include <vector>
11
+ #include "export.h"
12
+ #include "span.h"
13
+
14
+ namespace v8_crdtp {
15
+ // =============================================================================
16
+ // ErrorSupport - For tracking errors in tree structures.
17
+ // =============================================================================
18
+
19
+ // This abstraction is used when converting between Values and inspector
20
+ // objects, e.g. in lib/ValueConversions_{h,cc}.template. As the processing
21
+ // enters and exits a branch, we call Push / Pop. Within the branch,
22
+ // we either set the name or an index (in case we're processing the element of a
23
+ // list/vector). Only once an error is seen, the path which is now on the
24
+ // stack is materialized and prefixes the error message. E.g.,
25
+ // "foo.bar.2: some error". After error collection, ::Errors() is used to
26
+ // access the message.
27
+ class ErrorSupport {
28
+ public:
29
+ // Push / Pop operations for the path segments; after Push, either SetName or
30
+ // SetIndex must be called exactly once.
31
+ void Push();
32
+ void Pop();
33
+
34
+ // Sets the name of the current segment on the stack; e.g. a field name.
35
+ // |name| must be a C++ string literal in 7 bit US-ASCII.
36
+ void SetName(const char* name);
37
+ // Sets the index of the current segment on the stack; e.g. an array index.
38
+ void SetIndex(size_t index);
39
+
40
+ // Materializes the error internally. |error| must be a C++ string literal
41
+ // in 7 bit US-ASCII.
42
+ void AddError(const char* error);
43
+
44
+ // Returns the semicolon-separated list of errors as in 7 bit ASCII.
45
+ span<uint8_t> Errors() const;
46
+
47
+ private:
48
+ enum SegmentType { EMPTY, NAME, INDEX };
49
+ struct Segment {
50
+ SegmentType type = EMPTY;
51
+ union {
52
+ const char* name;
53
+ size_t index;
54
+ };
55
+ };
56
+ std::vector<Segment> stack_;
57
+ std::string errors_;
58
+ };
59
+
60
+ } // namespace v8_crdtp
61
+
62
+ #endif // V8_CRDTP_ERROR_SUPPORT_H_
@@ -0,0 +1,6 @@
1
+ // Copyright 2019 The Chromium Authors. All rights reserved.
2
+ // Use of this source code is governed by a BSD-style license that can be
3
+ // found in the LICENSE file.
4
+
5
+ // This file is V8 specific. It's not rolled from the upstream project.
6
+ // CRDTP doesn't export symbols from V8, so it's empty.