Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(2)

Side by Side Diff: src/interpreter/bytecode-array-builder.h

Issue 1634153002: [Interpreter] Adds support for const/let variables to interpreter. (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: Fixed rebase errors. Created 4 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2015 the V8 project authors. All rights reserved. 1 // Copyright 2015 the V8 project authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef V8_INTERPRETER_BYTECODE_ARRAY_BUILDER_H_ 5 #ifndef V8_INTERPRETER_BYTECODE_ARRAY_BUILDER_H_
6 #define V8_INTERPRETER_BYTECODE_ARRAY_BUILDER_H_ 6 #define V8_INTERPRETER_BYTECODE_ARRAY_BUILDER_H_
7 7
8 #include "src/ast/ast.h" 8 #include "src/ast/ast.h"
9 #include "src/interpreter/bytecode-register-allocator.h" 9 #include "src/interpreter/bytecode-register-allocator.h"
10 #include "src/interpreter/bytecodes.h" 10 #include "src/interpreter/bytecodes.h"
(...skipping 216 matching lines...) Expand 10 before | Expand all | Expand 10 after
227 227
228 // Flow Control. 228 // Flow Control.
229 BytecodeArrayBuilder& Bind(BytecodeLabel* label); 229 BytecodeArrayBuilder& Bind(BytecodeLabel* label);
230 BytecodeArrayBuilder& Bind(const BytecodeLabel& target, BytecodeLabel* label); 230 BytecodeArrayBuilder& Bind(const BytecodeLabel& target, BytecodeLabel* label);
231 231
232 BytecodeArrayBuilder& Jump(BytecodeLabel* label); 232 BytecodeArrayBuilder& Jump(BytecodeLabel* label);
233 BytecodeArrayBuilder& JumpIfTrue(BytecodeLabel* label); 233 BytecodeArrayBuilder& JumpIfTrue(BytecodeLabel* label);
234 BytecodeArrayBuilder& JumpIfFalse(BytecodeLabel* label); 234 BytecodeArrayBuilder& JumpIfFalse(BytecodeLabel* label);
235 BytecodeArrayBuilder& JumpIfNull(BytecodeLabel* label); 235 BytecodeArrayBuilder& JumpIfNull(BytecodeLabel* label);
236 BytecodeArrayBuilder& JumpIfUndefined(BytecodeLabel* label); 236 BytecodeArrayBuilder& JumpIfUndefined(BytecodeLabel* label);
237 BytecodeArrayBuilder& JumpIfHole(BytecodeLabel* label);
238 BytecodeArrayBuilder& JumpIfNotHole(BytecodeLabel* label);
237 239
238 BytecodeArrayBuilder& Throw(); 240 BytecodeArrayBuilder& Throw();
239 BytecodeArrayBuilder& ReThrow(); 241 BytecodeArrayBuilder& ReThrow();
240 BytecodeArrayBuilder& Return(); 242 BytecodeArrayBuilder& Return();
241 243
242 // Complex flow control. 244 // Complex flow control.
243 BytecodeArrayBuilder& ForInPrepare(Register cache_info_triple); 245 BytecodeArrayBuilder& ForInPrepare(Register cache_info_triple);
244 BytecodeArrayBuilder& ForInDone(Register index, Register cache_length); 246 BytecodeArrayBuilder& ForInDone(Register index, Register cache_length);
245 BytecodeArrayBuilder& ForInNext(Register receiver, Register index, 247 BytecodeArrayBuilder& ForInNext(Register receiver, Register index,
246 Register cache_type_array_pair); 248 Register cache_type_array_pair);
(...skipping 158 matching lines...) Expand 10 before | Expand all | Expand 10 after
405 size_t offset_; 407 size_t offset_;
406 408
407 friend class BytecodeArrayBuilder; 409 friend class BytecodeArrayBuilder;
408 }; 410 };
409 411
410 } // namespace interpreter 412 } // namespace interpreter
411 } // namespace internal 413 } // namespace internal
412 } // namespace v8 414 } // namespace v8
413 415
414 #endif // V8_INTERPRETER_BYTECODE_ARRAY_BUILDER_H_ 416 #endif // V8_INTERPRETER_BYTECODE_ARRAY_BUILDER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698