datadog-ruby_core_source 3.3.7 → 3.4.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (211) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.datadog.md +5 -0
  3. data/datadog-ruby_core_source.gemspec +1 -1
  4. data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/id.h +2 -0
  5. data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/error.h +26 -0
  6. data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/internal/gc.h +1 -0
  7. data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/parse.h +2 -1
  8. data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/proc.h +1 -0
  9. data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/internal/sanitizers.h +24 -36
  10. data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/prism/ast.h +10 -0
  11. data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/extension.h +1 -1
  12. data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/prism/version.h +2 -2
  13. data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/ractor_core.h +1 -0
  14. data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/rubyparser.h +3 -1
  15. data/lib/datadog/ruby_core_source/version.rb +1 -1
  16. metadata +106 -209
  17. data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/id.h +0 -347
  18. data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/internal/basic_operators.h +0 -64
  19. data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/internal/bits.h +0 -568
  20. data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/internal/encoding.h +0 -36
  21. data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/internal/fixnum.h +0 -184
  22. data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/internal/gc.h +0 -322
  23. data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/internal/imemo.h +0 -261
  24. data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/internal/io.h +0 -143
  25. data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/internal/ractor.h +0 -6
  26. data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/internal/sanitizers.h +0 -326
  27. data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/internal/string.h +0 -186
  28. data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/internal/thread.h +0 -85
  29. data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/internal/vm.h +0 -137
  30. data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/method.h +0 -255
  31. data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/prism/ast.h +0 -7524
  32. data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/prism/defines.h +0 -242
  33. data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/prism/diagnostic.h +0 -450
  34. data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/prism/prism.h +0 -336
  35. data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/prism/version.h +0 -29
  36. data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/prism_compile.h +0 -99
  37. data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/ractor_core.h +0 -382
  38. data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/rubyparser.h +0 -1350
  39. data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/thread_pthread.h +0 -168
  40. data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/vm_core.h +0 -2222
  41. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/ccan/build_assert/build_assert.h +0 -40
  42. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/ccan/check_type/check_type.h +0 -63
  43. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/ccan/container_of/container_of.h +0 -142
  44. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/ccan/list/list.h +0 -791
  45. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/ccan/str/str.h +0 -17
  46. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/id_table.h +0 -39
  47. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/array.h +0 -152
  48. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/bignum.h +0 -244
  49. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/class.h +0 -283
  50. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/cmdlineopt.h +0 -65
  51. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/compar.h +0 -29
  52. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/compile.h +0 -34
  53. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/compilers.h +0 -107
  54. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/complex.h +0 -29
  55. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/cont.h +0 -35
  56. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/dir.h +0 -16
  57. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/enc.h +0 -19
  58. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/enum.h +0 -18
  59. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/enumerator.h +0 -21
  60. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/error.h +0 -218
  61. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/eval.h +0 -33
  62. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/file.h +0 -38
  63. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/hash.h +0 -192
  64. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/inits.h +0 -47
  65. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/load.h +0 -18
  66. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/loadpath.h +0 -16
  67. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/math.h +0 -23
  68. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/missing.h +0 -19
  69. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/numeric.h +0 -274
  70. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/object.h +0 -63
  71. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/parse.h +0 -129
  72. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/proc.h +0 -30
  73. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/process.h +0 -124
  74. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/random.h +0 -17
  75. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/range.h +0 -40
  76. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/rational.h +0 -71
  77. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/re.h +0 -28
  78. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/ruby_parser.h +0 -102
  79. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/serial.h +0 -23
  80. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/signal.h +0 -24
  81. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/st.h +0 -11
  82. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/static_assert.h +0 -16
  83. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/struct.h +0 -127
  84. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/symbol.h +0 -45
  85. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/time.h +0 -34
  86. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/transcode.h +0 -23
  87. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/util.h +0 -27
  88. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/variable.h +0 -72
  89. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/warnings.h +0 -16
  90. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal.h +0 -108
  91. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/iseq.h +0 -340
  92. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/node.h +0 -111
  93. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/parser_st.h +0 -162
  94. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/parser_value.h +0 -106
  95. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/encoding.h +0 -283
  96. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/extension.h +0 -19
  97. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/node.h +0 -129
  98. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/options.h +0 -396
  99. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/pack.h +0 -163
  100. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/parser.h +0 -933
  101. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/prettyprint.h +0 -34
  102. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/regexp.h +0 -43
  103. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/static_literals.h +0 -121
  104. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/util/pm_buffer.h +0 -218
  105. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/util/pm_char.h +0 -204
  106. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/util/pm_constant_pool.h +0 -218
  107. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/util/pm_integer.h +0 -126
  108. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/util/pm_list.h +0 -97
  109. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/util/pm_memchr.h +0 -29
  110. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/util/pm_newline_list.h +0 -113
  111. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/util/pm_string.h +0 -190
  112. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/util/pm_strncasecmp.h +0 -32
  113. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/util/pm_strpbrk.h +0 -46
  114. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/ruby_assert.h +0 -14
  115. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/ruby_atomic.h +0 -23
  116. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/shape.h +0 -234
  117. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/thread_none.h +0 -21
  118. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/vm_debug.h +0 -124
  119. data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/vm_opts.h +0 -67
  120. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/ccan/build_assert/build_assert.h +0 -0
  121. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/ccan/check_type/check_type.h +0 -0
  122. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/ccan/container_of/container_of.h +0 -0
  123. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/ccan/list/list.h +0 -0
  124. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/ccan/str/str.h +0 -0
  125. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/id_table.h +0 -0
  126. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/array.h +0 -0
  127. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/internal/basic_operators.h +0 -0
  128. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/bignum.h +0 -0
  129. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/internal/bits.h +0 -0
  130. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/class.h +0 -0
  131. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/cmdlineopt.h +0 -0
  132. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/compar.h +0 -0
  133. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/compile.h +0 -0
  134. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/compilers.h +0 -0
  135. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/complex.h +0 -0
  136. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/cont.h +0 -0
  137. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/dir.h +0 -0
  138. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/enc.h +0 -0
  139. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/internal/encoding.h +0 -0
  140. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/enum.h +0 -0
  141. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/enumerator.h +0 -0
  142. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/eval.h +0 -0
  143. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/file.h +0 -0
  144. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/internal/fixnum.h +0 -0
  145. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/hash.h +0 -0
  146. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/internal/imemo.h +0 -0
  147. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/inits.h +0 -0
  148. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/internal/io.h +0 -0
  149. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/load.h +0 -0
  150. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/loadpath.h +0 -0
  151. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/math.h +0 -0
  152. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/missing.h +0 -0
  153. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/numeric.h +0 -0
  154. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/object.h +0 -0
  155. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/process.h +0 -0
  156. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/internal/ractor.h +0 -0
  157. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/random.h +0 -0
  158. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/range.h +0 -0
  159. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/rational.h +0 -0
  160. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/re.h +0 -0
  161. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/ruby_parser.h +0 -0
  162. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/serial.h +0 -0
  163. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/signal.h +0 -0
  164. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/st.h +0 -0
  165. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/static_assert.h +0 -0
  166. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/internal/string.h +0 -0
  167. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/struct.h +0 -0
  168. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/symbol.h +0 -0
  169. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/internal/thread.h +0 -0
  170. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/time.h +0 -0
  171. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/transcode.h +0 -0
  172. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/util.h +0 -0
  173. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/variable.h +0 -0
  174. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/internal/vm.h +0 -0
  175. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/warnings.h +0 -0
  176. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal.h +0 -0
  177. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/iseq.h +0 -0
  178. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/method.h +0 -0
  179. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/node.h +0 -0
  180. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/parser_st.h +0 -0
  181. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/parser_value.h +0 -0
  182. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/prism/defines.h +0 -0
  183. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/prism/diagnostic.h +0 -0
  184. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/encoding.h +0 -0
  185. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/node.h +0 -0
  186. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/options.h +0 -0
  187. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/pack.h +0 -0
  188. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/parser.h +0 -0
  189. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/prettyprint.h +0 -0
  190. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/prism/prism.h +0 -0
  191. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/regexp.h +0 -0
  192. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/static_literals.h +0 -0
  193. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/util/pm_buffer.h +0 -0
  194. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/util/pm_char.h +0 -0
  195. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/util/pm_constant_pool.h +0 -0
  196. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/util/pm_integer.h +0 -0
  197. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/util/pm_list.h +0 -0
  198. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/util/pm_memchr.h +0 -0
  199. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/util/pm_newline_list.h +0 -0
  200. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/util/pm_string.h +0 -0
  201. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/util/pm_strncasecmp.h +0 -0
  202. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/util/pm_strpbrk.h +0 -0
  203. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/prism_compile.h +0 -0
  204. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/ruby_assert.h +0 -0
  205. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/ruby_atomic.h +0 -0
  206. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/shape.h +0 -0
  207. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/thread_none.h +0 -0
  208. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/thread_pthread.h +0 -0
  209. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/vm_core.h +0 -0
  210. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/vm_debug.h +0 -0
  211. /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/vm_opts.h +0 -0
@@ -1,162 +0,0 @@
1
- /* This is a public domain general purpose hash table package
2
- originally written by Peter Moore @ UCB.
3
-
4
- The hash table data structures were redesigned and the package was
5
- rewritten by Vladimir Makarov <vmakarov@redhat.com>. */
6
-
7
- #ifndef RUBY_ST2_H
8
- #define RUBY_ST2_H 1
9
-
10
- #if defined(__cplusplus)
11
- extern "C" {
12
- #if 0
13
- } /* satisfy cc-mode */
14
- #endif
15
- #endif
16
-
17
- #include <stddef.h>
18
- #include <stdint.h>
19
- #include "ruby/config.h"
20
- #include "ruby/backward/2/long_long.h"
21
- #include "ruby/defines.h"
22
-
23
- RUBY_SYMBOL_EXPORT_BEGIN
24
-
25
- #if SIZEOF_LONG == SIZEOF_VOIDP
26
- typedef unsigned long parser_st_data_t;
27
- #elif SIZEOF_LONG_LONG == SIZEOF_VOIDP
28
- typedef unsigned LONG_LONG parser_st_data_t;
29
- #else
30
- # error ---->> parser_st.c requires sizeof(void*) == sizeof(long) or sizeof(LONG_LONG) to be compiled. <<----
31
- #endif
32
- #define ST2_DATA_T_DEFINED
33
-
34
- #ifndef CHAR_BIT
35
- # ifdef HAVE_LIMITS_H
36
- # include <limits.h>
37
- # else
38
- # define CHAR_BIT 8
39
- # endif
40
- #endif
41
- #ifndef _
42
- # define _(args) args
43
- #endif
44
- #ifndef ANYARGS
45
- # ifdef __cplusplus
46
- # define ANYARGS ...
47
- # else
48
- # define ANYARGS
49
- # endif
50
- #endif
51
-
52
- typedef struct parser_st_table parser_st_table;
53
-
54
- typedef parser_st_data_t parser_st_index_t;
55
-
56
- /* Maximal value of unsigned integer type parser_st_index_t. */
57
- #define MAX_ST2_INDEX_VAL (~(parser_st_index_t) 0)
58
-
59
- typedef int parser_st_compare_func(parser_st_data_t, parser_st_data_t);
60
- typedef parser_st_index_t parser_st_hash_func(parser_st_data_t);
61
-
62
- typedef char st_check_for_sizeof_parser_st_index_t[SIZEOF_VOIDP == (int)sizeof(parser_st_index_t) ? 1 : -1];
63
- #define SIZEOF_ST_INDEX_T SIZEOF_VOIDP
64
-
65
- struct parser_st_hash_type {
66
- int (*compare)(parser_st_data_t, parser_st_data_t); /* parser_st_compare_func* */
67
- parser_st_index_t (*hash)(parser_st_data_t); /* parser_st_hash_func* */
68
- };
69
-
70
- #define ST_INDEX_BITS (SIZEOF_ST_INDEX_T * CHAR_BIT)
71
-
72
- #if defined(HAVE_BUILTIN___BUILTIN_CHOOSE_EXPR) && defined(HAVE_BUILTIN___BUILTIN_TYPES_COMPATIBLE_P)
73
- # define ST2_DATA_COMPATIBLE_P(type) \
74
- __builtin_choose_expr(__builtin_types_compatible_p(type, parser_st_data_t), 1, 0)
75
- #else
76
- # define ST2_DATA_COMPATIBLE_P(type) 0
77
- #endif
78
-
79
- typedef struct parser_st_table_entry parser_st_table_entry;
80
-
81
- struct parser_st_table_entry; /* defined in parser_st.c */
82
-
83
- struct parser_st_table {
84
- /* Cached features of the table -- see st.c for more details. */
85
- unsigned char entry_power, bin_power, size_ind;
86
- /* How many times the table was rebuilt. */
87
- unsigned int rebuilds_num;
88
- const struct parser_st_hash_type *type;
89
- /* Number of entries currently in the table. */
90
- parser_st_index_t num_entries;
91
- /* Array of bins used for access by keys. */
92
- parser_st_index_t *bins;
93
- /* Start and bound index of entries in array entries.
94
- entries_starts and entries_bound are in interval
95
- [0,allocated_entries]. */
96
- parser_st_index_t entries_start, entries_bound;
97
- /* Array of size 2^entry_power. */
98
- parser_st_table_entry *entries;
99
- };
100
-
101
- #define parser_st_is_member(table,key) rb_parser_st_lookup((table),(key),(parser_st_data_t *)0)
102
-
103
- enum parser_st_retval {ST2_CONTINUE, ST2_STOP, ST2_DELETE, ST2_CHECK, ST2_REPLACE};
104
-
105
- size_t rb_parser_st_table_size(const struct parser_st_table *tbl);
106
- parser_st_table *rb_parser_st_init_table(const struct parser_st_hash_type *);
107
- parser_st_table *rb_parser_st_init_table_with_size(const struct parser_st_hash_type *, parser_st_index_t);
108
- parser_st_table *rb_parser_st_init_existing_table_with_size(parser_st_table *, const struct parser_st_hash_type *, parser_st_index_t);
109
- parser_st_table *rb_parser_st_init_numtable(void);
110
- parser_st_table *rb_parser_st_init_numtable_with_size(parser_st_index_t);
111
- parser_st_table *rb_parser_st_init_strtable(void);
112
- parser_st_table *rb_parser_st_init_strtable_with_size(parser_st_index_t);
113
- parser_st_table *rb_parser_st_init_strcasetable(void);
114
- parser_st_table *rb_parser_st_init_strcasetable_with_size(parser_st_index_t);
115
- int rb_parser_st_delete(parser_st_table *, parser_st_data_t *, parser_st_data_t *); /* returns 0:notfound 1:deleted */
116
- int rb_parser_st_delete_safe(parser_st_table *, parser_st_data_t *, parser_st_data_t *, parser_st_data_t);
117
- int rb_parser_st_shift(parser_st_table *, parser_st_data_t *, parser_st_data_t *); /* returns 0:notfound 1:deleted */
118
- int rb_parser_st_insert(parser_st_table *, parser_st_data_t, parser_st_data_t);
119
- int rb_parser_st_insert2(parser_st_table *, parser_st_data_t, parser_st_data_t, parser_st_data_t (*)(parser_st_data_t));
120
- int rb_parser_st_lookup(parser_st_table *, parser_st_data_t, parser_st_data_t *);
121
- int rb_parser_st_get_key(parser_st_table *, parser_st_data_t, parser_st_data_t *);
122
- typedef int parser_st_update_callback_func(parser_st_data_t *key, parser_st_data_t *value, parser_st_data_t arg, int existing);
123
- /* *key may be altered, but must equal to the old key, i.e., the
124
- * results of hash() are same and compare() returns 0, otherwise the
125
- * behavior is undefined */
126
- int rb_parser_st_update(parser_st_table *table, parser_st_data_t key, parser_st_update_callback_func *func, parser_st_data_t arg);
127
- typedef int parser_st_foreach_callback_func(parser_st_data_t, parser_st_data_t, parser_st_data_t);
128
- typedef int parser_st_foreach_check_callback_func(parser_st_data_t, parser_st_data_t, parser_st_data_t, int);
129
- int rb_parser_st_foreach_with_replace(parser_st_table *tab, parser_st_foreach_check_callback_func *func, parser_st_update_callback_func *replace, parser_st_data_t arg);
130
- int rb_parser_st_foreach(parser_st_table *, parser_st_foreach_callback_func *, parser_st_data_t);
131
- int rb_parser_st_foreach_check(parser_st_table *, parser_st_foreach_check_callback_func *, parser_st_data_t, parser_st_data_t);
132
- parser_st_index_t rb_parser_st_keys(parser_st_table *table, parser_st_data_t *keys, parser_st_index_t size);
133
- parser_st_index_t rb_parser_st_keys_check(parser_st_table *table, parser_st_data_t *keys, parser_st_index_t size, parser_st_data_t never);
134
- parser_st_index_t rb_parser_st_values(parser_st_table *table, parser_st_data_t *values, parser_st_index_t size);
135
- parser_st_index_t rb_parser_st_values_check(parser_st_table *table, parser_st_data_t *values, parser_st_index_t size, parser_st_data_t never);
136
- void rb_parser_st_add_direct(parser_st_table *, parser_st_data_t, parser_st_data_t);
137
- void rb_parser_st_free_table(parser_st_table *);
138
- void rb_parser_st_cleanup_safe(parser_st_table *, parser_st_data_t);
139
- void rb_parser_st_clear(parser_st_table *);
140
- parser_st_table *rb_parser_st_replace(parser_st_table *, parser_st_table *);
141
- parser_st_table *rb_parser_st_copy(parser_st_table *);
142
- CONSTFUNC(int rb_parser_st_numcmp(parser_st_data_t, parser_st_data_t));
143
- CONSTFUNC(parser_st_index_t rb_parser_st_numhash(parser_st_data_t));
144
- PUREFUNC(int rb_parser_st_locale_insensitive_strcasecmp(const char *s1, const char *s2));
145
- PUREFUNC(int rb_parser_st_locale_insensitive_strncasecmp(const char *s1, const char *s2, size_t n));
146
- PUREFUNC(size_t rb_parser_st_memsize(const parser_st_table *));
147
- PUREFUNC(parser_st_index_t rb_parser_st_hash(const void *ptr, size_t len, parser_st_index_t h));
148
- CONSTFUNC(parser_st_index_t rb_parser_st_hash_uint32(parser_st_index_t h, uint32_t i));
149
- CONSTFUNC(parser_st_index_t rb_parser_st_hash_uint(parser_st_index_t h, parser_st_index_t i));
150
- CONSTFUNC(parser_st_index_t rb_parser_st_hash_end(parser_st_index_t h));
151
- CONSTFUNC(parser_st_index_t rb_parser_st_hash_start(parser_st_index_t h));
152
-
153
- RUBY_SYMBOL_EXPORT_END
154
-
155
- #if defined(__cplusplus)
156
- #if 0
157
- { /* satisfy cc-mode */
158
- #endif
159
- } /* extern "C" { */
160
- #endif
161
-
162
- #endif /* RUBY_ST2_H */
@@ -1,106 +0,0 @@
1
- #ifndef EXTERNAL_VALUE_H
2
- #define EXTERNAL_VALUE_H
3
-
4
- #include "ruby/config.h"
5
-
6
- #if defined(__DOXYGEN__)
7
-
8
- /**
9
- * Type that represents a Ruby object. It is an unsigned integer of some kind,
10
- * depending on platforms.
11
- *
12
- * ```CXX
13
- * VALUE value = rb_eval_string("ARGF.readlines.map.with_index");
14
- * ```
15
- *
16
- * @warning ::VALUE is not a pointer.
17
- * @warning ::VALUE can be wider than `long`.
18
- */
19
- typedef uintptr_t VALUE;
20
-
21
- /**
22
- * Type that represents a Ruby identifier such as a variable name.
23
- *
24
- * ```CXX
25
- * ID method = rb_intern("method");
26
- * VALUE result = rb_funcall(obj, method, 0);
27
- * ```
28
- *
29
- * @note ::rb_cSymbol is a Ruby-level data type for the same thing.
30
- */
31
- typedef uintptr_t ID;
32
-
33
- /**
34
- * A signed integer type that has the same width with ::VALUE.
35
- *
36
- * @internal
37
- *
38
- * @shyouhei wonders: is it guaranteed that `uintptr_t` and `intptr_t` are the
39
- * same width? As far as I read ISO/IEC 9899:2018 section 7.20.1.4 paragraph 1
40
- * no such description is given... or defined elsewhere?
41
- */
42
- typedef intptr_t SIGNED_VALUE;
43
-
44
- /**
45
- * Identical to `sizeof(VALUE)`, except it is a macro that can also be used
46
- * inside of preprocessor directives such as `#if`. Handy on occasions.
47
- */
48
- #define SIZEOF_VALUE SIZEOF_UINTPTR_T
49
-
50
- /**
51
- * @private
52
- *
53
- * A compile-time constant of type ::VALUE whose value is 0.
54
- */
55
- #define RBIMPL_VALUE_NULL UINTPTR_C(0)
56
-
57
- /**
58
- * @private
59
- *
60
- * A compile-time constant of type ::VALUE whose value is 1.
61
- */
62
- #define RBIMPL_VALUE_ONE UINTPTR_C(1)
63
-
64
- /**
65
- * @private
66
- *
67
- * Maximum possible value that a ::VALUE can take.
68
- */
69
- #define RBIMPL_VALUE_FULL UINTPTR_MAX
70
-
71
- #elif defined HAVE_UINTPTR_T && 0
72
- typedef uintptr_t VALUE;
73
- typedef uintptr_t ID;
74
- # define SIGNED_VALUE intptr_t
75
- # define SIZEOF_VALUE SIZEOF_UINTPTR_T
76
- # undef PRI_VALUE_PREFIX
77
- # define RBIMPL_VALUE_NULL UINTPTR_C(0)
78
- # define RBIMPL_VALUE_ONE UINTPTR_C(1)
79
- # define RBIMPL_VALUE_FULL UINTPTR_MAX
80
-
81
- #elif SIZEOF_LONG == SIZEOF_VOIDP
82
- typedef unsigned long VALUE;
83
- typedef unsigned long ID;
84
- # define SIGNED_VALUE long
85
- # define SIZEOF_VALUE SIZEOF_LONG
86
- # define PRI_VALUE_PREFIX "l"
87
- # define RBIMPL_VALUE_NULL 0UL
88
- # define RBIMPL_VALUE_ONE 1UL
89
- # define RBIMPL_VALUE_FULL ULONG_MAX
90
-
91
- #elif SIZEOF_LONG_LONG == SIZEOF_VOIDP
92
- typedef unsigned LONG_LONG VALUE;
93
- typedef unsigned LONG_LONG ID;
94
- # define SIGNED_VALUE LONG_LONG
95
- # define LONG_LONG_VALUE 1
96
- # define SIZEOF_VALUE SIZEOF_LONG_LONG
97
- # define PRI_VALUE_PREFIX PRI_LL_PREFIX
98
- # define RBIMPL_VALUE_NULL 0ULL
99
- # define RBIMPL_VALUE_ONE 1ULL
100
- # define RBIMPL_VALUE_FULL ULLONG_MAX
101
-
102
- #else
103
- # error ---->> ruby requires sizeof(void*) == sizeof(long) or sizeof(LONG_LONG) to be compiled. <<----
104
- #endif
105
-
106
- #endif /* EXTERNAL_VALUE_H */
@@ -1,283 +0,0 @@
1
- /**
2
- * @file encoding.h
3
- *
4
- * The encoding interface and implementations used by the parser.
5
- */
6
- #ifndef PRISM_ENCODING_H
7
- #define PRISM_ENCODING_H
8
-
9
- #include "prism/defines.h"
10
- #include "prism/util/pm_strncasecmp.h"
11
-
12
- #include <assert.h>
13
- #include <stdbool.h>
14
- #include <stddef.h>
15
- #include <stdint.h>
16
-
17
- /**
18
- * This struct defines the functions necessary to implement the encoding
19
- * interface so we can determine how many bytes the subsequent character takes.
20
- * Each callback should return the number of bytes, or 0 if the next bytes are
21
- * invalid for the encoding and type.
22
- */
23
- typedef struct {
24
- /**
25
- * Return the number of bytes that the next character takes if it is valid
26
- * in the encoding. Does not read more than n bytes. It is assumed that n is
27
- * at least 1.
28
- */
29
- size_t (*char_width)(const uint8_t *b, ptrdiff_t n);
30
-
31
- /**
32
- * Return the number of bytes that the next character takes if it is valid
33
- * in the encoding and is alphabetical. Does not read more than n bytes. It
34
- * is assumed that n is at least 1.
35
- */
36
- size_t (*alpha_char)(const uint8_t *b, ptrdiff_t n);
37
-
38
- /**
39
- * Return the number of bytes that the next character takes if it is valid
40
- * in the encoding and is alphanumeric. Does not read more than n bytes. It
41
- * is assumed that n is at least 1.
42
- */
43
- size_t (*alnum_char)(const uint8_t *b, ptrdiff_t n);
44
-
45
- /**
46
- * Return true if the next character is valid in the encoding and is an
47
- * uppercase character. Does not read more than n bytes. It is assumed that
48
- * n is at least 1.
49
- */
50
- bool (*isupper_char)(const uint8_t *b, ptrdiff_t n);
51
-
52
- /**
53
- * The name of the encoding. This should correspond to a value that can be
54
- * passed to Encoding.find in Ruby.
55
- */
56
- const char *name;
57
-
58
- /**
59
- * Return true if the encoding is a multibyte encoding.
60
- */
61
- bool multibyte;
62
- } pm_encoding_t;
63
-
64
- /**
65
- * All of the lookup tables use the first bit of each embedded byte to indicate
66
- * whether the codepoint is alphabetical.
67
- */
68
- #define PRISM_ENCODING_ALPHABETIC_BIT 1 << 0
69
-
70
- /**
71
- * All of the lookup tables use the second bit of each embedded byte to indicate
72
- * whether the codepoint is alphanumeric.
73
- */
74
- #define PRISM_ENCODING_ALPHANUMERIC_BIT 1 << 1
75
-
76
- /**
77
- * All of the lookup tables use the third bit of each embedded byte to indicate
78
- * whether the codepoint is uppercase.
79
- */
80
- #define PRISM_ENCODING_UPPERCASE_BIT 1 << 2
81
-
82
- /**
83
- * Return the size of the next character in the UTF-8 encoding.
84
- *
85
- * @param b The bytes to read.
86
- * @param n The number of bytes that can be read.
87
- * @returns The number of bytes that the next character takes if it is valid in
88
- * the encoding, or 0 if it is not.
89
- */
90
- size_t pm_encoding_utf_8_char_width(const uint8_t *b, ptrdiff_t n);
91
-
92
- /**
93
- * Return the size of the next character in the UTF-8 encoding if it is an
94
- * alphabetical character.
95
- *
96
- * @param b The bytes to read.
97
- * @param n The number of bytes that can be read.
98
- * @returns The number of bytes that the next character takes if it is valid in
99
- * the encoding, or 0 if it is not.
100
- */
101
- size_t pm_encoding_utf_8_alpha_char(const uint8_t *b, ptrdiff_t n);
102
-
103
- /**
104
- * Return the size of the next character in the UTF-8 encoding if it is an
105
- * alphanumeric character.
106
- *
107
- * @param b The bytes to read.
108
- * @param n The number of bytes that can be read.
109
- * @returns The number of bytes that the next character takes if it is valid in
110
- * the encoding, or 0 if it is not.
111
- */
112
- size_t pm_encoding_utf_8_alnum_char(const uint8_t *b, ptrdiff_t n);
113
-
114
- /**
115
- * Return true if the next character in the UTF-8 encoding if it is an uppercase
116
- * character.
117
- *
118
- * @param b The bytes to read.
119
- * @param n The number of bytes that can be read.
120
- * @returns True if the next character is valid in the encoding and is an
121
- * uppercase character, or false if it is not.
122
- */
123
- bool pm_encoding_utf_8_isupper_char(const uint8_t *b, ptrdiff_t n);
124
-
125
- /**
126
- * This lookup table is referenced in both the UTF-8 encoding file and the
127
- * parser directly in order to speed up the default encoding processing. It is
128
- * used to indicate whether a character is alphabetical, alphanumeric, or
129
- * uppercase in unicode mappings.
130
- */
131
- extern const uint8_t pm_encoding_unicode_table[256];
132
-
133
- /**
134
- * These are all of the encodings that prism supports.
135
- */
136
- typedef enum {
137
- PM_ENCODING_UTF_8 = 0,
138
- PM_ENCODING_US_ASCII,
139
- PM_ENCODING_ASCII_8BIT,
140
- PM_ENCODING_EUC_JP,
141
- PM_ENCODING_WINDOWS_31J,
142
-
143
- // We optionally support excluding the full set of encodings to only support the
144
- // minimum necessary to process Ruby code without encoding comments.
145
- #ifndef PRISM_ENCODING_EXCLUDE_FULL
146
- PM_ENCODING_BIG5,
147
- PM_ENCODING_BIG5_HKSCS,
148
- PM_ENCODING_BIG5_UAO,
149
- PM_ENCODING_CESU_8,
150
- PM_ENCODING_CP51932,
151
- PM_ENCODING_CP850,
152
- PM_ENCODING_CP852,
153
- PM_ENCODING_CP855,
154
- PM_ENCODING_CP949,
155
- PM_ENCODING_CP950,
156
- PM_ENCODING_CP951,
157
- PM_ENCODING_EMACS_MULE,
158
- PM_ENCODING_EUC_JP_MS,
159
- PM_ENCODING_EUC_JIS_2004,
160
- PM_ENCODING_EUC_KR,
161
- PM_ENCODING_EUC_TW,
162
- PM_ENCODING_GB12345,
163
- PM_ENCODING_GB18030,
164
- PM_ENCODING_GB1988,
165
- PM_ENCODING_GB2312,
166
- PM_ENCODING_GBK,
167
- PM_ENCODING_IBM437,
168
- PM_ENCODING_IBM720,
169
- PM_ENCODING_IBM737,
170
- PM_ENCODING_IBM775,
171
- PM_ENCODING_IBM852,
172
- PM_ENCODING_IBM855,
173
- PM_ENCODING_IBM857,
174
- PM_ENCODING_IBM860,
175
- PM_ENCODING_IBM861,
176
- PM_ENCODING_IBM862,
177
- PM_ENCODING_IBM863,
178
- PM_ENCODING_IBM864,
179
- PM_ENCODING_IBM865,
180
- PM_ENCODING_IBM866,
181
- PM_ENCODING_IBM869,
182
- PM_ENCODING_ISO_8859_1,
183
- PM_ENCODING_ISO_8859_2,
184
- PM_ENCODING_ISO_8859_3,
185
- PM_ENCODING_ISO_8859_4,
186
- PM_ENCODING_ISO_8859_5,
187
- PM_ENCODING_ISO_8859_6,
188
- PM_ENCODING_ISO_8859_7,
189
- PM_ENCODING_ISO_8859_8,
190
- PM_ENCODING_ISO_8859_9,
191
- PM_ENCODING_ISO_8859_10,
192
- PM_ENCODING_ISO_8859_11,
193
- PM_ENCODING_ISO_8859_13,
194
- PM_ENCODING_ISO_8859_14,
195
- PM_ENCODING_ISO_8859_15,
196
- PM_ENCODING_ISO_8859_16,
197
- PM_ENCODING_KOI8_R,
198
- PM_ENCODING_KOI8_U,
199
- PM_ENCODING_MAC_CENT_EURO,
200
- PM_ENCODING_MAC_CROATIAN,
201
- PM_ENCODING_MAC_CYRILLIC,
202
- PM_ENCODING_MAC_GREEK,
203
- PM_ENCODING_MAC_ICELAND,
204
- PM_ENCODING_MAC_JAPANESE,
205
- PM_ENCODING_MAC_ROMAN,
206
- PM_ENCODING_MAC_ROMANIA,
207
- PM_ENCODING_MAC_THAI,
208
- PM_ENCODING_MAC_TURKISH,
209
- PM_ENCODING_MAC_UKRAINE,
210
- PM_ENCODING_SHIFT_JIS,
211
- PM_ENCODING_SJIS_DOCOMO,
212
- PM_ENCODING_SJIS_KDDI,
213
- PM_ENCODING_SJIS_SOFTBANK,
214
- PM_ENCODING_STATELESS_ISO_2022_JP,
215
- PM_ENCODING_STATELESS_ISO_2022_JP_KDDI,
216
- PM_ENCODING_TIS_620,
217
- PM_ENCODING_UTF8_MAC,
218
- PM_ENCODING_UTF8_DOCOMO,
219
- PM_ENCODING_UTF8_KDDI,
220
- PM_ENCODING_UTF8_SOFTBANK,
221
- PM_ENCODING_WINDOWS_1250,
222
- PM_ENCODING_WINDOWS_1251,
223
- PM_ENCODING_WINDOWS_1252,
224
- PM_ENCODING_WINDOWS_1253,
225
- PM_ENCODING_WINDOWS_1254,
226
- PM_ENCODING_WINDOWS_1255,
227
- PM_ENCODING_WINDOWS_1256,
228
- PM_ENCODING_WINDOWS_1257,
229
- PM_ENCODING_WINDOWS_1258,
230
- PM_ENCODING_WINDOWS_874,
231
- #endif
232
-
233
- PM_ENCODING_MAXIMUM
234
- } pm_encoding_type_t;
235
-
236
- /**
237
- * This is the table of all of the encodings that prism supports.
238
- */
239
- extern const pm_encoding_t pm_encodings[PM_ENCODING_MAXIMUM];
240
-
241
- /**
242
- * This is the default UTF-8 encoding. We need a reference to it to quickly
243
- * create parsers.
244
- */
245
- #define PM_ENCODING_UTF_8_ENTRY (&pm_encodings[PM_ENCODING_UTF_8])
246
-
247
- /**
248
- * This is the US-ASCII encoding. We need a reference to it to be able to
249
- * compare against it when a string is being created because it could possibly
250
- * need to fall back to ASCII-8BIT.
251
- */
252
- #define PM_ENCODING_US_ASCII_ENTRY (&pm_encodings[PM_ENCODING_US_ASCII])
253
-
254
- /**
255
- * This is the ASCII-8BIT encoding. We need a reference to it so that pm_strpbrk
256
- * can compare against it because invalid multibyte characters are not a thing
257
- * in this encoding. It is also needed for handling Regexp encoding flags.
258
- */
259
- #define PM_ENCODING_ASCII_8BIT_ENTRY (&pm_encodings[PM_ENCODING_ASCII_8BIT])
260
-
261
- /**
262
- * This is the EUC-JP encoding. We need a reference to it to quickly process
263
- * regular expression modifiers.
264
- */
265
- #define PM_ENCODING_EUC_JP_ENTRY (&pm_encodings[PM_ENCODING_EUC_JP])
266
-
267
- /**
268
- * This is the Windows-31J encoding. We need a reference to it to quickly
269
- * process regular expression modifiers.
270
- */
271
- #define PM_ENCODING_WINDOWS_31J_ENTRY (&pm_encodings[PM_ENCODING_WINDOWS_31J])
272
-
273
- /**
274
- * Parse the given name of an encoding and return a pointer to the corresponding
275
- * encoding struct if one can be found, otherwise return NULL.
276
- *
277
- * @param start A pointer to the first byte of the name.
278
- * @param end A pointer to the last byte of the name.
279
- * @returns A pointer to the encoding struct if one is found, otherwise NULL.
280
- */
281
- const pm_encoding_t * pm_encoding_find(const uint8_t *start, const uint8_t *end);
282
-
283
- #endif
@@ -1,19 +0,0 @@
1
- #ifndef PRISM_EXT_NODE_H
2
- #define PRISM_EXT_NODE_H
3
-
4
- #define EXPECTED_PRISM_VERSION "1.0.0"
5
-
6
- #include <ruby.h>
7
- #include <ruby/encoding.h>
8
- #include "prism.h"
9
-
10
- VALUE pm_source_new(const pm_parser_t *parser, rb_encoding *encoding);
11
- VALUE pm_token_new(const pm_parser_t *parser, const pm_token_t *token, rb_encoding *encoding, VALUE source);
12
- VALUE pm_ast_new(const pm_parser_t *parser, const pm_node_t *node, rb_encoding *encoding, VALUE source);
13
- VALUE pm_integer_new(const pm_integer_t *integer);
14
-
15
- void Init_prism_api_node(void);
16
- void Init_prism_pack(void);
17
- RUBY_FUNC_EXPORTED void Init_prism(void);
18
-
19
- #endif
@@ -1,129 +0,0 @@
1
- /**
2
- * @file node.h
3
- *
4
- * Functions related to nodes in the AST.
5
- */
6
- #ifndef PRISM_NODE_H
7
- #define PRISM_NODE_H
8
-
9
- #include "prism/defines.h"
10
- #include "prism/parser.h"
11
- #include "prism/util/pm_buffer.h"
12
-
13
- /**
14
- * Loop through each node in the node list, writing each node to the given
15
- * pm_node_t pointer.
16
- */
17
- #define PM_NODE_LIST_FOREACH(list, index, node) \
18
- for (size_t index = 0; index < (list)->size && ((node) = (list)->nodes[index]); index++)
19
-
20
- /**
21
- * Append a new node onto the end of the node list.
22
- *
23
- * @param list The list to append to.
24
- * @param node The node to append.
25
- */
26
- void pm_node_list_append(pm_node_list_t *list, pm_node_t *node);
27
-
28
- /**
29
- * Prepend a new node onto the beginning of the node list.
30
- *
31
- * @param list The list to prepend to.
32
- * @param node The node to prepend.
33
- */
34
- void pm_node_list_prepend(pm_node_list_t *list, pm_node_t *node);
35
-
36
- /**
37
- * Concatenate the given node list onto the end of the other node list.
38
- *
39
- * @param list The list to concatenate onto.
40
- * @param other The list to concatenate.
41
- */
42
- void pm_node_list_concat(pm_node_list_t *list, pm_node_list_t *other);
43
-
44
- /**
45
- * Free the internal memory associated with the given node list.
46
- *
47
- * @param list The list to free.
48
- */
49
- void pm_node_list_free(pm_node_list_t *list);
50
-
51
- /**
52
- * Deallocate a node and all of its children.
53
- *
54
- * @param parser The parser that owns the node.
55
- * @param node The node to deallocate.
56
- */
57
- PRISM_EXPORTED_FUNCTION void pm_node_destroy(pm_parser_t *parser, struct pm_node *node);
58
-
59
- /**
60
- * Returns a string representation of the given node type.
61
- *
62
- * @param node_type The node type to convert to a string.
63
- * @return A string representation of the given node type.
64
- */
65
- PRISM_EXPORTED_FUNCTION const char * pm_node_type_to_str(pm_node_type_t node_type);
66
-
67
- /**
68
- * Visit each of the nodes in this subtree using the given visitor callback. The
69
- * callback function will be called for each node in the subtree. If it returns
70
- * false, then that node's children will not be visited. If it returns true,
71
- * then the children will be visited. The data parameter is treated as an opaque
72
- * pointer and is passed to the visitor callback for consumers to use as they
73
- * see fit.
74
- *
75
- * As an example:
76
- *
77
- * ```c
78
- * #include "prism.h"
79
- *
80
- * bool visit(const pm_node_t *node, void *data) {
81
- * size_t *indent = (size_t *) data;
82
- * for (size_t i = 0; i < *indent * 2; i++) putc(' ', stdout);
83
- * printf("%s\n", pm_node_type_to_str(node->type));
84
- *
85
- * size_t next_indent = *indent + 1;
86
- * size_t *next_data = &next_indent;
87
- * pm_visit_child_nodes(node, visit, next_data);
88
- *
89
- * return false;
90
- * }
91
- *
92
- * int main(void) {
93
- * const char *source = "1 + 2; 3 + 4";
94
- * size_t size = strlen(source);
95
- *
96
- * pm_parser_t parser;
97
- * pm_options_t options = { 0 };
98
- * pm_parser_init(&parser, (const uint8_t *) source, size, &options);
99
- *
100
- * size_t indent = 0;
101
- * pm_node_t *node = pm_parse(&parser);
102
- *
103
- * size_t *data = &indent;
104
- * pm_visit_node(node, visit, data);
105
- *
106
- * pm_node_destroy(&parser, node);
107
- * pm_parser_free(&parser);
108
- * return EXIT_SUCCESS;
109
- * }
110
- * ```
111
- *
112
- * @param node The root node to start visiting from.
113
- * @param visitor The callback to call for each node in the subtree.
114
- * @param data An opaque pointer that is passed to the visitor callback.
115
- */
116
- PRISM_EXPORTED_FUNCTION void pm_visit_node(const pm_node_t *node, bool (*visitor)(const pm_node_t *node, void *data), void *data);
117
-
118
- /**
119
- * Visit the children of the given node with the given callback. This is the
120
- * default behavior for walking the tree that is called from pm_visit_node if
121
- * the callback returns true.
122
- *
123
- * @param node The node to visit the children of.
124
- * @param visitor The callback to call for each child node.
125
- * @param data An opaque pointer that is passed to the visitor callback.
126
- */
127
- PRISM_EXPORTED_FUNCTION void pm_visit_child_nodes(const pm_node_t *node, bool (*visitor)(const pm_node_t *node, void *data), void *data);
128
-
129
- #endif