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.
- 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
|