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

Side by Side Diff: test/unittests/interpreter/bytecode-array-builder-unittest.cc

Issue 1524803003: [Interpreter] Add support for Load / Store to Lookup slots. (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@init_eval_impl
Patch Set: Fixed nits. Created 5 years 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
« no previous file with comments | « test/cctest/interpreter/test-interpreter.cc ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2014 the V8 project authors. All rights reserved. 1 // Copyright 2014 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 #include "src/v8.h" 5 #include "src/v8.h"
6 6
7 #include "src/interpreter/bytecode-array-builder.h" 7 #include "src/interpreter/bytecode-array-builder.h"
8 #include "src/interpreter/bytecode-array-iterator.h" 8 #include "src/interpreter/bytecode-array-iterator.h"
9 #include "test/unittests/test-utils.h" 9 #include "test/unittests/test-utils.h"
10 10
(...skipping 75 matching lines...) Expand 10 before | Expand all | Expand 10 after
86 // Emit wide load / store property operations. 86 // Emit wide load / store property operations.
87 builder.LoadNamedProperty(reg, 2056, 0, LanguageMode::SLOPPY) 87 builder.LoadNamedProperty(reg, 2056, 0, LanguageMode::SLOPPY)
88 .LoadKeyedProperty(reg, 2056, LanguageMode::SLOPPY) 88 .LoadKeyedProperty(reg, 2056, LanguageMode::SLOPPY)
89 .StoreNamedProperty(reg, 0, 2056, LanguageMode::SLOPPY) 89 .StoreNamedProperty(reg, 0, 2056, LanguageMode::SLOPPY)
90 .StoreKeyedProperty(reg, reg, 2056, LanguageMode::SLOPPY) 90 .StoreKeyedProperty(reg, reg, 2056, LanguageMode::SLOPPY)
91 .LoadNamedProperty(reg, 2056, 0, LanguageMode::STRICT) 91 .LoadNamedProperty(reg, 2056, 0, LanguageMode::STRICT)
92 .LoadKeyedProperty(reg, 2056, LanguageMode::STRICT) 92 .LoadKeyedProperty(reg, 2056, LanguageMode::STRICT)
93 .StoreNamedProperty(reg, 0, 2056, LanguageMode::STRICT) 93 .StoreNamedProperty(reg, 0, 2056, LanguageMode::STRICT)
94 .StoreKeyedProperty(reg, reg, 2056, LanguageMode::STRICT); 94 .StoreKeyedProperty(reg, reg, 2056, LanguageMode::STRICT);
95 95
96 // Emit load / store lookup slots.
97 Factory* factory = isolate()->factory();
98 Handle<String> name = factory->NewStringFromStaticChars("var_name");
99 builder.LoadLookupSlot(name, TypeofMode::NOT_INSIDE_TYPEOF)
100 .LoadLookupSlot(name, TypeofMode::INSIDE_TYPEOF)
101 .StoreLookupSlot(name, LanguageMode::SLOPPY)
102 .StoreLookupSlot(name, LanguageMode::STRICT);
103
96 // Emit closure operations. 104 // Emit closure operations.
97 Factory* factory = isolate()->factory();
98 Handle<SharedFunctionInfo> shared_info = factory->NewSharedFunctionInfo( 105 Handle<SharedFunctionInfo> shared_info = factory->NewSharedFunctionInfo(
99 factory->NewStringFromStaticChars("function_a"), MaybeHandle<Code>(), 106 factory->NewStringFromStaticChars("function_a"), MaybeHandle<Code>(),
100 false); 107 false);
101 builder.CreateClosure(shared_info, NOT_TENURED); 108 builder.CreateClosure(shared_info, NOT_TENURED);
102 109
103 // Emit argument creation operations. 110 // Emit argument creation operations.
104 builder.CreateArguments(CreateArgumentsType::kMappedArguments) 111 builder.CreateArguments(CreateArgumentsType::kMappedArguments)
105 .CreateArguments(CreateArgumentsType::kUnmappedArguments); 112 .CreateArguments(CreateArgumentsType::kUnmappedArguments);
106 113
107 // Emit literal creation operations. 114 // Emit literal creation operations.
(...skipping 551 matching lines...) Expand 10 before | Expand all | Expand 10 after
659 iterator.Advance(); 666 iterator.Advance();
660 } 667 }
661 CHECK_EQ(iterator.current_bytecode(), Bytecode::kReturn); 668 CHECK_EQ(iterator.current_bytecode(), Bytecode::kReturn);
662 iterator.Advance(); 669 iterator.Advance();
663 CHECK(iterator.done()); 670 CHECK(iterator.done());
664 } 671 }
665 672
666 } // namespace interpreter 673 } // namespace interpreter
667 } // namespace internal 674 } // namespace internal
668 } // namespace v8 675 } // namespace v8
OLDNEW
« no previous file with comments | « test/cctest/interpreter/test-interpreter.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698