OLD | NEW |
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2013, 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/coverage.h" | 5 #include "vm/coverage.h" |
6 | 6 |
7 #include "include/dart_api.h" | 7 #include "include/dart_api.h" |
8 | 8 |
9 #include "vm/compiler.h" | 9 #include "vm/compiler.h" |
10 #include "vm/isolate.h" | 10 #include "vm/isolate.h" |
(...skipping 23 matching lines...) Expand all Loading... |
34 static void ComputeTokenPosToLineNumberMap(const Script& script, | 34 static void ComputeTokenPosToLineNumberMap(const Script& script, |
35 GrowableArray<intptr_t>* map) { | 35 GrowableArray<intptr_t>* map) { |
36 const TokenStream& tkns = TokenStream::Handle(script.tokens()); | 36 const TokenStream& tkns = TokenStream::Handle(script.tokens()); |
37 const intptr_t len = ExternalTypedData::Handle(tkns.GetStream()).Length(); | 37 const intptr_t len = ExternalTypedData::Handle(tkns.GetStream()).Length(); |
38 map->SetLength(len); | 38 map->SetLength(len); |
39 #if defined(DEBUG) | 39 #if defined(DEBUG) |
40 for (intptr_t i = 0; i < len; i++) { | 40 for (intptr_t i = 0; i < len; i++) { |
41 (*map)[i] = -1; | 41 (*map)[i] = -1; |
42 } | 42 } |
43 #endif | 43 #endif |
44 TokenStream::Iterator tkit(tkns, 0, TokenStream::Iterator::kAllTokens); | 44 TokenStream::Iterator tkit(tkns, |
| 45 TokenPosition::kMinSource, |
| 46 TokenStream::Iterator::kAllTokens); |
45 intptr_t cur_line = script.line_offset() + 1; | 47 intptr_t cur_line = script.line_offset() + 1; |
46 while (tkit.CurrentTokenKind() != Token::kEOS) { | 48 while (tkit.CurrentTokenKind() != Token::kEOS) { |
47 (*map)[tkit.CurrentPosition()] = cur_line; | 49 const intptr_t position = tkit.CurrentPosition().Pos(); |
| 50 (*map)[position] = cur_line; |
48 if (tkit.CurrentTokenKind() == Token::kNEWLINE) { | 51 if (tkit.CurrentTokenKind() == Token::kNEWLINE) { |
49 cur_line++; | 52 cur_line++; |
50 } | 53 } |
51 tkit.Advance(); | 54 tkit.Advance(); |
52 } | 55 } |
53 } | 56 } |
54 | 57 |
55 | 58 |
56 void CodeCoverage::CompileAndAdd(const Function& function, | 59 void CodeCoverage::CompileAndAdd(const Function& function, |
57 const JSONArray& hits_or_sites, | 60 const JSONArray& hits_or_sites, |
(...skipping 22 matching lines...) Expand all Loading... |
80 const Code& code = Code::Handle(zone, function.unoptimized_code()); | 83 const Code& code = Code::Handle(zone, function.unoptimized_code()); |
81 ASSERT(!code.IsNull()); | 84 ASSERT(!code.IsNull()); |
82 | 85 |
83 // Print the hit counts for all IC datas. | 86 // Print the hit counts for all IC datas. |
84 ZoneGrowableArray<const ICData*>* ic_data_array = | 87 ZoneGrowableArray<const ICData*>* ic_data_array = |
85 new(zone) ZoneGrowableArray<const ICData*>(); | 88 new(zone) ZoneGrowableArray<const ICData*>(); |
86 function.RestoreICDataMap(ic_data_array, false /* clone descriptors */); | 89 function.RestoreICDataMap(ic_data_array, false /* clone descriptors */); |
87 const PcDescriptors& descriptors = PcDescriptors::Handle( | 90 const PcDescriptors& descriptors = PcDescriptors::Handle( |
88 zone, code.pc_descriptors()); | 91 zone, code.pc_descriptors()); |
89 | 92 |
90 const intptr_t begin_pos = function.token_pos(); | 93 const TokenPosition begin_pos = function.token_pos(); |
91 const intptr_t end_pos = function.end_token_pos(); | 94 const TokenPosition end_pos = function.end_token_pos(); |
92 intptr_t last_line = -1; | 95 intptr_t last_line = -1; |
93 intptr_t last_count = 0; | 96 intptr_t last_count = 0; |
94 // Only IC based calls have counting. | 97 // Only IC based calls have counting. |
95 PcDescriptors::Iterator iter(descriptors, | 98 PcDescriptors::Iterator iter(descriptors, |
96 RawPcDescriptors::kIcCall | RawPcDescriptors::kUnoptStaticCall); | 99 RawPcDescriptors::kIcCall | RawPcDescriptors::kUnoptStaticCall); |
97 while (iter.MoveNext()) { | 100 while (iter.MoveNext()) { |
98 HANDLESCOPE(thread); | 101 HANDLESCOPE(thread); |
99 const ICData* ic_data = (*ic_data_array)[iter.DeoptId()]; | 102 const ICData* ic_data = (*ic_data_array)[iter.DeoptId()]; |
100 if (!ic_data->IsNull()) { | 103 if (!ic_data->IsNull()) { |
101 const intptr_t token_pos = iter.TokenPos(); | 104 const TokenPosition token_pos = iter.TokenPos(); |
102 // Filter out descriptors that do not map to tokens in the source code. | 105 // Filter out descriptors that do not map to tokens in the source code. |
103 if ((token_pos < begin_pos) || (token_pos > end_pos)) { | 106 if ((token_pos < begin_pos) || (token_pos > end_pos)) { |
104 continue; | 107 continue; |
105 } | 108 } |
106 if (as_call_sites) { | 109 if (as_call_sites) { |
107 bool is_static_call = iter.Kind() == RawPcDescriptors::kUnoptStaticCall; | 110 bool is_static_call = iter.Kind() == RawPcDescriptors::kUnoptStaticCall; |
108 ic_data->PrintToJSONArray(hits_or_sites, token_pos, is_static_call); | 111 ic_data->PrintToJSONArray(hits_or_sites, |
| 112 token_pos, |
| 113 is_static_call); |
109 } else { | 114 } else { |
110 intptr_t line = pos_to_line[token_pos]; | 115 intptr_t line = pos_to_line[token_pos.Pos()]; |
111 #if defined(DEBUG) | 116 #if defined(DEBUG) |
112 const Script& script = Script::Handle(zone, function.script()); | 117 const Script& script = Script::Handle(zone, function.script()); |
113 intptr_t test_line = -1; | 118 intptr_t test_line = -1; |
114 script.GetTokenLocation(token_pos, &test_line, NULL); | 119 script.GetTokenLocation(token_pos, &test_line, NULL); |
115 ASSERT(test_line == line); | 120 ASSERT(test_line == line); |
116 #endif | 121 #endif |
117 // Merge hit data where possible. | 122 // Merge hit data where possible. |
118 if (last_line == line) { | 123 if (last_line == line) { |
119 last_count += ic_data->AggregateCount(); | 124 last_count += ic_data->AggregateCount(); |
120 } else { | 125 } else { |
(...skipping 166 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
287 cls = it.GetNextClass(); | 292 cls = it.GetNextClass(); |
288 ASSERT(!cls.IsNull()); | 293 ASSERT(!cls.IsNull()); |
289 PrintClass(lib, cls, jsarr, filter, as_call_sites); | 294 PrintClass(lib, cls, jsarr, filter, as_call_sites); |
290 } | 295 } |
291 } | 296 } |
292 } | 297 } |
293 } | 298 } |
294 | 299 |
295 | 300 |
296 } // namespace dart | 301 } // namespace dart |
OLD | NEW |