debase-ruby_core_source 0.9.6 → 0.9.7

Sign up to get free protection for your applications and to get access to all the features.
Files changed (51) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +5 -1
  3. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/addr2line.h +21 -0
  4. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/ccan/build_assert/build_assert.h +40 -0
  5. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/ccan/check_type/check_type.h +63 -0
  6. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/ccan/container_of/container_of.h +142 -0
  7. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/ccan/list/list.h +773 -0
  8. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/ccan/str/str.h +16 -0
  9. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/constant.h +50 -0
  10. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/dln.h +51 -0
  11. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/encindex.h +67 -0
  12. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/eval_intern.h +315 -0
  13. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/gc.h +114 -0
  14. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/id.h +220 -0
  15. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/id_table.h +31 -0
  16. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/insns.inc +112 -0
  17. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/insns_info.inc +796 -0
  18. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/internal.h +1772 -0
  19. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/iseq.h +252 -0
  20. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/known_errors.inc +746 -0
  21. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/method.h +213 -0
  22. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/node.h +520 -0
  23. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/node_name.inc +208 -0
  24. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/opt_sc.inc +774 -0
  25. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/optinsn.inc +83 -0
  26. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/optunifs.inc +129 -0
  27. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/parse.h +191 -0
  28. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/probes_helper.h +43 -0
  29. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/regenc.h +254 -0
  30. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/regint.h +938 -0
  31. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/regparse.h +370 -0
  32. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/revision.h +1 -0
  33. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/ruby_assert.h +54 -0
  34. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/ruby_atomic.h +233 -0
  35. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/siphash.h +48 -0
  36. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/symbol.h +108 -0
  37. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/thread_pthread.h +54 -0
  38. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/thread_win32.h +36 -0
  39. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/timev.h +42 -0
  40. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/transcode_data.h +139 -0
  41. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/version.h +73 -0
  42. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/vm.inc +3415 -0
  43. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/vm_call_iseq_optimized.inc +212 -0
  44. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/vm_core.h +1646 -0
  45. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/vm_debug.h +37 -0
  46. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/vm_exec.h +182 -0
  47. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/vm_insnhelper.h +227 -0
  48. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/vm_opts.h +57 -0
  49. data/lib/debase/ruby_core_source/ruby-2.4.1-p111/vmtc.inc +110 -0
  50. data/lib/debase/ruby_core_source/version.rb +1 -1
  51. metadata +49 -2
@@ -0,0 +1,83 @@
1
+ /* -*-c-*- *********************************************************/
2
+ /*******************************************************************/
3
+ /*******************************************************************/
4
+ /**
5
+ This file is for threaded code.
6
+
7
+ ----
8
+ This file is auto generated by insns2vm.rb
9
+ DO NOT TOUCH!
10
+
11
+ If you want to fix something, you must edit 'template/optinsn.inc.tmpl'
12
+ or tool/insns2vm.rb
13
+ */
14
+
15
+ static INSN *
16
+ insn_operands_unification(INSN *insnobj){
17
+ #ifdef OPT_OPERANDS_UNIFICATION
18
+ /* optimize rule */
19
+ switch(insnobj->insn_id){
20
+
21
+ case BIN(getlocal):
22
+ if(
23
+ insnobj->operands[1] == INT2FIX(0)
24
+ ){
25
+ insnobj->insn_id = BIN(getlocal_OP__WC__0);
26
+ insnobj->operand_size = 1;
27
+ break;
28
+ }
29
+
30
+ if(
31
+ insnobj->operands[1] == INT2FIX(1)
32
+ ){
33
+ insnobj->insn_id = BIN(getlocal_OP__WC__1);
34
+ insnobj->operand_size = 1;
35
+ break;
36
+ }
37
+
38
+ break;
39
+ case BIN(setlocal):
40
+ if(
41
+ insnobj->operands[1] == INT2FIX(0)
42
+ ){
43
+ insnobj->insn_id = BIN(setlocal_OP__WC__0);
44
+ insnobj->operand_size = 1;
45
+ break;
46
+ }
47
+
48
+ if(
49
+ insnobj->operands[1] == INT2FIX(1)
50
+ ){
51
+ insnobj->insn_id = BIN(setlocal_OP__WC__1);
52
+ insnobj->operand_size = 1;
53
+ break;
54
+ }
55
+
56
+ break;
57
+ case BIN(putobject):
58
+ if(
59
+ insnobj->operands[0] == INT2FIX(0)
60
+ ){
61
+ insnobj->insn_id = BIN(putobject_OP_INT2FIX_O_0_C_);
62
+ insnobj->operand_size = 0;
63
+ break;
64
+ }
65
+
66
+ if(
67
+ insnobj->operands[0] == INT2FIX(1)
68
+ ){
69
+ insnobj->insn_id = BIN(putobject_OP_INT2FIX_O_1_C_);
70
+ insnobj->operand_size = 0;
71
+ break;
72
+ }
73
+
74
+ break;
75
+
76
+ default:
77
+ /* do nothing */;
78
+ break;
79
+ }
80
+ #endif
81
+ return insnobj;
82
+ }
83
+
@@ -0,0 +1,129 @@
1
+ /* -*-c-*- *********************************************************/
2
+ /*******************************************************************/
3
+ /*******************************************************************/
4
+ /**
5
+ This file is for threaded code.
6
+
7
+ ----
8
+ This file is auto generated by insns2vm.rb
9
+ DO NOT TOUCH!
10
+
11
+ If you want to fix something, you must edit 'template/optunifs.inc.tmpl'
12
+ or tool/insns2vm.rb
13
+ */
14
+
15
+ /*
16
+ static const int UNIFIED_insn_name_1[] = {id, size, ...};
17
+ static const int UNIFIED_insn_name_2[] = {id, size, ...};
18
+ ...
19
+
20
+ static const int *const UNIFIED_insn_name[] = {size,
21
+ UNIFIED_insn_name_1,
22
+ UNIFIED_insn_name_2, ...};
23
+ ...
24
+
25
+ static const int *const *const unified_insns_data[] = {
26
+ UNIFIED_insn_nameA,
27
+ UNIFIED_insn_nameB, ...};
28
+ */
29
+
30
+
31
+
32
+ static const int *const *const unified_insns_data[] = {
33
+ 0,
34
+ 0,
35
+ 0,
36
+ 0,
37
+ 0,
38
+ 0,
39
+ 0,
40
+ 0,
41
+ 0,
42
+ 0,
43
+ 0,
44
+ 0,
45
+ 0,
46
+ 0,
47
+ 0,
48
+ 0,
49
+ 0,
50
+ 0,
51
+ 0,
52
+ 0,
53
+ 0,
54
+ 0,
55
+ 0,
56
+ 0,
57
+ 0,
58
+ 0,
59
+ 0,
60
+ 0,
61
+ 0,
62
+ 0,
63
+ 0,
64
+ 0,
65
+ 0,
66
+ 0,
67
+ 0,
68
+ 0,
69
+ 0,
70
+ 0,
71
+ 0,
72
+ 0,
73
+ 0,
74
+ 0,
75
+ 0,
76
+ 0,
77
+ 0,
78
+ 0,
79
+ 0,
80
+ 0,
81
+ 0,
82
+ 0,
83
+ 0,
84
+ 0,
85
+ 0,
86
+ 0,
87
+ 0,
88
+ 0,
89
+ 0,
90
+ 0,
91
+ 0,
92
+ 0,
93
+ 0,
94
+ 0,
95
+ 0,
96
+ 0,
97
+ 0,
98
+ 0,
99
+ 0,
100
+ 0,
101
+ 0,
102
+ 0,
103
+ 0,
104
+ 0,
105
+ 0,
106
+ 0,
107
+ 0,
108
+ 0,
109
+ 0,
110
+ 0,
111
+ 0,
112
+ 0,
113
+ 0,
114
+ 0,
115
+ 0,
116
+ 0,
117
+ 0,
118
+ 0,
119
+ 0,
120
+ 0,
121
+ 0,
122
+ 0,
123
+ 0,
124
+ 0,
125
+ 0};
126
+
127
+
128
+ #undef GET_INSN_NAME
129
+
@@ -0,0 +1,191 @@
1
+ /* A Bison parser, made by GNU Bison 3.0.4. */
2
+
3
+ /* Bison interface for Yacc-like parsers in C
4
+
5
+ Copyright (C) 1984, 1989-1990, 2000-2015 Free Software Foundation, Inc.
6
+
7
+ This program is free software: you can redistribute it and/or modify
8
+ it under the terms of the GNU General Public License as published by
9
+ the Free Software Foundation, either version 3 of the License, or
10
+ (at your option) any later version.
11
+
12
+ This program is distributed in the hope that it will be useful,
13
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
14
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15
+ GNU General Public License for more details.
16
+
17
+ You should have received a copy of the GNU General Public License
18
+ along with this program. If not, see <http://www.gnu.org/licenses/>. */
19
+
20
+ /* As a special exception, you may create a larger work that contains
21
+ part or all of the Bison parser skeleton and distribute that work
22
+ under terms of your choice, so long as that work isn't itself a
23
+ parser generator using the skeleton or a modified version thereof
24
+ as a parser skeleton. Alternatively, if you modify or redistribute
25
+ the parser skeleton itself, you may (at your option) remove this
26
+ special exception, which will cause the skeleton and the resulting
27
+ Bison output files to be licensed under the GNU General Public
28
+ License without this special exception.
29
+
30
+ This special exception was added by the Free Software Foundation in
31
+ version 2.2 of Bison. */
32
+
33
+ #ifndef YY_YY_Y_TAB_H_INCLUDED
34
+ # define YY_YY_Y_TAB_H_INCLUDED
35
+ /* Debug traces. */
36
+ #ifndef YYDEBUG
37
+ # define YYDEBUG 0
38
+ #endif
39
+ #if YYDEBUG
40
+ extern int yydebug;
41
+ #endif
42
+
43
+ /* Token type. */
44
+ #ifndef YYTOKENTYPE
45
+ # define YYTOKENTYPE
46
+ enum yytokentype
47
+ {
48
+ END_OF_INPUT = 0,
49
+ keyword_class = 258,
50
+ keyword_module = 259,
51
+ keyword_def = 260,
52
+ keyword_undef = 261,
53
+ keyword_begin = 262,
54
+ keyword_rescue = 263,
55
+ keyword_ensure = 264,
56
+ keyword_end = 265,
57
+ keyword_if = 266,
58
+ keyword_unless = 267,
59
+ keyword_then = 268,
60
+ keyword_elsif = 269,
61
+ keyword_else = 270,
62
+ keyword_case = 271,
63
+ keyword_when = 272,
64
+ keyword_while = 273,
65
+ keyword_until = 274,
66
+ keyword_for = 275,
67
+ keyword_break = 276,
68
+ keyword_next = 277,
69
+ keyword_redo = 278,
70
+ keyword_retry = 279,
71
+ keyword_in = 280,
72
+ keyword_do = 281,
73
+ keyword_do_cond = 282,
74
+ keyword_do_block = 283,
75
+ keyword_do_LAMBDA = 284,
76
+ keyword_return = 285,
77
+ keyword_yield = 286,
78
+ keyword_super = 287,
79
+ keyword_self = 288,
80
+ keyword_nil = 289,
81
+ keyword_true = 290,
82
+ keyword_false = 291,
83
+ keyword_and = 292,
84
+ keyword_or = 293,
85
+ keyword_not = 294,
86
+ modifier_if = 295,
87
+ modifier_unless = 296,
88
+ modifier_while = 297,
89
+ modifier_until = 298,
90
+ modifier_rescue = 299,
91
+ keyword_alias = 300,
92
+ keyword_defined = 301,
93
+ keyword_BEGIN = 302,
94
+ keyword_END = 303,
95
+ keyword__LINE__ = 304,
96
+ keyword__FILE__ = 305,
97
+ keyword__ENCODING__ = 306,
98
+ tIDENTIFIER = 307,
99
+ tFID = 308,
100
+ tGVAR = 309,
101
+ tIVAR = 310,
102
+ tCONSTANT = 311,
103
+ tCVAR = 312,
104
+ tLABEL = 313,
105
+ tINTEGER = 314,
106
+ tFLOAT = 315,
107
+ tRATIONAL = 316,
108
+ tIMAGINARY = 317,
109
+ tSTRING_CONTENT = 318,
110
+ tCHAR = 319,
111
+ tNTH_REF = 320,
112
+ tBACK_REF = 321,
113
+ tREGEXP_END = 322,
114
+ tUPLUS = 130,
115
+ tUMINUS = 131,
116
+ tPOW = 132,
117
+ tCMP = 134,
118
+ tEQ = 139,
119
+ tEQQ = 140,
120
+ tNEQ = 141,
121
+ tGEQ = 138,
122
+ tLEQ = 137,
123
+ tANDOP = 148,
124
+ tOROP = 149,
125
+ tMATCH = 142,
126
+ tNMATCH = 143,
127
+ tDOT2 = 128,
128
+ tDOT3 = 129,
129
+ tAREF = 144,
130
+ tASET = 145,
131
+ tLSHFT = 135,
132
+ tRSHFT = 136,
133
+ tANDDOT = 150,
134
+ tCOLON2 = 323,
135
+ tCOLON3 = 324,
136
+ tOP_ASGN = 325,
137
+ tASSOC = 326,
138
+ tLPAREN = 327,
139
+ tLPAREN_ARG = 328,
140
+ tRPAREN = 329,
141
+ tLBRACK = 330,
142
+ tLBRACE = 331,
143
+ tLBRACE_ARG = 332,
144
+ tSTAR = 333,
145
+ tDSTAR = 334,
146
+ tAMPER = 335,
147
+ tLAMBDA = 336,
148
+ tSYMBEG = 337,
149
+ tSTRING_BEG = 338,
150
+ tXSTRING_BEG = 339,
151
+ tREGEXP_BEG = 340,
152
+ tWORDS_BEG = 341,
153
+ tQWORDS_BEG = 342,
154
+ tSYMBOLS_BEG = 343,
155
+ tQSYMBOLS_BEG = 344,
156
+ tSTRING_DBEG = 345,
157
+ tSTRING_DEND = 346,
158
+ tSTRING_DVAR = 347,
159
+ tSTRING_END = 348,
160
+ tLAMBEG = 349,
161
+ tLABEL_END = 350,
162
+ tLOWEST = 351,
163
+ tUMINUS_NUM = 352,
164
+ tLAST_TOKEN = 353
165
+ };
166
+ #endif
167
+
168
+ /* Value type. */
169
+ #if ! defined YYSTYPE && ! defined YYSTYPE_IS_DECLARED
170
+
171
+ union YYSTYPE
172
+ {
173
+
174
+ VALUE val;
175
+ NODE *node;
176
+ ID id;
177
+ int num;
178
+ const struct vtable *vars;
179
+
180
+ };
181
+
182
+ typedef union YYSTYPE YYSTYPE;
183
+ # define YYSTYPE_IS_TRIVIAL 1
184
+ # define YYSTYPE_IS_DECLARED 1
185
+ #endif
186
+
187
+
188
+
189
+ int yyparse (struct parser_params *parser);
190
+
191
+ #endif /* !YY_YY_Y_TAB_H_INCLUDED */
@@ -0,0 +1,43 @@
1
+ #ifndef RUBY_PROBES_HELPER_H
2
+ #define RUBY_PROBES_HELPER_H
3
+
4
+ #include "ruby/ruby.h"
5
+ #include "probes.h"
6
+
7
+ struct ruby_dtrace_method_hook_args {
8
+ const char *classname;
9
+ const char *methodname;
10
+ const char *filename;
11
+ int line_no;
12
+ volatile VALUE klass;
13
+ volatile VALUE name;
14
+ };
15
+
16
+ NOINLINE(int ruby_th_dtrace_setup(rb_thread_t *, VALUE, ID, struct ruby_dtrace_method_hook_args *));
17
+
18
+ #define RUBY_DTRACE_METHOD_HOOK(name, th, klazz, id) \
19
+ do { \
20
+ if (UNLIKELY(RUBY_DTRACE_##name##_ENABLED())) { \
21
+ struct ruby_dtrace_method_hook_args args; \
22
+ if (ruby_th_dtrace_setup(th, klazz, id, &args)) { \
23
+ RUBY_DTRACE_##name(args.classname, \
24
+ args.methodname, \
25
+ args.filename, \
26
+ args.line_no); \
27
+ } \
28
+ } \
29
+ } while (0)
30
+
31
+ #define RUBY_DTRACE_METHOD_ENTRY_HOOK(th, klass, id) \
32
+ RUBY_DTRACE_METHOD_HOOK(METHOD_ENTRY, th, klass, id)
33
+
34
+ #define RUBY_DTRACE_METHOD_RETURN_HOOK(th, klass, id) \
35
+ RUBY_DTRACE_METHOD_HOOK(METHOD_RETURN, th, klass, id)
36
+
37
+ #define RUBY_DTRACE_CMETHOD_ENTRY_HOOK(th, klass, id) \
38
+ RUBY_DTRACE_METHOD_HOOK(CMETHOD_ENTRY, th, klass, id)
39
+
40
+ #define RUBY_DTRACE_CMETHOD_RETURN_HOOK(th, klass, id) \
41
+ RUBY_DTRACE_METHOD_HOOK(CMETHOD_RETURN, th, klass, id)
42
+
43
+ #endif /* RUBY_PROBES_HELPER_H */