OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 #include "base/debug/stack_trace.h" | 5 #include "base/debug/stack_trace.h" |
6 | 6 |
7 #include "base/basictypes.h" | 7 #include "base/basictypes.h" |
8 | 8 |
9 #include <string.h> | 9 #include <string.h> |
10 | 10 |
11 #include <algorithm> | 11 #include <algorithm> |
| 12 #include <sstream> |
12 | 13 |
13 namespace base { | 14 namespace base { |
14 namespace debug { | 15 namespace debug { |
15 | 16 |
16 StackTrace::StackTrace(const void* const* trace, size_t count) { | 17 StackTrace::StackTrace(const void* const* trace, size_t count) { |
17 count = std::min(count, arraysize(trace_)); | 18 count = std::min(count, arraysize(trace_)); |
18 if (count) | 19 if (count) |
19 memcpy(trace_, trace, count * sizeof(trace_[0])); | 20 memcpy(trace_, trace, count * sizeof(trace_[0])); |
20 count_ = static_cast<int>(count); | 21 count_ = static_cast<int>(count); |
21 } | 22 } |
22 | 23 |
23 StackTrace::~StackTrace() { | 24 StackTrace::~StackTrace() { |
24 } | 25 } |
25 | 26 |
26 const void *const *StackTrace::Addresses(size_t* count) const { | 27 const void *const *StackTrace::Addresses(size_t* count) const { |
27 *count = count_; | 28 *count = count_; |
28 if (count_) | 29 if (count_) |
29 return trace_; | 30 return trace_; |
30 return NULL; | 31 return NULL; |
31 } | 32 } |
32 | 33 |
| 34 std::string StackTrace::ToString() const { |
| 35 std::stringstream stream; |
| 36 OutputToStream(&stream); |
| 37 return stream.str(); |
| 38 } |
| 39 |
33 } // namespace debug | 40 } // namespace debug |
34 } // namespace base | 41 } // namespace base |
OLD | NEW |