datadog-ruby_core_source 3.3.7 → 3.4.0
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.
- checksums.yaml +4 -4
- data/CHANGELOG.datadog.md +5 -0
- data/datadog-ruby_core_source.gemspec +1 -1
- data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/id.h +2 -0
- data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/error.h +26 -0
- data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/internal/gc.h +1 -0
- data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/parse.h +2 -1
- data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/proc.h +1 -0
- data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/internal/sanitizers.h +24 -36
- data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/prism/ast.h +10 -0
- data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/extension.h +1 -1
- data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/prism/version.h +2 -2
- data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/ractor_core.h +1 -0
- data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/rubyparser.h +3 -1
- data/lib/datadog/ruby_core_source/version.rb +1 -1
- metadata +106 -209
- data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/id.h +0 -347
- data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/internal/basic_operators.h +0 -64
- data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/internal/bits.h +0 -568
- data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/internal/encoding.h +0 -36
- data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/internal/fixnum.h +0 -184
- data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/internal/gc.h +0 -322
- data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/internal/imemo.h +0 -261
- data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/internal/io.h +0 -143
- data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/internal/ractor.h +0 -6
- data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/internal/sanitizers.h +0 -326
- data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/internal/string.h +0 -186
- data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/internal/thread.h +0 -85
- data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/internal/vm.h +0 -137
- data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/method.h +0 -255
- data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/prism/ast.h +0 -7524
- data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/prism/defines.h +0 -242
- data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/prism/diagnostic.h +0 -450
- data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/prism/prism.h +0 -336
- data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/prism/version.h +0 -29
- data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/prism_compile.h +0 -99
- data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/ractor_core.h +0 -382
- data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/rubyparser.h +0 -1350
- data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/thread_pthread.h +0 -168
- data/lib/datadog/ruby_core_source/ruby-3.4.0-preview2/vm_core.h +0 -2222
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/ccan/build_assert/build_assert.h +0 -40
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/ccan/check_type/check_type.h +0 -63
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/ccan/container_of/container_of.h +0 -142
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/ccan/list/list.h +0 -791
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/ccan/str/str.h +0 -17
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/id_table.h +0 -39
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/array.h +0 -152
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/bignum.h +0 -244
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/class.h +0 -283
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/cmdlineopt.h +0 -65
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/compar.h +0 -29
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/compile.h +0 -34
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/compilers.h +0 -107
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/complex.h +0 -29
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/cont.h +0 -35
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/dir.h +0 -16
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/enc.h +0 -19
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/enum.h +0 -18
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/enumerator.h +0 -21
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/error.h +0 -218
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/eval.h +0 -33
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/file.h +0 -38
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/hash.h +0 -192
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/inits.h +0 -47
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/load.h +0 -18
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/loadpath.h +0 -16
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/math.h +0 -23
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/missing.h +0 -19
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/numeric.h +0 -274
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/object.h +0 -63
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/parse.h +0 -129
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/proc.h +0 -30
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/process.h +0 -124
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/random.h +0 -17
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/range.h +0 -40
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/rational.h +0 -71
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/re.h +0 -28
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/ruby_parser.h +0 -102
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/serial.h +0 -23
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/signal.h +0 -24
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/st.h +0 -11
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/static_assert.h +0 -16
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/struct.h +0 -127
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/symbol.h +0 -45
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/time.h +0 -34
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/transcode.h +0 -23
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/util.h +0 -27
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/variable.h +0 -72
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal/warnings.h +0 -16
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/internal.h +0 -108
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/iseq.h +0 -340
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/node.h +0 -111
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/parser_st.h +0 -162
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/parser_value.h +0 -106
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/encoding.h +0 -283
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/extension.h +0 -19
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/node.h +0 -129
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/options.h +0 -396
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/pack.h +0 -163
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/parser.h +0 -933
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/prettyprint.h +0 -34
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/regexp.h +0 -43
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/static_literals.h +0 -121
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/util/pm_buffer.h +0 -218
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/util/pm_char.h +0 -204
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/util/pm_constant_pool.h +0 -218
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/util/pm_integer.h +0 -126
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/util/pm_list.h +0 -97
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/util/pm_memchr.h +0 -29
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/util/pm_newline_list.h +0 -113
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/util/pm_string.h +0 -190
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/util/pm_strncasecmp.h +0 -32
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/prism/util/pm_strpbrk.h +0 -46
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/ruby_assert.h +0 -14
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/ruby_atomic.h +0 -23
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/shape.h +0 -234
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/thread_none.h +0 -21
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/vm_debug.h +0 -124
- data/lib/datadog/ruby_core_source/ruby-3.4.0-rc1/vm_opts.h +0 -67
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/ccan/build_assert/build_assert.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/ccan/check_type/check_type.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/ccan/container_of/container_of.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/ccan/list/list.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/ccan/str/str.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/id_table.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/array.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/internal/basic_operators.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/bignum.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/internal/bits.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/class.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/cmdlineopt.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/compar.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/compile.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/compilers.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/complex.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/cont.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/dir.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/enc.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/internal/encoding.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/enum.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/enumerator.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/eval.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/file.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/internal/fixnum.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/hash.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/internal/imemo.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/inits.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/internal/io.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/load.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/loadpath.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/math.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/missing.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/numeric.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/object.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/process.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/internal/ractor.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/random.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/range.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/rational.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/re.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/ruby_parser.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/serial.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/signal.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/st.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/static_assert.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/internal/string.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/struct.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/symbol.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/internal/thread.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/time.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/transcode.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/util.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/variable.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/internal/vm.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal/warnings.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/internal.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/iseq.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/method.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/node.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/parser_st.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/parser_value.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/prism/defines.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/prism/diagnostic.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/encoding.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/node.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/options.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/pack.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/parser.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/prettyprint.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/prism/prism.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/regexp.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/static_literals.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/util/pm_buffer.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/util/pm_char.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/util/pm_constant_pool.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/util/pm_integer.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/util/pm_list.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/util/pm_memchr.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/util/pm_newline_list.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/util/pm_string.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/util/pm_strncasecmp.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/prism/util/pm_strpbrk.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/prism_compile.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/ruby_assert.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/ruby_atomic.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/shape.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/thread_none.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/thread_pthread.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-rc1 → ruby-3.4.0-p0}/vm_core.h +0 -0
- /data/lib/datadog/ruby_core_source/{ruby-3.4.0-preview2 → ruby-3.4.0-p0}/vm_debug.h +0 -0
- /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
|