Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 # Copyright 2016 The Chromium Authors. All rights reserved. | 1 # Copyright 2016 The Chromium 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 import logging | 5 import logging |
| 6 import re | 6 import re |
| 7 | 7 |
| 8 from crash import callstack_detectors | 8 from crash import callstack_detectors |
| 9 from crash.callstack_filters import FilterFramesAfterBlinkGeneratedCode | 9 from crash.callstack_filters import FilterFramesAfterBlinkGeneratedCode |
| 10 from crash.callstack_filters import FilterJavaJreSdkFrames | 10 from crash.callstack_filters import FilterJavaJreSdkFrames |
| (...skipping 86 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 97 signature or '', job_type) | 97 signature or '', job_type) |
| 98 return None | 98 return None |
| 99 | 99 |
| 100 # Initial background callstack which is not to be added into Stacktrace. | 100 # Initial background callstack which is not to be added into Stacktrace. |
| 101 stack_buffer = CallStackBuffer() | 101 stack_buffer = CallStackBuffer() |
| 102 # Reset both stacktrace and callstack flags. | 102 # Reset both stacktrace and callstack flags. |
| 103 self.flag_manager.ResetAllFlags() | 103 self.flag_manager.ResetAllFlags() |
| 104 for line in stacktrace_string.splitlines(): | 104 for line in stacktrace_string.splitlines(): |
| 105 # Note, some flags like is_first_stack may be changed inside of stack | 105 # Note, some flags like is_first_stack may be changed inside of stack |
| 106 # detector. | 106 # detector. |
| 107 is_new_callstack, priority, format_type, language_type, metadata = ( | 107 start_of_callstack = stack_detector(line) |
| 108 stack_detector.IsStartOfNewCallStack(line, flags=self.flag_manager)) | |
| 109 | 108 |
| 110 if is_new_callstack: | 109 if start_of_callstack: |
| 111 stacktrace_buffer.AddFilteredStack( | 110 stacktrace_buffer.AddFilteredStack( |
| 112 self.UpdateMetadataWithFlags(stack_buffer)) | 111 self.UpdateMetadataWithFlags(stack_buffer)) |
| 113 | |
| 114 # Create new stack and reset callstack scope flags. | 112 # Create new stack and reset callstack scope flags. |
| 115 stack_buffer = CallStackBuffer(priority=priority, | 113 stack_buffer = CallStackBuffer( |
| 116 format_type=format_type, | 114 priority=start_of_callstack.priority, |
| 117 language_type=language_type, | 115 format_type=start_of_callstack.format_type, |
| 118 metadata=metadata) | 116 language_type=start_of_callstack.language_type, |
| 117 metadata=start_of_callstack.metadata) | |
|
wrengr
2016/12/29 20:13:03
ditto.
Sharu Jiang
2016/12/29 21:40:14
As above
| |
| 119 self.flag_manager.ResetGroupFlags(CALLSTACK_FLAG_GROUP) | 118 self.flag_manager.ResetGroupFlags(CALLSTACK_FLAG_GROUP) |
| 120 else: | 119 else: |
| 121 frame = StackFrame.Parse(stack_buffer.language_type, | 120 frame = StackFrame.Parse(stack_buffer.language_type, |
| 122 stack_buffer.format_type, line, deps, | 121 stack_buffer.format_type, line, deps, |
| 123 len(stack_buffer.frames)) | 122 len(stack_buffer.frames)) |
| 124 if frame is not None: | 123 if frame is not None: |
| 125 stack_buffer.frames.append(frame) | 124 stack_buffer.frames.append(frame) |
| 126 # Turn on flags if condition met. | 125 # Turn on flags if condition met. |
| 127 self.flag_manager.ConditionallyTurnOnFlags(line) | 126 self.flag_manager.ConditionallyTurnOnFlags(line) |
| 128 | 127 |
| 129 # Add the last stack to stacktrace. | 128 # Add the last stack to stacktrace. |
| 130 stacktrace_buffer.AddFilteredStack( | 129 stacktrace_buffer.AddFilteredStack( |
| 131 self.UpdateMetadataWithFlags(stack_buffer)) | 130 self.UpdateMetadataWithFlags(stack_buffer)) |
| 132 return stacktrace_buffer.ToStacktrace() | 131 return stacktrace_buffer.ToStacktrace() |
| OLD | NEW |