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

Side by Side Diff: runtime/vm/object.cc

Issue 25909002: Sampling profiler (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 7 years, 1 month 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 | Annotate | Revision Log
« no previous file with comments | « runtime/vm/native_symbol_win.cc ('k') | runtime/vm/object_test.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a 2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file. 3 // BSD-style license that can be found in the LICENSE file.
4 4
5 #include "vm/object.h" 5 #include "vm/object.h"
6 6
7 #include "include/dart_api.h" 7 #include "include/dart_api.h"
8 #include "platform/assert.h" 8 #include "platform/assert.h"
9 #include "vm/assembler.h" 9 #include "vm/assembler.h"
10 #include "vm/cpu.h" 10 #include "vm/cpu.h"
(...skipping 7293 matching lines...) Expand 10 before | Expand all | Expand 10 after
7304 7304
7305 RawObject* Library::GetMetadata(const Object& obj) const { 7305 RawObject* Library::GetMetadata(const Object& obj) const {
7306 if (!obj.IsClass() && !obj.IsField() && !obj.IsFunction() && 7306 if (!obj.IsClass() && !obj.IsField() && !obj.IsFunction() &&
7307 !obj.IsLibrary() && !obj.IsTypeParameter()) { 7307 !obj.IsLibrary() && !obj.IsTypeParameter()) {
7308 return Object::null(); 7308 return Object::null();
7309 } 7309 }
7310 const String& metaname = String::Handle(MakeMetadataName(obj)); 7310 const String& metaname = String::Handle(MakeMetadataName(obj));
7311 Field& field = Field::Handle(GetMetadataField(metaname)); 7311 Field& field = Field::Handle(GetMetadataField(metaname));
7312 if (field.IsNull()) { 7312 if (field.IsNull()) {
7313 // There is no metadata for this object. 7313 // There is no metadata for this object.
7314 return Object::empty_array().raw();; 7314 return Object::empty_array().raw();
7315 } 7315 }
7316 Object& metadata = Object::Handle(); 7316 Object& metadata = Object::Handle();
7317 metadata = field.value(); 7317 metadata = field.value();
7318 if (field.value() == Object::empty_array().raw()) { 7318 if (field.value() == Object::empty_array().raw()) {
7319 metadata = Parser::ParseMetadata(Class::Handle(field.owner()), 7319 metadata = Parser::ParseMetadata(Class::Handle(field.owner()),
7320 field.token_pos()); 7320 field.token_pos());
7321 if (metadata.IsArray()) { 7321 if (metadata.IsArray()) {
7322 ASSERT(Array::Cast(metadata).raw() != Object::empty_array().raw()); 7322 ASSERT(Array::Cast(metadata).raw() != Object::empty_array().raw());
7323 field.set_value(Array::Cast(metadata)); 7323 field.set_value(Array::Cast(metadata));
7324 } 7324 }
(...skipping 2265 matching lines...) Expand 10 before | Expand all | Expand 10 after
9590 bool Code::FindRawCodeVisitor::FindObject(RawObject* obj) { 9590 bool Code::FindRawCodeVisitor::FindObject(RawObject* obj) {
9591 return RawInstructions::ContainsPC(obj, pc_); 9591 return RawInstructions::ContainsPC(obj, pc_);
9592 } 9592 }
9593 9593
9594 9594
9595 RawCode* Code::LookupCode(uword pc) { 9595 RawCode* Code::LookupCode(uword pc) {
9596 Isolate* isolate = Isolate::Current(); 9596 Isolate* isolate = Isolate::Current();
9597 NoGCScope no_gc; 9597 NoGCScope no_gc;
9598 FindRawCodeVisitor visitor(pc); 9598 FindRawCodeVisitor visitor(pc);
9599 RawInstructions* instr; 9599 RawInstructions* instr;
9600 if (isolate->heap() == NULL) {
9601 return Code::null();
9602 }
9600 instr = isolate->heap()->FindObjectInCodeSpace(&visitor); 9603 instr = isolate->heap()->FindObjectInCodeSpace(&visitor);
9601 if (instr != Instructions::null()) { 9604 if (instr != Instructions::null()) {
9602 return instr->ptr()->code_; 9605 return instr->ptr()->code_;
9603 } 9606 }
9604 return Code::null(); 9607 return Code::null();
9605 } 9608 }
9606 9609
9607 9610
9608 intptr_t Code::GetTokenIndexOfPC(uword pc) const { 9611 intptr_t Code::GetTokenIndexOfPC(uword pc) const {
9609 intptr_t token_pos = -1; 9612 intptr_t token_pos = -1;
(...skipping 6306 matching lines...) Expand 10 before | Expand all | Expand 10 after
15916 return "_MirrorReference"; 15919 return "_MirrorReference";
15917 } 15920 }
15918 15921
15919 15922
15920 void MirrorReference::PrintToJSONStream(JSONStream* stream, bool ref) const { 15923 void MirrorReference::PrintToJSONStream(JSONStream* stream, bool ref) const {
15921 JSONObject jsobj(stream); 15924 JSONObject jsobj(stream);
15922 } 15925 }
15923 15926
15924 15927
15925 } // namespace dart 15928 } // namespace dart
OLDNEW
« no previous file with comments | « runtime/vm/native_symbol_win.cc ('k') | runtime/vm/object_test.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698