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

Side by Side Diff: src/builtins/builtins-object.cc

Issue 2549773002: Internalize strings in-place (Closed)
Patch Set: forgot one Created 4 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
OLDNEW
1 // Copyright 2016 the V8 project authors. All rights reserved. 1 // Copyright 2016 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/builtins/builtins-utils.h" 5 #include "src/builtins/builtins-utils.h"
6 #include "src/builtins/builtins.h" 6 #include "src/builtins/builtins.h"
7 #include "src/code-factory.h" 7 #include "src/code-factory.h"
8 #include "src/code-stub-assembler.h" 8 #include "src/code-stub-assembler.h"
9 #include "src/property-descriptor.h" 9 #include "src/property-descriptor.h"
10 10
(...skipping 19 matching lines...) Expand all
30 30
31 // Smi receivers do not have own properties. 31 // Smi receivers do not have own properties.
32 Label if_objectisnotsmi(&assembler); 32 Label if_objectisnotsmi(&assembler);
33 assembler.Branch(assembler.TaggedIsSmi(object), &return_false, 33 assembler.Branch(assembler.TaggedIsSmi(object), &return_false,
34 &if_objectisnotsmi); 34 &if_objectisnotsmi);
35 assembler.Bind(&if_objectisnotsmi); 35 assembler.Bind(&if_objectisnotsmi);
36 36
37 Node* map = assembler.LoadMap(object); 37 Node* map = assembler.LoadMap(object);
38 Node* instance_type = assembler.LoadMapInstanceType(map); 38 Node* instance_type = assembler.LoadMapInstanceType(map);
39 39
40 Variable var_index(&assembler, MachineType::PointerRepresentation()); 40 {
41 Variable var_index(&assembler, MachineType::PointerRepresentation());
42 Variable var_unique(&assembler, MachineRepresentation::kTagged);
41 43
42 Label keyisindex(&assembler), if_iskeyunique(&assembler); 44 Label keyisindex(&assembler), if_iskeyunique(&assembler);
43 assembler.TryToName(key, &keyisindex, &var_index, &if_iskeyunique, 45 assembler.TryToName(key, &keyisindex, &var_index, &if_iskeyunique,
44 &call_runtime); 46 &var_unique, &call_runtime);
45 47
46 assembler.Bind(&if_iskeyunique); 48 assembler.Bind(&if_iskeyunique);
47 assembler.TryHasOwnProperty(object, map, instance_type, key, &return_true, 49 assembler.TryHasOwnProperty(object, map, instance_type, var_unique.value(),
48 &return_false, &call_runtime); 50 &return_true, &return_false, &call_runtime);
49 51
50 assembler.Bind(&keyisindex); 52 assembler.Bind(&keyisindex);
51 // Handle negative keys in the runtime. 53 // Handle negative keys in the runtime.
52 assembler.GotoIf( 54 assembler.GotoIf(assembler.IntPtrLessThan(var_index.value(),
53 assembler.IntPtrLessThan(var_index.value(), assembler.IntPtrConstant(0)), 55 assembler.IntPtrConstant(0)),
54 &call_runtime); 56 &call_runtime);
55 assembler.TryLookupElement(object, map, instance_type, var_index.value(), 57 assembler.TryLookupElement(object, map, instance_type, var_index.value(),
56 &return_true, &return_false, &call_runtime); 58 &return_true, &return_false, &call_runtime);
57 59 }
58 assembler.Bind(&return_true); 60 assembler.Bind(&return_true);
59 assembler.Return(assembler.BooleanConstant(true)); 61 assembler.Return(assembler.BooleanConstant(true));
60 62
61 assembler.Bind(&return_false); 63 assembler.Bind(&return_false);
62 assembler.Return(assembler.BooleanConstant(false)); 64 assembler.Return(assembler.BooleanConstant(false));
63 65
64 assembler.Bind(&call_runtime); 66 assembler.Bind(&call_runtime);
65 assembler.Return(assembler.CallRuntime(Runtime::kObjectHasOwnProperty, 67 assembler.Return(assembler.CallRuntime(Runtime::kObjectHasOwnProperty,
66 context, object, key)); 68 context, object, key));
67 } 69 }
(...skipping 1005 matching lines...) Expand 10 before | Expand all | Expand 10 after
1073 1075
1074 Node* constructor = assembler.Parameter(Descriptor::kLeft); 1076 Node* constructor = assembler.Parameter(Descriptor::kLeft);
1075 Node* object = assembler.Parameter(Descriptor::kRight); 1077 Node* object = assembler.Parameter(Descriptor::kRight);
1076 Node* context = assembler.Parameter(Descriptor::kContext); 1078 Node* context = assembler.Parameter(Descriptor::kContext);
1077 1079
1078 assembler.Return(assembler.OrdinaryHasInstance(context, constructor, object)); 1080 assembler.Return(assembler.OrdinaryHasInstance(context, constructor, object));
1079 } 1081 }
1080 1082
1081 } // namespace internal 1083 } // namespace internal
1082 } // namespace v8 1084 } // namespace v8
OLDNEW
« no previous file with comments | « src/ast/ast-types.cc ('k') | src/code-stub-assembler.h » ('j') | src/code-stub-assembler.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698