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

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: rebased the patch Created 4 years, 11 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 197 matching lines...) Expand 10 before | Expand all | Expand 10 after
208 208
209 // Flow Control. 209 // Flow Control.
210 BytecodeArrayBuilder& Bind(BytecodeLabel* label); 210 BytecodeArrayBuilder& Bind(BytecodeLabel* label);
211 BytecodeArrayBuilder& Bind(const BytecodeLabel& target, BytecodeLabel* label); 211 BytecodeArrayBuilder& Bind(const BytecodeLabel& target, BytecodeLabel* label);
212 212
213 BytecodeArrayBuilder& Jump(BytecodeLabel* label); 213 BytecodeArrayBuilder& Jump(BytecodeLabel* label);
214 BytecodeArrayBuilder& JumpIfTrue(BytecodeLabel* label); 214 BytecodeArrayBuilder& JumpIfTrue(BytecodeLabel* label);
215 BytecodeArrayBuilder& JumpIfFalse(BytecodeLabel* label); 215 BytecodeArrayBuilder& JumpIfFalse(BytecodeLabel* label);
216 BytecodeArrayBuilder& JumpIfNull(BytecodeLabel* label); 216 BytecodeArrayBuilder& JumpIfNull(BytecodeLabel* label);
217 BytecodeArrayBuilder& JumpIfUndefined(BytecodeLabel* label); 217 BytecodeArrayBuilder& JumpIfUndefined(BytecodeLabel* label);
218 BytecodeArrayBuilder& JumpIfHole(BytecodeLabel* label);
219 BytecodeArrayBuilder& JumpIfNotHole(BytecodeLabel* label);
218 220
219 BytecodeArrayBuilder& Throw(); 221 BytecodeArrayBuilder& Throw();
220 BytecodeArrayBuilder& ReThrow(); 222 BytecodeArrayBuilder& ReThrow();
221 BytecodeArrayBuilder& Return(); 223 BytecodeArrayBuilder& Return();
222 224
223 // Complex flow control. 225 // Complex flow control.
224 BytecodeArrayBuilder& ForInPrepare(Register cache_info_triple); 226 BytecodeArrayBuilder& ForInPrepare(Register cache_info_triple);
225 BytecodeArrayBuilder& ForInDone(Register index, Register cache_length); 227 BytecodeArrayBuilder& ForInDone(Register index, Register cache_length);
226 BytecodeArrayBuilder& ForInNext(Register receiver, Register index, 228 BytecodeArrayBuilder& ForInNext(Register receiver, Register index,
227 Register cache_type_array_pair); 229 Register cache_type_array_pair);
(...skipping 161 matching lines...) Expand 10 before | Expand all | Expand 10 after
389 size_t offset_; 391 size_t offset_;
390 392
391 friend class BytecodeArrayBuilder; 393 friend class BytecodeArrayBuilder;
392 }; 394 };
393 395
394 } // namespace interpreter 396 } // namespace interpreter
395 } // namespace internal 397 } // namespace internal
396 } // namespace v8 398 } // namespace v8
397 399
398 #endif // V8_INTERPRETER_BYTECODE_ARRAY_BUILDER_H_ 400 #endif // V8_INTERPRETER_BYTECODE_ARRAY_BUILDER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698