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

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: Refactored VisitVariableAssignment. 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/bytecodes.h" 9 #include "src/interpreter/bytecodes.h"
10 #include "src/interpreter/constant-array-builder.h" 10 #include "src/interpreter/constant-array-builder.h"
(...skipping 210 matching lines...) Expand 10 before | Expand all | Expand 10 after
221 221
222 // Flow Control. 222 // Flow Control.
223 BytecodeArrayBuilder& Bind(BytecodeLabel* label); 223 BytecodeArrayBuilder& Bind(BytecodeLabel* label);
224 BytecodeArrayBuilder& Bind(const BytecodeLabel& target, BytecodeLabel* label); 224 BytecodeArrayBuilder& Bind(const BytecodeLabel& target, BytecodeLabel* label);
225 225
226 BytecodeArrayBuilder& Jump(BytecodeLabel* label); 226 BytecodeArrayBuilder& Jump(BytecodeLabel* label);
227 BytecodeArrayBuilder& JumpIfTrue(BytecodeLabel* label); 227 BytecodeArrayBuilder& JumpIfTrue(BytecodeLabel* label);
228 BytecodeArrayBuilder& JumpIfFalse(BytecodeLabel* label); 228 BytecodeArrayBuilder& JumpIfFalse(BytecodeLabel* label);
229 BytecodeArrayBuilder& JumpIfNull(BytecodeLabel* label); 229 BytecodeArrayBuilder& JumpIfNull(BytecodeLabel* label);
230 BytecodeArrayBuilder& JumpIfUndefined(BytecodeLabel* label); 230 BytecodeArrayBuilder& JumpIfUndefined(BytecodeLabel* label);
231 BytecodeArrayBuilder& JumpIfHole(BytecodeLabel* label);
232 BytecodeArrayBuilder& JumpIfNotHole(BytecodeLabel* label);
231 233
232 BytecodeArrayBuilder& Throw(); 234 BytecodeArrayBuilder& Throw();
233 BytecodeArrayBuilder& ReThrow(); 235 BytecodeArrayBuilder& ReThrow();
234 BytecodeArrayBuilder& Return(); 236 BytecodeArrayBuilder& Return();
235 237
236 // Complex flow control. 238 // Complex flow control.
237 BytecodeArrayBuilder& ForInPrepare(Register cache_info_triple); 239 BytecodeArrayBuilder& ForInPrepare(Register cache_info_triple);
238 BytecodeArrayBuilder& ForInDone(Register index, Register cache_length); 240 BytecodeArrayBuilder& ForInDone(Register index, Register cache_length);
239 BytecodeArrayBuilder& ForInNext(Register receiver, Register index, 241 BytecodeArrayBuilder& ForInNext(Register receiver, Register index,
240 Register cache_type_array_pair); 242 Register cache_type_array_pair);
(...skipping 165 matching lines...) Expand 10 before | Expand all | Expand 10 after
406 size_t offset_; 408 size_t offset_;
407 409
408 friend class BytecodeArrayBuilder; 410 friend class BytecodeArrayBuilder;
409 }; 411 };
410 412
411 } // namespace interpreter 413 } // namespace interpreter
412 } // namespace internal 414 } // namespace internal
413 } // namespace v8 415 } // namespace v8
414 416
415 #endif // V8_INTERPRETER_BYTECODE_ARRAY_BUILDER_H_ 417 #endif // V8_INTERPRETER_BYTECODE_ARRAY_BUILDER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698