opal 0.5.5 → 0.6.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (257) hide show
  1. checksums.yaml +4 -4
  2. data/.travis.yml +40 -9
  3. data/CHANGELOG.md +349 -0
  4. data/Gemfile +7 -8
  5. data/README.md +25 -3
  6. data/Rakefile +4 -2
  7. data/bin/opal +1 -1
  8. data/examples/rack/Gemfile +3 -0
  9. data/examples/rack/app/application.rb +13 -0
  10. data/examples/rack/app/user.rb +21 -0
  11. data/examples/rack/config.ru +7 -0
  12. data/examples/rack/index.html.erb +10 -0
  13. data/examples/sinatra/Gemfile +4 -0
  14. data/examples/sinatra/app/application.rb +7 -0
  15. data/examples/sinatra/config.ru +21 -0
  16. data/lib/mspec/opal/rake_task.rb +29 -8
  17. data/lib/mspec/opal/runner.rb +5 -4
  18. data/lib/opal.rb +1 -0
  19. data/lib/opal/builder.rb +0 -28
  20. data/lib/opal/cli.rb +0 -14
  21. data/lib/opal/compiler.rb +12 -11
  22. data/lib/opal/fragment.rb +8 -1
  23. data/lib/opal/nodes/array.rb +1 -1
  24. data/lib/opal/nodes/base.rb +4 -0
  25. data/lib/opal/nodes/call.rb +6 -2
  26. data/lib/opal/nodes/call_special.rb +1 -1
  27. data/lib/opal/nodes/class.rb +2 -2
  28. data/lib/opal/nodes/constants.rb +3 -1
  29. data/lib/opal/nodes/helpers.rb +23 -14
  30. data/lib/opal/nodes/if.rb +16 -9
  31. data/lib/opal/nodes/literal.rb +37 -5
  32. data/lib/opal/nodes/logic.rb +7 -1
  33. data/lib/opal/nodes/module.rb +2 -2
  34. data/lib/opal/nodes/scope.rb +13 -2
  35. data/lib/opal/nodes/top.rb +9 -0
  36. data/lib/opal/nodes/variables.rb +5 -2
  37. data/lib/opal/parser.rb +306 -71
  38. data/lib/opal/parser/grammar.rb +2667 -2775
  39. data/lib/opal/parser/grammar.y +177 -233
  40. data/lib/opal/parser/lexer.rb +511 -427
  41. data/lib/opal/parser/sexp.rb +15 -3
  42. data/lib/opal/source_map.rb +8 -4
  43. data/lib/opal/sprockets.rb +4 -0
  44. data/lib/opal/sprockets/cache_key_fix.rb +17 -0
  45. data/lib/opal/sprockets/environment.rb +21 -0
  46. data/lib/opal/sprockets/erb.rb +30 -0
  47. data/lib/opal/sprockets/processor.rb +127 -0
  48. data/lib/opal/sprockets/server.rb +166 -0
  49. data/lib/opal/util.rb +29 -0
  50. data/lib/opal/version.rb +1 -1
  51. data/opal.gemspec +1 -1
  52. data/opal/corelib/array.rb +106 -187
  53. data/opal/corelib/array/inheritance.rb +113 -0
  54. data/opal/corelib/basic_object.rb +6 -2
  55. data/opal/corelib/boolean.rb +4 -0
  56. data/opal/corelib/class.rb +2 -0
  57. data/opal/corelib/complex.rb +3 -0
  58. data/opal/corelib/enumerable.rb +75 -8
  59. data/opal/corelib/enumerator.rb +2 -0
  60. data/opal/corelib/error.rb +23 -23
  61. data/opal/corelib/hash.rb +5 -5
  62. data/opal/corelib/helpers.rb +51 -16
  63. data/opal/corelib/io.rb +7 -24
  64. data/opal/corelib/kernel.rb +23 -11
  65. data/opal/corelib/module.rb +44 -47
  66. data/opal/corelib/nil_class.rb +4 -0
  67. data/opal/corelib/numeric.rb +101 -15
  68. data/opal/corelib/range.rb +2 -0
  69. data/opal/corelib/rational.rb +3 -0
  70. data/opal/corelib/regexp.rb +36 -17
  71. data/opal/corelib/runtime.js +22 -7
  72. data/opal/corelib/string.rb +213 -110
  73. data/opal/corelib/string/inheritance.rb +78 -0
  74. data/opal/corelib/struct.rb +8 -0
  75. data/opal/corelib/time.rb +54 -42
  76. data/opal/corelib/variables.rb +24 -0
  77. data/opal/opal.rb +5 -27
  78. data/spec/cli/compiler_spec.rb +136 -0
  79. data/spec/cli/dependency_resolver_spec.rb +40 -0
  80. data/spec/cli/lexer_spec.rb +110 -0
  81. data/spec/cli/parser/alias_spec.rb +26 -0
  82. data/spec/cli/parser/and_spec.rb +13 -0
  83. data/spec/cli/parser/attrasgn_spec.rb +28 -0
  84. data/spec/cli/parser/begin_spec.rb +42 -0
  85. data/spec/cli/parser/block_spec.rb +12 -0
  86. data/spec/cli/parser/break_spec.rb +17 -0
  87. data/spec/cli/parser/call_spec.rb +139 -0
  88. data/spec/cli/parser/class_spec.rb +35 -0
  89. data/spec/cli/parser/comments_spec.rb +11 -0
  90. data/spec/cli/parser/def_spec.rb +61 -0
  91. data/spec/cli/parser/if_spec.rb +26 -0
  92. data/spec/cli/parser/iter_spec.rb +59 -0
  93. data/spec/cli/parser/lambda_spec.rb +64 -0
  94. data/spec/cli/parser/literal_spec.rb +113 -0
  95. data/spec/cli/parser/masgn_spec.rb +37 -0
  96. data/spec/cli/parser/module_spec.rb +27 -0
  97. data/spec/cli/parser/not_spec.rb +27 -0
  98. data/spec/cli/parser/op_asgn1_spec.rb +23 -0
  99. data/spec/cli/parser/op_asgn2_spec.rb +23 -0
  100. data/spec/cli/parser/or_spec.rb +13 -0
  101. data/spec/cli/parser/return_spec.rb +17 -0
  102. data/spec/cli/parser/sclass_spec.rb +21 -0
  103. data/spec/cli/parser/string_spec.rb +269 -0
  104. data/spec/cli/parser/super_spec.rb +20 -0
  105. data/spec/cli/parser/undef_spec.rb +15 -0
  106. data/spec/cli/parser/unless_spec.rb +13 -0
  107. data/spec/cli/parser/variables_spec.rb +92 -0
  108. data/spec/cli/parser/while_spec.rb +15 -0
  109. data/spec/cli/parser/yield_spec.rb +20 -0
  110. data/spec/cli/spec_helper.rb +31 -11
  111. data/spec/opal/core/array/set_range_to_array_spec.rb +7 -0
  112. data/spec/opal/core/date_spec.rb +122 -0
  113. data/spec/opal/core/language/predefined_spec.rb +1 -1
  114. data/spec/opal/core/runtime/operator_call_spec.rb +13 -0
  115. data/spec/opal/core/runtime/truthy_spec.rb +23 -0
  116. data/spec/opal/filters/bugs/array.rb +96 -87
  117. data/spec/opal/filters/bugs/basic_object.rb +9 -0
  118. data/spec/opal/filters/bugs/class.rb +16 -0
  119. data/spec/opal/filters/bugs/enumerable.rb +54 -0
  120. data/spec/opal/filters/bugs/language.rb +37 -3
  121. data/spec/opal/filters/bugs/math.rb +93 -0
  122. data/spec/opal/filters/bugs/nil.rb +7 -0
  123. data/spec/opal/filters/bugs/numeric.rb +19 -0
  124. data/spec/opal/filters/bugs/opal.rb +12 -0
  125. data/spec/opal/filters/bugs/regexp.rb +0 -2
  126. data/spec/opal/filters/bugs/string.rb +317 -19
  127. data/spec/opal/filters/bugs/struct.rb +29 -0
  128. data/spec/opal/filters/bugs/time.rb +130 -9
  129. data/spec/opal/filters/unsupported/encoding.rb +52 -4
  130. data/spec/opal/filters/unsupported/enumerator.rb +0 -3
  131. data/spec/opal/filters/unsupported/integer_size.rb +7 -0
  132. data/spec/opal/filters/unsupported/method_added.rb +10 -0
  133. data/spec/opal/filters/unsupported/mutable_strings.rb +299 -1
  134. data/spec/opal/filters/unsupported/private_constants.rb +30 -0
  135. data/spec/opal/filters/unsupported/private_methods.rb +16 -0
  136. data/spec/opal/filters/unsupported/random.rb +4 -0
  137. data/spec/opal/filters/unsupported/tainted.rb +53 -0
  138. data/spec/opal/filters/unsupported/trusted.rb +5 -0
  139. data/spec/opal/rubyspecs +167 -234
  140. data/spec/opal/spec_helper.rb +3 -0
  141. data/spec/opal/stdlib/promise/error_spec.rb +15 -0
  142. data/spec/opal/stdlib/promise/rescue_spec.rb +35 -0
  143. data/spec/opal/stdlib/promise/then_spec.rb +54 -0
  144. data/spec/opal/stdlib/promise/trace_spec.rb +35 -0
  145. data/spec/opal/stdlib/promise/value_spec.rb +15 -0
  146. data/spec/opal/stdlib/promise/when_spec.rb +34 -0
  147. data/stdlib/base64.rb +152 -0
  148. data/stdlib/date.rb +82 -49
  149. data/{opal/corelib → stdlib}/encoding.rb +3 -1
  150. data/stdlib/erb.rb +0 -1
  151. data/stdlib/json.rb +10 -26
  152. data/stdlib/math.rb +370 -0
  153. data/stdlib/native.rb +40 -33
  154. data/stdlib/opal-parser.rb +7 -4
  155. data/stdlib/promise.rb +292 -0
  156. data/stdlib/strscan.rb +1 -1
  157. data/stdlib/template.rb +1 -3
  158. data/stdlib/time.rb +9 -0
  159. metadata +143 -204
  160. data/doc/compiler.md +0 -42
  161. data/doc/compiler_options.md +0 -5
  162. data/doc/examples/node_http_server.rb +0 -49
  163. data/doc/external_libraries.md +0 -9
  164. data/doc/generated_javascript.md +0 -272
  165. data/doc/home.md +0 -17
  166. data/doc/method_missing.md +0 -58
  167. data/doc/static_applications.md +0 -60
  168. data/doc/using_ruby_from_javascript.md +0 -18
  169. data/doc/using_sprockets.md +0 -65
  170. data/spec/opal/core/numeric/abs_spec.rb +0 -12
  171. data/spec/opal/core/numeric/downto_spec.rb +0 -19
  172. data/spec/opal/core/numeric/equal_value_spec.rb +0 -9
  173. data/spec/opal/core/numeric/even_spec.rb +0 -21
  174. data/spec/opal/core/numeric/magnitude_spec.rb +0 -12
  175. data/spec/opal/core/numeric/odd_spec.rb +0 -21
  176. data/spec/opal/core/string/chop_spec.rb +0 -10
  177. data/spec/opal/core/string/chr_spec.rb +0 -13
  178. data/spec/opal/core/string/clone_spec.rb +0 -8
  179. data/spec/opal/core/string/comparison_spec.rb +0 -13
  180. data/spec/opal/core/string/dup_spec.rb +0 -8
  181. data/spec/opal/core/string/element_reference_spec.rb +0 -96
  182. data/spec/opal/core/string/fixtures/classes.rb +0 -49
  183. data/spec/opal/core/string/format_spec.rb +0 -9
  184. data/spec/opal/core/string/freeze_spec.rb +0 -15
  185. data/spec/opal/core/string/gsub_spec.rb +0 -31
  186. data/spec/opal/core/string/lines_spec.rb +0 -9
  187. data/spec/opal/core/string/ljust_spec.rb +0 -32
  188. data/spec/opal/core/string/lstrip_spec.rb +0 -7
  189. data/spec/opal/core/string/match_spec.rb +0 -49
  190. data/spec/opal/core/string/next_spec.rb +0 -10
  191. data/spec/opal/core/string/ord_spec.rb +0 -9
  192. data/spec/opal/core/string/partition_spec.rb +0 -10
  193. data/spec/opal/core/string/rindex_spec.rb +0 -50
  194. data/spec/opal/core/string/rjust_spec.rb +0 -32
  195. data/spec/opal/core/string/rstrip_spec.rb +0 -7
  196. data/spec/opal/core/string/scan_spec.rb +0 -66
  197. data/spec/opal/core/string/slice_spec.rb +0 -74
  198. data/spec/opal/core/string/split_spec.rb +0 -5
  199. data/spec/opal/core/string/strip_spec.rb +0 -6
  200. data/spec/opal/core/string/sub_spec.rb +0 -38
  201. data/spec/opal/core/string/succ_spec.rb +0 -10
  202. data/spec/opal/core/string/sum_spec.rb +0 -5
  203. data/spec/opal/core/string/to_f_spec.rb +0 -14
  204. data/spec/opal/core/string/to_i_spec.rb +0 -25
  205. data/spec/opal/core/string/tr_s_spec.rb +0 -31
  206. data/spec/opal/core/string/tr_spec.rb +0 -31
  207. data/spec/opal/filters/bugs/parser.rb +0 -10
  208. data/spec/opal/filters/unsupported/immutable_strings.rb +0 -24
  209. data/spec/opal/filters/unsupported/string_subclasses.rb +0 -8
  210. data/spec/opal/parser/alias_spec.rb +0 -26
  211. data/spec/opal/parser/and_spec.rb +0 -13
  212. data/spec/opal/parser/array_spec.rb +0 -22
  213. data/spec/opal/parser/attrasgn_spec.rb +0 -28
  214. data/spec/opal/parser/begin_spec.rb +0 -42
  215. data/spec/opal/parser/block_spec.rb +0 -12
  216. data/spec/opal/parser/break_spec.rb +0 -17
  217. data/spec/opal/parser/call_spec.rb +0 -131
  218. data/spec/opal/parser/class_spec.rb +0 -35
  219. data/spec/opal/parser/const_spec.rb +0 -13
  220. data/spec/opal/parser/cvar_spec.rb +0 -11
  221. data/spec/opal/parser/def_spec.rb +0 -61
  222. data/spec/opal/parser/false_spec.rb +0 -17
  223. data/spec/opal/parser/file_spec.rb +0 -7
  224. data/spec/opal/parser/gvar_spec.rb +0 -13
  225. data/spec/opal/parser/hash_spec.rb +0 -17
  226. data/spec/opal/parser/heredoc_spec.rb +0 -30
  227. data/spec/opal/parser/iasgn_spec.rb +0 -9
  228. data/spec/opal/parser/if_spec.rb +0 -26
  229. data/spec/opal/parser/int_spec.rb +0 -13
  230. data/spec/opal/parser/iter_spec.rb +0 -59
  231. data/spec/opal/parser/ivar_spec.rb +0 -9
  232. data/spec/opal/parser/lambda_spec.rb +0 -64
  233. data/spec/opal/parser/lasgn_spec.rb +0 -8
  234. data/spec/opal/parser/line_spec.rb +0 -8
  235. data/spec/opal/parser/lvar_spec.rb +0 -38
  236. data/spec/opal/parser/masgn_spec.rb +0 -37
  237. data/spec/opal/parser/module_spec.rb +0 -27
  238. data/spec/opal/parser/nil_spec.rb +0 -17
  239. data/spec/opal/parser/not_spec.rb +0 -27
  240. data/spec/opal/parser/nth_ref_spec.rb +0 -13
  241. data/spec/opal/parser/op_asgn1_spec.rb +0 -23
  242. data/spec/opal/parser/op_asgn2_spec.rb +0 -23
  243. data/spec/opal/parser/or_spec.rb +0 -13
  244. data/spec/opal/parser/parse_spec.rb +0 -66
  245. data/spec/opal/parser/regexp_spec.rb +0 -16
  246. data/spec/opal/parser/return_spec.rb +0 -17
  247. data/spec/opal/parser/sclass_spec.rb +0 -21
  248. data/spec/opal/parser/self_spec.rb +0 -17
  249. data/spec/opal/parser/str_spec.rb +0 -107
  250. data/spec/opal/parser/string_spec.rb +0 -8
  251. data/spec/opal/parser/super_spec.rb +0 -20
  252. data/spec/opal/parser/true_spec.rb +0 -17
  253. data/spec/opal/parser/undef_spec.rb +0 -15
  254. data/spec/opal/parser/unless_spec.rb +0 -13
  255. data/spec/opal/parser/while_spec.rb +0 -15
  256. data/spec/opal/parser/xstr_spec.rb +0 -116
  257. data/spec/opal/parser/yield_spec.rb +0 -20
@@ -45,19 +45,10 @@ preclow
45
45
  rule
46
46
 
47
47
  program: top_compstmt
48
- {
49
- result = val[0]
50
- }
51
48
 
52
49
  top_compstmt: top_stmts opt_terms
53
50
  {
54
- comp = new_compstmt val[0]
55
- if comp and comp.type == :begin and comp.size == 2
56
- result = comp[1]
57
- result.line = comp.line
58
- else
59
- result = comp
60
- end
51
+ result = new_compstmt val[0]
61
52
  }
62
53
 
63
54
  top_stmts: # none
@@ -82,18 +73,12 @@ rule
82
73
 
83
74
  bodystmt: compstmt opt_rescue opt_else opt_ensure
84
75
  {
85
- result = new_body val[0], val[1], val[2], val[3]
76
+ result = new_body(val[0], val[1], val[2], val[3])
86
77
  }
87
78
 
88
79
  compstmt: stmts opt_terms
89
80
  {
90
- comp = new_compstmt val[0]
91
- if comp and comp.type == :begin and comp.size == 2
92
- result = comp[1]
93
- result.line = comp.line
94
- else
95
- result = comp
96
- end
81
+ result = new_compstmt val[0]
97
82
  }
98
83
 
99
84
  stmts: # none
@@ -116,16 +101,16 @@ rule
116
101
  }
117
102
  fitem
118
103
  {
119
- result = s(:alias, val[1], val[3])
104
+ result = new_alias(val[0], val[1], val[3])
120
105
  }
121
106
  | kALIAS tGVAR tGVAR
122
107
  {
123
- result = s(:valias, val[1].intern, val[2].intern)
108
+ result = s(:valias, value(val[1]).to_sym, value(val[2]).to_sym)
124
109
  }
125
110
  | kALIAS tGVAR tBACK_REF
126
111
  | kALIAS tGVAR tNTH_REF
127
112
  {
128
- result = s(:valias, val[1].intern, val[2].intern)
113
+ result = s(:valias, value(val[1]).to_sym, value(val[2]).to_sym)
129
114
  }
130
115
  | kUNDEF undef_list
131
116
  {
@@ -133,28 +118,28 @@ rule
133
118
  }
134
119
  | stmt kIF_MOD expr_value
135
120
  {
136
- result = new_if val[2], val[0], nil
121
+ result = new_if(val[1], val[2], val[0], nil)
137
122
  }
138
123
  | stmt kUNLESS_MOD expr_value
139
124
  {
140
- result = new_if val[2], nil, val[0]
125
+ result = new_if(val[1], val[2], nil, val[0])
141
126
  }
142
127
  | stmt kWHILE_MOD expr_value
143
128
  {
144
- result = s(:while, val[2], val[0], true)
129
+ result = new_while(val[1], val[2], val[0])
145
130
  }
146
131
  | stmt kUNTIL_MOD expr_value
147
132
  {
148
- result = s(:until, val[2], val[0], true)
133
+ result = new_until(val[1], val[2], val[0])
149
134
  }
150
135
  | stmt kRESCUE_MOD stmt
151
136
  {
152
- result = s(:rescue_mod, val[0], val[2])
137
+ result = new_rescue_mod(val[1], val[0], val[2])
153
138
  }
154
139
  | klEND tLCURLY compstmt tRCURLY
155
140
  | lhs tEQL command_call
156
141
  {
157
- result = new_assign val[0], val[2]
142
+ result = new_assign(val[0], val[1], val[2])
158
143
  }
159
144
  | mlhs tEQL command_call
160
145
  {
@@ -162,19 +147,19 @@ rule
162
147
  }
163
148
  | var_lhs tOP_ASGN command_call
164
149
  {
165
- result = new_op_asgn val[1].intern, val[0], val[2]
150
+ result = new_op_asgn val[1], val[0], val[2]
166
151
  }
167
152
  | primary_value tLBRACK2 aref_args tRBRACK tOP_ASGN command_call
168
153
  | primary_value tDOT tIDENTIFIER tOP_ASGN command_call
169
154
  {
170
- result = s(:op_asgn2, val[0], "#{val[2]}=".intern, val[3].intern, val[4])
155
+ result = s(:op_asgn2, val[0], op_to_setter(val[2]), value(val[3]).to_sym, val[4])
171
156
  }
172
157
  | primary_value tDOT tCONSTANT tOP_ASGN command_call
173
158
  | primary_value tCOLON2 tIDENTIFIER tOP_ASGN command_call
174
159
  | backref tOP_ASGN command_call
175
160
  | lhs tEQL mrhs
176
161
  {
177
- result = new_assign val[0], s(:svalue, val[2])
162
+ result = new_assign val[0], val[1], s(:svalue, val[2])
178
163
  }
179
164
  | mlhs tEQL arg_value
180
165
  {
@@ -190,21 +175,18 @@ rule
190
175
  | expr kAND expr
191
176
  {
192
177
  result = s(:and, val[0], val[2])
193
- result.line = val[0].line
194
178
  }
195
179
  | expr kOR expr
196
180
  {
197
181
  result = s(:or, val[0], val[2])
198
- result.line = val[0].line
199
182
  }
200
183
  | kNOT expr
201
184
  {
202
- result = s(:not, val[1])
203
- result.line = val[1].line
185
+ result = new_unary_call(['!', []], val[1])
204
186
  }
205
187
  | tBANG command_call
206
188
  {
207
- result = s(:not, val[1])
189
+ result = new_unary_call(val[0], val[1])
208
190
  }
209
191
  | arg
210
192
 
@@ -214,21 +196,15 @@ rule
214
196
  | block_command
215
197
  | kRETURN call_args
216
198
  {
217
- args = val[1]
218
- args = args[1] if args.size == 2
219
- result = s(:return, args)
199
+ result = new_return(val[0], val[1])
220
200
  }
221
201
  | kBREAK call_args
222
202
  {
223
- args = val[1]
224
- args = args[1] if args.size == 2
225
- result = s(:break, args)
203
+ result = new_break(val[0], val[1])
226
204
  }
227
205
  | kNEXT call_args
228
206
  {
229
- args = val[1]
230
- args = args[1] if args.size == 2
231
- result = s(:next, args)
207
+ result = new_next(val[0], val[1])
232
208
  }
233
209
 
234
210
  block_command: block_call
@@ -239,22 +215,22 @@ rule
239
215
 
240
216
  command: operation command_args =tLOWEST
241
217
  {
242
- result = new_call nil, val[0].intern, val[1]
218
+ result = new_call(nil, val[0], val[1])
243
219
  }
244
220
  | operation command_args cmd_brace_block
245
221
  | primary_value tDOT operation2 command_args =tLOWEST
246
222
  {
247
- result = new_call val[0], val[2].intern, val[3]
223
+ result = new_call(val[0], val[2], val[3])
248
224
  }
249
225
  | primary_value tDOT operation2 command_args cmd_brace_block
250
226
  | primary_value tCOLON2 operation2 command_args =tLOWEST
251
227
  {
252
- result = new_call val[0], val[2].intern, val[3]
228
+ result = new_call(val[0], val[2], val[3])
253
229
  }
254
230
  | primary_value tCOLON2 operation2 command_args cmd_brace_block
255
231
  | kSUPER command_args
256
232
  {
257
- result = new_super val[1]
233
+ result = new_super(val[0], val[1])
258
234
  }
259
235
  | kYIELD command_args
260
236
  {
@@ -334,13 +310,12 @@ rule
334
310
  }
335
311
  | primary_value tLBRACK2 aref_args tRBRACK
336
312
  {
337
- args = val[2]
338
- args.type = :arglist if args.type == :array
339
- result = s(:attrasgn, val[0], :[]=, args)
313
+ args = val[2] ? val[2] : []
314
+ result = s(:attrasgn, val[0], :[]=, s(:arglist, *args))
340
315
  }
341
316
  | primary_value tDOT tIDENTIFIER
342
317
  {
343
- result = new_call val[0], val[2].intern, s(:arglist)
318
+ result = new_call val[0], val[2], []
344
319
  }
345
320
  | primary_value tCOLON2 tIDENTIFIER
346
321
  | primary_value tDOT tCONSTANT
@@ -354,29 +329,27 @@ rule
354
329
  }
355
330
  | primary_value tLBRACK2 aref_args tRBRACK
356
331
  {
357
- args = val[2]
358
- args.type = :arglist if args.type == :array
359
- result = s(:attrasgn, val[0], :[]=, args)
332
+ result = new_attrasgn(val[0], :[]=, val[2])
360
333
  }
361
334
  | primary_value tDOT tIDENTIFIER
362
335
  {
363
- result = s(:attrasgn, val[0], "#{val[2]}=".intern, s(:arglist))
336
+ result = new_attrasgn(val[0], op_to_setter(val[2]))
364
337
  }
365
338
  | primary_value tCOLON2 tIDENTIFIER
366
339
  {
367
- result = s(:attrasgn, val[0], "#{val[2]}=".intern, s(:arglist))
340
+ result = new_attrasgn(val[0], op_to_setter(val[2]))
368
341
  }
369
342
  | primary_value tDOT tCONSTANT
370
343
  {
371
- result = s(:attrasgn, val[0], "#{val[2]}=".intern, s(:arglist))
344
+ result = new_attrasgn(val[0], op_to_setter(val[2]))
372
345
  }
373
346
  | primary_value tCOLON2 tCONSTANT
374
347
  {
375
- result = s(:colon2, val[0], val[2].intern)
348
+ result = new_colon2(val[0], val[1], val[2])
376
349
  }
377
350
  | tCOLON3 tCONSTANT
378
351
  {
379
- result = s(:colon3, val[1].intern)
352
+ result = new_colon3(val[0], val[1])
380
353
  }
381
354
  | backref
382
355
 
@@ -384,15 +357,15 @@ rule
384
357
 
385
358
  cpath: tCOLON3 cname
386
359
  {
387
- result = s(:colon3, val[1].intern)
360
+ result = new_colon3(val[0], val[1])
388
361
  }
389
362
  | cname
390
363
  {
391
- result = val[0].intern
364
+ result = new_const(val[0])
392
365
  }
393
366
  | primary_value tCOLON2 cname
394
367
  {
395
- result = s(:colon2, val[0], val[2].intern)
368
+ result = new_colon2(val[0], val[1], val[2])
396
369
  }
397
370
 
398
371
  fname: tIDENTIFIER
@@ -411,7 +384,7 @@ rule
411
384
 
412
385
  fitem: fname
413
386
  {
414
- result = s(:sym, val[0].intern)
387
+ result = new_sym(val[0])
415
388
  }
416
389
  | symbol
417
390
 
@@ -441,26 +414,23 @@ rule
441
414
 
442
415
  arg: lhs tEQL arg
443
416
  {
444
- result = new_assign val[0], val[2]
417
+ result = new_assign(val[0], val[1], val[2])
445
418
  }
446
419
  | lhs tEQL arg kRESCUE_MOD arg
447
420
  {
448
- result = new_assign val[0], s(:rescue_mod, val[2], val[4])
421
+ result = new_assign val[0], val[1], s(:rescue_mod, val[2], val[4])
449
422
  }
450
423
  | var_lhs tOP_ASGN arg
451
424
  {
452
- result = new_op_asgn val[1].intern, val[0], val[2]
425
+ result = new_op_asgn val[1], val[0], val[2]
453
426
  }
454
427
  | primary_value tLBRACK2 aref_args tRBRACK tOP_ASGN arg
455
428
  {
456
- args = val[2]
457
- args.type = :arglist if args.type == :array
458
- result = s(:op_asgn1, val[0], val[2], val[4].intern, val[5])
459
- result.line = val[0].line
429
+ result = new_op_asgn1(val[0], val[2], val[4], val[5])
460
430
  }
461
431
  | primary_value tDOT tIDENTIFIER tOP_ASGN arg
462
432
  {
463
- result = s(:op_asgn2, val[0], "#{val[2]}=".intern, val[3].intern, val[4])
433
+ result = s(:op_asgn2, val[0], op_to_setter(val[2]), value(val[3]).to_sym, val[4])
464
434
  }
465
435
  | primary_value tDOT tCONSTANT tOP_ASGN arg
466
436
  | primary_value tCOLON2 tIDENTIFIER tOP_ASGN arg
@@ -469,48 +439,46 @@ rule
469
439
  | backref tOP_ASGN arg
470
440
  | arg tDOT2 arg
471
441
  {
472
- result = s(:irange, val[0], val[2])
473
- result.line = val[0].line
442
+ result = new_irange(val[0], val[1], val[2])
474
443
  }
475
444
  | arg tDOT3 arg
476
445
  {
477
- result = s(:erange, val[0], val[2])
478
- result.line = val[0].line
446
+ result = new_erange(val[0], val[1], val[2])
479
447
  }
480
448
  | arg tPLUS arg
481
449
  {
482
- result = new_call val[0], :"+", s(:arglist, val[2])
450
+ result = new_binary_call(val[0], val[1], val[2])
483
451
  }
484
452
  | arg tMINUS arg
485
453
  {
486
- result = new_call val[0], :"-", s(:arglist, val[2])
454
+ result = new_binary_call(val[0], val[1], val[2])
487
455
  }
488
456
  | arg tSTAR2 arg
489
457
  {
490
- result = new_call val[0], :"*", s(:arglist, val[2])
458
+ result = new_binary_call(val[0], val[1], val[2])
491
459
  }
492
460
  | arg tDIVIDE arg
493
461
  {
494
- result = new_call val[0], :"/", s(:arglist, val[2])
462
+ result = new_binary_call(val[0], val[1], val[2])
495
463
  }
496
464
  | arg tPERCENT arg
497
465
  {
498
- result = new_call val[0], :"%", s(:arglist, val[2])
466
+ result = new_binary_call(val[0], val[1], val[2])
499
467
  }
500
468
  | arg tPOW arg
501
469
  {
502
- result = new_call val[0], :"**", s(:arglist, val[2])
470
+ result = new_binary_call(val[0], val[1], val[2])
503
471
  }
504
472
  | '-@NUM' tINTEGER tPOW arg
505
473
  | '-@NUM' tFLOAT tPOW arg
506
474
  | tUPLUS arg
507
475
  {
508
- result = new_call val[1], :"+@", s(:arglist)
476
+ result = new_call val[1], [:"+@", []], []
509
477
  result = val[1] if [:int, :float].include? val[1].type
510
478
  }
511
479
  | tUMINUS arg
512
480
  {
513
- result = new_call val[1], :"-@", s(:arglist)
481
+ result = new_call val[1], [:"-@", []], []
514
482
  if val[1].type == :int
515
483
  val[1][1] = -val[1][1]
516
484
  result = val[1]
@@ -521,81 +489,81 @@ rule
521
489
  }
522
490
  | arg tPIPE arg
523
491
  {
524
- result = new_call val[0], :"|", s(:arglist, val[2])
492
+ result = new_binary_call(val[0], val[1], val[2])
525
493
  }
526
494
  | arg tCARET arg
527
495
  {
528
- result = new_call val[0], :"^", s(:arglist, val[2])
496
+ result = new_binary_call(val[0], val[1], val[2])
529
497
  }
530
498
  | arg tAMPER2 arg
531
499
  {
532
- result = new_call val[0], :"&", s(:arglist, val[2])
500
+ result = new_binary_call(val[0], val[1], val[2])
533
501
  }
534
502
  | arg tCMP arg
535
503
  {
536
- result = new_call val[0], :"<=>", s(:arglist, val[2])
504
+ result = new_binary_call(val[0], val[1], val[2])
537
505
  }
538
506
  | arg tGT arg
539
507
  {
540
- result = new_call val[0], :">", s(:arglist, val[2])
508
+ result = new_binary_call(val[0], val[1], val[2])
541
509
  }
542
510
  | arg tGEQ arg
543
511
  {
544
- result = new_call val[0], :">=", s(:arglist, val[2])
512
+ result = new_binary_call(val[0], val[1], val[2])
545
513
  }
546
514
  | arg tLT arg
547
515
  {
548
- result = new_call val[0], :"<", s(:arglist, val[2])
516
+ result = new_binary_call(val[0], val[1], val[2])
549
517
  }
550
518
  | arg tLEQ arg
551
519
  {
552
- result = new_call val[0], :"<=", s(:arglist, val[2])
520
+ result = new_binary_call(val[0], val[1], val[2])
553
521
  }
554
522
  | arg tEQ arg
555
523
  {
556
- result = new_call val[0], :"==", s(:arglist, val[2])
524
+ result = new_binary_call(val[0], val[1], val[2])
557
525
  }
558
526
  | arg tEQQ arg
559
527
  {
560
- result = new_call val[0], :"===", s(:arglist, val[2])
528
+ result = new_binary_call(val[0], val[1], val[2])
561
529
  }
562
530
  | arg tNEQ arg
563
531
  {
564
- result = s(:not, new_call(val[0], :"==", s(:arglist, val[2])))
532
+ result = new_unary_call(['!', []], new_binary_call(
533
+ val[0], ['==', []], val[2]))
565
534
  }
566
535
  | arg tMATCH arg
567
536
  {
568
- result = new_call val[0], :"=~", s(:arglist, val[2])
537
+ result = new_binary_call(val[0], val[1], val[2])
569
538
  }
570
539
  | arg tNMATCH arg
571
540
  {
572
- result = s(:not, new_call(val[0], :"=~", s(:arglist, val[2])))
541
+ result = new_not(val[1], new_binary_call(
542
+ val[0], ['=~', []], val[2]))
573
543
  }
574
544
  | tBANG arg
575
545
  {
576
- result = s(:not, val[1])
546
+ result = new_unary_call(val[0], val[1])
577
547
  }
578
548
  | tTILDE arg
579
549
  {
580
- result = new_call val[1], :"~", s(:arglist)
550
+ result = new_unary_call(val[0], val[1])
581
551
  }
582
552
  | arg tLSHFT arg
583
553
  {
584
- result = new_call val[0], :"<<", s(:arglist, val[2])
554
+ result = new_binary_call(val[0], val[1], val[2])
585
555
  }
586
556
  | arg tRSHFT arg
587
557
  {
588
- result = new_call val[0], :">>", s(:arglist, val[2])
558
+ result = new_binary_call(val[0], val[1], val[2])
589
559
  }
590
560
  | arg tANDOP arg
591
561
  {
592
- result = s(:and, val[0], val[2])
593
- result.line = val[0].line
562
+ result = new_and(val[0], val[1], val[2])
594
563
  }
595
564
  | arg tOROP arg
596
565
  {
597
- result = s(:or, val[0], val[2])
598
- result.line = val[0].line
566
+ result = new_or(val[0], val[1], val[2])
599
567
  }
600
568
  | kDEFINED opt_nl arg
601
569
  {
@@ -603,8 +571,7 @@ rule
603
571
  }
604
572
  | arg tEH arg tCOLON arg
605
573
  {
606
- result = s(:if, val[0], val[2], val[4])
607
- result.line = val[0].line
574
+ result = new_if(val[1], val[0], val[2], val[4])
608
575
  }
609
576
  | primary
610
577
 
@@ -616,7 +583,7 @@ rule
616
583
  }
617
584
  | command opt_nl
618
585
  {
619
- result = s(:array, val[0])
586
+ result = [val[0]]
620
587
  }
621
588
  | args trailer
622
589
  {
@@ -629,12 +596,12 @@ rule
629
596
  }
630
597
  | assocs trailer
631
598
  {
632
- result = s(:array, s(:hash, *val[0]))
599
+ result = [s(:hash, *val[0])]
633
600
  }
634
601
 
635
602
  paren_args: tLPAREN2 none tRPAREN
636
603
  {
637
- result = nil
604
+ result = []
638
605
  }
639
606
  | tLPAREN2 call_args opt_nl tRPAREN
640
607
  {
@@ -644,11 +611,14 @@ rule
644
611
  | tLPAREN2 args tCOMMA block_call opt_nl tRPAREN
645
612
 
646
613
  opt_paren_args: none
614
+ {
615
+ result = []
616
+ }
647
617
  | paren_args
648
618
 
649
619
  call_args: command
650
620
  {
651
- result = s(:array, val[0])
621
+ result = [val[0]]
652
622
  }
653
623
  | args opt_block_arg
654
624
  {
@@ -657,17 +627,17 @@ rule
657
627
  }
658
628
  | assocs opt_block_arg
659
629
  {
660
- result = s(:arglist, s(:hash, *val[0]))
630
+ result = [new_hash(nil, val[0], nil)]
661
631
  add_block_pass result, val[1]
662
632
  }
663
633
  | args tCOMMA assocs opt_block_arg
664
634
  {
665
635
  result = val[0]
666
- result << s(:hash, *val[2])
636
+ result << new_hash(nil, val[2], nil)
667
637
  }
668
638
  | block_arg
669
639
  {
670
- result = s(:arglist)
640
+ result = []
671
641
  add_block_pass result, val[0]
672
642
  }
673
643
 
@@ -695,7 +665,7 @@ rule
695
665
 
696
666
  block_arg: tAMPER arg_value
697
667
  {
698
- result = s(:block_pass, val[1])
668
+ result = new_block_pass(val[0], val[1])
699
669
  }
700
670
 
701
671
  opt_block_arg: tCOMMA block_arg
@@ -709,11 +679,11 @@ rule
709
679
 
710
680
  args: arg_value
711
681
  {
712
- result = s(:array, val[0])
682
+ result = [val[0]]
713
683
  }
714
684
  | tSTAR arg_value
715
685
  {
716
- result = s(:array, s(:splat, val[1]))
686
+ result = [new_splat(val[0], val[1])]
717
687
  }
718
688
  | args tCOMMA arg_value
719
689
  {
@@ -721,13 +691,13 @@ rule
721
691
  }
722
692
  | args tCOMMA tSTAR arg_value
723
693
  {
724
- result = val[0] << s(:splat, val[3])
694
+ result = val[0] << new_splat(val[2], val[3])
725
695
  }
726
696
 
727
697
  mrhs: args tCOMMA arg_value
728
698
  {
729
699
  val[0] << val[2]
730
- result = val[0]
700
+ result = s(:array, *val[0])
731
701
  }
732
702
  | args tCOMMA tSTAR arg_value
733
703
  | tSTAR arg_value
@@ -751,7 +721,6 @@ rule
751
721
  bodystmt kEND
752
722
  {
753
723
  result = s(:begin, val[2])
754
- result.line = val[1]
755
724
  }
756
725
  | tLPAREN_ARG expr opt_nl tRPAREN
757
726
  {
@@ -759,31 +728,31 @@ rule
759
728
  }
760
729
  | tLPAREN compstmt tRPAREN
761
730
  {
762
- result = s(:paren, val[1] || s(:nil))
731
+ result = new_paren(val[0], val[1], val[2])
763
732
  }
764
733
  | primary_value tCOLON2 tCONSTANT
765
734
  {
766
- result = s(:colon2, val[0], val[2].intern)
735
+ result = new_colon2(val[0], val[1], val[2])
767
736
  }
768
737
  | tCOLON3 tCONSTANT
769
738
  {
770
- result = s(:colon3, val[1])
739
+ result = new_colon3(val[0], val[1])
771
740
  }
772
741
  | primary_value tLBRACK2 aref_args tRBRACK
773
742
  {
774
- result = new_call val[0], :[], val[2]
743
+ result = new_call val[0], [:[], []], val[2]
775
744
  }
776
745
  | tLBRACK aref_args tRBRACK
777
746
  {
778
- result = val[1] || s(:array)
747
+ result = new_array(val[0], val[1], val[2])
779
748
  }
780
- | '{' assoc_list tRCURLY
749
+ | tLBRACE assoc_list tRCURLY
781
750
  {
782
- result = s(:hash, *val[1])
751
+ result = new_hash(val[0], val[1], val[2])
783
752
  }
784
753
  | kRETURN
785
754
  {
786
- result = s(:return)
755
+ result = new_return(val[0])
787
756
  }
788
757
  | kYIELD tLPAREN2 call_args tRPAREN
789
758
  {
@@ -803,16 +772,15 @@ rule
803
772
  }
804
773
  | kNOT tLPAREN2 expr tRPAREN
805
774
  {
806
- result = s(:not, val[2])
807
- result.line = val[2].line
775
+ result = new_unary_call(['!', []], val[2])
808
776
  }
809
777
  | kNOT tLPAREN2 tRPAREN
810
778
  {
811
- result = s(:not, s(:nil))
779
+ result = new_unary_call(['!', []], new_nil(val[0]))
812
780
  }
813
781
  | operation brace_block
814
782
  {
815
- result = new_call nil, val[0].intern, s(:arglist)
783
+ result = new_call(nil, val[0], [])
816
784
  result << val[1]
817
785
  }
818
786
  | method_call
@@ -827,11 +795,11 @@ rule
827
795
  }
828
796
  | kIF expr_value then compstmt if_tail kEND
829
797
  {
830
- result = new_if val[1], val[3], val[4]
798
+ result = new_if(val[0], val[1], val[3], val[4])
831
799
  }
832
800
  | kUNLESS expr_value then compstmt opt_else kEND
833
801
  {
834
- result = new_if val[1], val[4], val[3]
802
+ result = new_if(val[0], val[1], val[4], val[3])
835
803
  }
836
804
  | kWHILE
837
805
  {
@@ -844,8 +812,7 @@ rule
844
812
  }
845
813
  compstmt kEND
846
814
  {
847
- result = s(:while, val[2], val[5], true)
848
- result.line = val[1]
815
+ result = s(:while, val[2], val[5])
849
816
  }
850
817
  | kUNTIL
851
818
  {
@@ -858,23 +825,19 @@ rule
858
825
  }
859
826
  compstmt kEND
860
827
  {
861
- result = s(:until, val[2], val[5], true)
862
- result.line = val[1]
828
+ result = s(:until, val[2], val[5])
863
829
  }
864
830
  | kCASE expr_value opt_terms case_body kEND
865
831
  {
866
832
  result = s(:case, val[1], *val[3])
867
- result.line = val[1].line
868
833
  }
869
834
  | kCASE opt_terms case_body kEND
870
835
  {
871
836
  result = s(:case, nil, *val[2])
872
- # result.line = val[2].line
873
837
  }
874
838
  | kCASE opt_terms kELSE compstmt kEND
875
839
  {
876
840
  result = s(:case, nil, val[3])
877
- # result.line = val[3].line
878
841
  }
879
842
  | kFOR mlhs kIN
880
843
  {
@@ -885,19 +848,13 @@ rule
885
848
  # ...
886
849
  }
887
850
  compstmt kEND
888
- | kCLASS
889
- {
890
- result = lexer.line
891
- }
892
- cpath superclass
851
+ | kCLASS cpath superclass
893
852
  {
894
853
  # ...
895
854
  }
896
855
  bodystmt kEND
897
856
  {
898
- result = new_class val[2], val[3], val[5]
899
- result.line = val[1]
900
- result.end_line = lexer.line
857
+ result = new_class val[0], val[1], val[2], val[4], val[5]
901
858
  }
902
859
  | kCLASS tLSHFT
903
860
  {
@@ -909,8 +866,7 @@ rule
909
866
  }
910
867
  bodystmt kEND
911
868
  {
912
- result = new_sclass val[3], val[6]
913
- result.line = val[2]
869
+ result = new_sclass(val[0], val[3], val[6], val[7])
914
870
  }
915
871
  | kMODULE
916
872
  {
@@ -922,18 +878,15 @@ rule
922
878
  }
923
879
  bodystmt kEND
924
880
  {
925
- result = new_module val[2], val[4]
926
- result.line = val[1]
927
- result.end_line = lexer.line
881
+ result = new_module(val[0], val[2], val[4], val[5])
928
882
  }
929
883
  | kDEF fname
930
884
  {
931
- result = lexer.scope_line
932
885
  push_scope
933
886
  }
934
887
  f_arglist bodystmt kEND
935
888
  {
936
- result = new_def val[2], nil, val[1], val[3], val[4]
889
+ result = new_def(val[0], nil, val[1], val[3], val[4], val[5])
937
890
  pop_scope
938
891
  }
939
892
  | kDEF singleton dot_or_colon
@@ -942,17 +895,16 @@ rule
942
895
  }
943
896
  fname
944
897
  {
945
- result = lexer.scope_line
946
898
  push_scope
947
899
  }
948
900
  f_arglist bodystmt kEND
949
901
  {
950
- result = new_def val[5], val[1], val[4], val[6], val[7]
902
+ result = new_def(val[0], val[1], val[4], val[6], val[7], val[8])
951
903
  pop_scope
952
904
  }
953
905
  | kBREAK
954
906
  {
955
- result = s(:break)
907
+ result = new_break(val[0])
956
908
  }
957
909
  | kNEXT
958
910
  {
@@ -977,7 +929,7 @@ rule
977
929
 
978
930
  lambda: f_larglist lambda_body
979
931
  {
980
- result = new_call nil, :lambda, s(:arglist)
932
+ result = new_call nil, [:lambda, []], []
981
933
  result << new_iter(val[0], val[1])
982
934
  }
983
935
 
@@ -1005,14 +957,9 @@ rule
1005
957
  {
1006
958
  result = val[0]
1007
959
  }
1008
- | kELSIF
960
+ | kELSIF expr_value then compstmt if_tail
1009
961
  {
1010
- result = lexer.line
1011
- }
1012
- expr_value then compstmt if_tail
1013
- {
1014
- result = s(:if, val[2], val[4], val[5])
1015
- result.line = val[1]
962
+ result = new_if(val[0], val[1], val[3], val[4])
1016
963
  }
1017
964
 
1018
965
  opt_else: none
@@ -1033,17 +980,18 @@ rule
1033
980
 
1034
981
  f_block_opt: tIDENTIFIER tEQL primary_value
1035
982
  {
1036
- result = new_assign new_assignable(s(:identifier, val[0].intern)), val[2]
983
+ result = new_assign(new_assignable(new_ident(
984
+ val[0])), val[1], val[2])
1037
985
  }
1038
986
 
1039
987
  opt_block_var: none
1040
988
  | tPIPE tPIPE
1041
989
  {
1042
- result = 0
990
+ result = nil
1043
991
  }
1044
992
  | tOROP
1045
993
  {
1046
- result = 0
994
+ result = nil
1047
995
  }
1048
996
  | tPIPE block_param tPIPE
1049
997
  {
@@ -1066,39 +1014,39 @@ opt_block_args_tail: tCOMMA block_args_tail
1066
1014
 
1067
1015
  block_param: f_arg tCOMMA f_block_optarg tCOMMA f_rest_arg opt_block_args_tail
1068
1016
  {
1069
- result = new_block_args val[0], val[2], val[4], val[5]
1017
+ result = new_block_args(val[0], val[2], val[4], val[5])
1070
1018
  }
1071
1019
  | f_arg tCOMMA f_block_optarg opt_block_args_tail
1072
1020
  {
1073
- result = new_block_args val[0], val[2], nil, val[3]
1021
+ result = new_block_args(val[0], val[2], nil, val[3])
1074
1022
  }
1075
1023
  | f_arg tCOMMA f_rest_arg opt_block_args_tail
1076
1024
  {
1077
- result = new_block_args val[0], nil, val[2], val[3]
1025
+ result = new_block_args(val[0], nil, val[2], val[3])
1078
1026
  }
1079
1027
  | f_arg tCOMMA
1080
1028
  {
1081
- result = new_block_args val[0], nil, nil, nil
1029
+ result = new_block_args(val[0], nil, nil, nil)
1082
1030
  }
1083
1031
  | f_arg opt_block_args_tail
1084
1032
  {
1085
- result = new_block_args val[0], nil, nil, val[1]
1033
+ result = new_block_args(val[0], nil, nil, val[1])
1086
1034
  }
1087
1035
  | f_block_optarg tCOMMA f_rest_arg opt_block_args_tail
1088
1036
  {
1089
- result = new_block_args nil, val[0], val[2], val[3]
1037
+ result = new_block_args(nil, val[0], val[2], val[3])
1090
1038
  }
1091
1039
  | f_block_optarg opt_block_args_tail
1092
1040
  {
1093
- result = new_block_args nil, val[0], nil, val[1]
1041
+ result = new_block_args(nil, val[0], nil, val[1])
1094
1042
  }
1095
1043
  | f_rest_arg opt_block_args_tail
1096
1044
  {
1097
- result = new_block_args nil, nil, val[0], val[1]
1045
+ result = new_block_args(nil, nil, val[0], val[1])
1098
1046
  }
1099
1047
  | block_args_tail
1100
1048
  {
1101
- result = new_block_args nil, nil, nil, val[0]
1049
+ result = new_block_args(nil, nil, nil, val[0])
1102
1050
  }
1103
1051
 
1104
1052
  do_block: kDO_BLOCK
@@ -1109,7 +1057,6 @@ opt_block_args_tail: tCOMMA block_args_tail
1109
1057
  opt_block_var compstmt kEND
1110
1058
  {
1111
1059
  result = new_iter val[2], val[3]
1112
- result.line = val[1]
1113
1060
  pop_scope
1114
1061
  }
1115
1062
 
@@ -1123,31 +1070,31 @@ opt_block_args_tail: tCOMMA block_args_tail
1123
1070
 
1124
1071
  method_call: operation paren_args
1125
1072
  {
1126
- result = new_call nil, val[0].intern, val[1]
1073
+ result = new_call(nil, val[0], val[1])
1127
1074
  }
1128
1075
  | primary_value tDOT operation2 opt_paren_args
1129
1076
  {
1130
- result = new_call val[0], val[2].intern, val[3]
1077
+ result = new_call(val[0], val[2], val[3])
1131
1078
  }
1132
1079
  | primary_value tDOT paren_args
1133
1080
  {
1134
- result = new_call val[0], :call, val[2]
1081
+ result = new_call(val[0], [:call, []], val[2])
1135
1082
  }
1136
1083
  | primary_value tCOLON2 operation2 paren_args
1137
1084
  {
1138
- result = new_call val[0], val[2].intern, val[3]
1085
+ result = new_call(val[0], val[2], val[3])
1139
1086
  }
1140
1087
  | primary_value tCOLON2 operation3
1141
1088
  {
1142
- result = new_call val[0], val[2].intern, s(:arglist)
1089
+ result = new_call(val[0], val[2])
1143
1090
  }
1144
1091
  | kSUPER paren_args
1145
1092
  {
1146
- result = new_super val[1]
1093
+ result = new_super(val[0], val[1])
1147
1094
  }
1148
1095
  | kSUPER
1149
1096
  {
1150
- result = s(:super, nil)
1097
+ result = new_super(val[0], nil)
1151
1098
  }
1152
1099
 
1153
1100
  brace_block: tLCURLY
@@ -1158,7 +1105,6 @@ opt_block_args_tail: tCOMMA block_args_tail
1158
1105
  opt_block_var compstmt tRCURLY
1159
1106
  {
1160
1107
  result = new_iter val[2], val[3]
1161
- result.line = val[1]
1162
1108
  pop_scope
1163
1109
  }
1164
1110
  | kDO
@@ -1169,7 +1115,6 @@ opt_block_args_tail: tCOMMA block_args_tail
1169
1115
  opt_block_var compstmt kEND
1170
1116
  {
1171
1117
  result = new_iter val[2], val[3]
1172
- result.line = val[1]
1173
1118
  pop_scope
1174
1119
  }
1175
1120
 
@@ -1179,8 +1124,7 @@ opt_block_args_tail: tCOMMA block_args_tail
1179
1124
  }
1180
1125
  args then compstmt cases
1181
1126
  {
1182
- part = s(:when, val[2], val[4])
1183
- part.line = val[2].line
1127
+ part = s(:when, s(:array, *val[2]), val[4])
1184
1128
  result = [part]
1185
1129
  result.push *val[5] if val[5]
1186
1130
  }
@@ -1194,7 +1138,7 @@ opt_block_args_tail: tCOMMA block_args_tail
1194
1138
  opt_rescue: kRESCUE exc_list exc_var then compstmt opt_rescue
1195
1139
  {
1196
1140
  exc = val[1] || s(:array)
1197
- exc << new_assign(val[2], s(:gvar, '$!'.intern)) if val[2]
1141
+ exc << new_assign(val[2], val[2], s(:gvar, '$!'.intern)) if val[2]
1198
1142
  result = [s(:resbody, exc, val[4])]
1199
1143
  result.push val[5].first if val[5]
1200
1144
  }
@@ -1243,12 +1187,12 @@ opt_block_args_tail: tCOMMA block_args_tail
1243
1187
  }
1244
1188
  | tSTRING
1245
1189
  {
1246
- result = s(:str, val[0])
1190
+ result = s(:str, value(val[0]))
1247
1191
  }
1248
1192
 
1249
1193
  xstring: tXSTRING_BEG xstring_contents tSTRING_END
1250
1194
  {
1251
- result = new_xstr val[1]
1195
+ result = new_xstr(val[0], val[1], val[2])
1252
1196
  }
1253
1197
 
1254
1198
  regexp: tREGEXP_BEG xstring_contents tREGEXP_END
@@ -1300,7 +1244,7 @@ opt_block_args_tail: tCOMMA block_args_tail
1300
1244
  }
1301
1245
  | qword_list tSTRING_CONTENT tSPACE
1302
1246
  {
1303
- result = val[0] << s(:str, val[1])
1247
+ result = val[0] << s(:str, value(val[1]))
1304
1248
  }
1305
1249
 
1306
1250
  string_contents: none
@@ -1323,7 +1267,7 @@ xstring_contents: none
1323
1267
 
1324
1268
  string_content: tSTRING_CONTENT
1325
1269
  {
1326
- result = s(:str, val[0])
1270
+ result = new_str_content(val[0])
1327
1271
  }
1328
1272
  | tSTRING_DVAR
1329
1273
  {
@@ -1333,7 +1277,7 @@ xstring_contents: none
1333
1277
  string_dvar
1334
1278
  {
1335
1279
  lexer.strterm = val[1]
1336
- result = s(:evstr, val[2])
1280
+ result = new_evstr(val[2])
1337
1281
  }
1338
1282
  | tSTRING_DBEG
1339
1283
  {
@@ -1348,32 +1292,32 @@ xstring_contents: none
1348
1292
  lexer.strterm = val[1]
1349
1293
  lexer.cond_lexpop
1350
1294
  lexer.cmdarg_lexpop
1351
- result = s(:evstr, val[2])
1295
+ result = new_evstr(val[2])
1352
1296
  }
1353
1297
 
1354
1298
  string_dvar: tGVAR
1355
1299
  {
1356
- result = s(:gvar, val[0].intern)
1300
+ result = new_gvar(val[0])
1357
1301
  }
1358
1302
  | tIVAR
1359
1303
  {
1360
- result = s(:ivar, val[0].intern)
1304
+ result = new_ivar(val[0])
1361
1305
  }
1362
1306
  | tCVAR
1363
1307
  {
1364
- result = s(:cvar, val[0].intern)
1308
+ result = new_cvar(val[0])
1365
1309
  }
1366
1310
  | backref
1367
1311
 
1368
1312
 
1369
1313
  symbol: tSYMBEG sym
1370
1314
  {
1371
- result = s(:sym, val[1].intern)
1315
+ result = new_sym(val[1])
1372
1316
  lexer.lex_state = :expr_end
1373
1317
  }
1374
1318
  | tSYMBOL
1375
1319
  {
1376
- result = s(:sym, val[0].intern)
1320
+ result = new_sym(val[0])
1377
1321
  }
1378
1322
 
1379
1323
  sym: fname
@@ -1388,63 +1332,63 @@ xstring_contents: none
1388
1332
 
1389
1333
  numeric: tINTEGER
1390
1334
  {
1391
- result = s(:int, val[0])
1335
+ result = new_int(val[0])
1392
1336
  }
1393
1337
  | tFLOAT
1394
1338
  {
1395
- result = s(:float, val[0])
1339
+ result = new_float(val[0])
1396
1340
  }
1397
1341
  | '-@NUM' tINTEGER =tLOWEST
1398
1342
  | '-@NUM' tFLOAT =tLOWEST
1399
1343
 
1400
1344
  variable: tIDENTIFIER
1401
1345
  {
1402
- result = s(:identifier, val[0].intern)
1346
+ result = new_ident(val[0])
1403
1347
  }
1404
1348
  | tIVAR
1405
1349
  {
1406
- result = s(:ivar, val[0].intern)
1350
+ result = new_ivar(val[0])
1407
1351
  }
1408
1352
  | tGVAR
1409
1353
  {
1410
- result = s(:gvar, val[0].intern)
1354
+ result = new_gvar(val[0])
1411
1355
  }
1412
1356
  | tCONSTANT
1413
1357
  {
1414
- result = s(:const, val[0].intern)
1358
+ result = new_const(val[0])
1415
1359
  }
1416
1360
  | tCVAR
1417
1361
  {
1418
- result = s(:cvar, val[0].intern)
1362
+ result = new_cvar(val[0])
1419
1363
  }
1420
1364
  | kNIL
1421
1365
  {
1422
- result = s(:nil)
1366
+ result = new_nil(val[0])
1423
1367
  }
1424
1368
  | kSELF
1425
1369
  {
1426
- result = s(:self)
1370
+ result = new_self(val[0])
1427
1371
  }
1428
1372
  | kTRUE
1429
1373
  {
1430
- result = s(:true)
1374
+ result = new_true(val[0])
1431
1375
  }
1432
1376
  | kFALSE
1433
1377
  {
1434
- result = s(:false)
1378
+ result = new_false(val[0])
1435
1379
  }
1436
1380
  | k__FILE__
1437
1381
  {
1438
- result = s(:str, self.file)
1382
+ result = new___FILE__(val[0])
1439
1383
  }
1440
1384
  | k__LINE__
1441
1385
  {
1442
- result = s(:int, lexer.line)
1386
+ result = new___LINE__(val[0])
1443
1387
  }
1444
1388
 
1445
1389
  var_ref: variable
1446
1390
  {
1447
- result = new_var_ref val[0]
1391
+ result = new_var_ref(val[0])
1448
1392
  }
1449
1393
 
1450
1394
  var_lhs: variable
@@ -1454,7 +1398,7 @@ xstring_contents: none
1454
1398
 
1455
1399
  backref: tNTH_REF
1456
1400
  {
1457
- result = s(:nth_ref, val[0])
1401
+ result = s(:nth_ref, value(val[0]))
1458
1402
  }
1459
1403
  | tBACK_REF
1460
1404
 
@@ -1483,45 +1427,45 @@ xstring_contents: none
1483
1427
 
1484
1428
  f_args: f_arg tCOMMA f_optarg tCOMMA f_rest_arg opt_f_block_arg
1485
1429
  {
1486
- result = new_args val[0], val[2], val[4], val[5]
1430
+ result = new_args(val[0], val[2], val[4], val[5])
1487
1431
  }
1488
1432
  | f_arg tCOMMA f_optarg opt_f_block_arg
1489
1433
  {
1490
- result = new_args val[0], val[2], nil, val[3]
1434
+ result = new_args(val[0], val[2], nil, val[3])
1491
1435
  }
1492
1436
  | f_arg tCOMMA f_rest_arg opt_f_block_arg
1493
1437
  {
1494
- result = new_args val[0], nil, val[2], val[3]
1438
+ result = new_args(val[0], nil, val[2], val[3])
1495
1439
  }
1496
1440
  | f_arg opt_f_block_arg
1497
1441
  {
1498
- result = new_args val[0], nil, nil, val[1]
1442
+ result = new_args(val[0], nil, nil, val[1])
1499
1443
  }
1500
1444
  | f_optarg tCOMMA f_rest_arg opt_f_block_arg
1501
1445
  {
1502
- result = new_args nil, val[0], val[2], val[3]
1446
+ result = new_args(nil, val[0], val[2], val[3])
1503
1447
  }
1504
1448
  | f_optarg opt_f_block_arg
1505
1449
  {
1506
- result = new_args nil, val[0], nil, val[1]
1450
+ result = new_args(nil, val[0], nil, val[1])
1507
1451
  }
1508
1452
  | f_rest_arg opt_f_block_arg
1509
1453
  {
1510
- result = new_args nil, nil, val[0], val[1]
1454
+ result = new_args(nil, nil, val[0], val[1])
1511
1455
  }
1512
1456
  | f_block_arg
1513
1457
  {
1514
- result = new_args nil, nil, nil, val[0]
1458
+ result = new_args(nil, nil, nil, val[0])
1515
1459
  }
1516
1460
  | # none
1517
1461
  {
1518
- result = s(:args)
1462
+ result = new_args(nil, nil, nil, nil)
1519
1463
  }
1520
1464
 
1521
1465
  f_norm_arg: f_bad_arg
1522
1466
  | tIDENTIFIER
1523
1467
  {
1524
- result = val[0].intern
1468
+ result = value(val[0]).to_sym
1525
1469
  scope.add_local result
1526
1470
  }
1527
1471
 
@@ -1585,7 +1529,7 @@ xstring_contents: none
1585
1529
 
1586
1530
  f_opt: tIDENTIFIER tEQL arg_value
1587
1531
  {
1588
- result = new_assign new_assignable(s(:identifier, val[0].intern)), val[2]
1532
+ result = new_assign(new_assignable(new_ident(val[0])), val[1], val[2])
1589
1533
  }
1590
1534
 
1591
1535
  f_optarg: f_opt
@@ -1603,7 +1547,7 @@ xstring_contents: none
1603
1547
 
1604
1548
  f_rest_arg: restarg_mark tIDENTIFIER
1605
1549
  {
1606
- result = "*#{val[1]}".intern
1550
+ result = "*#{value(val[1])}".to_sym
1607
1551
  }
1608
1552
  | restarg_mark
1609
1553
  {
@@ -1615,7 +1559,7 @@ xstring_contents: none
1615
1559
 
1616
1560
  f_block_arg: blkarg_mark tIDENTIFIER
1617
1561
  {
1618
- result = "&#{val[1]}".intern
1562
+ result = "&#{value(val[1])}".to_sym
1619
1563
  }
1620
1564
 
1621
1565
  opt_f_block_arg: tCOMMA f_block_arg
@@ -1651,7 +1595,7 @@ xstring_contents: none
1651
1595
  }
1652
1596
  | assocs tCOMMA assoc
1653
1597
  {
1654
- result = val[0].push *val[2]
1598
+ result = val[0].push(*val[2])
1655
1599
  }
1656
1600
 
1657
1601
  assoc: arg_value tASSOC arg_value
@@ -1660,7 +1604,7 @@ xstring_contents: none
1660
1604
  }
1661
1605
  | tLABEL arg_value
1662
1606
  {
1663
- result = [s(:sym, val[0].intern), val[1]]
1607
+ result = [new_sym(val[0]), val[1]]
1664
1608
  }
1665
1609
 
1666
1610
  operation: tIDENTIFIER