| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "config.h" | 5 #include "config.h" |
| 6 #include "core/inspector/ConsoleMessageStorage.h" | 6 #include "core/inspector/ConsoleMessageStorage.h" |
| 7 | 7 |
| 8 #include "core/frame/LocalDOMWindow.h" | 8 #include "core/frame/LocalDOMWindow.h" |
| 9 #include "core/inspector/ConsoleMessage.h" | 9 #include "core/inspector/ConsoleMessage.h" |
| 10 #include "core/inspector/InspectorConsoleInstrumentation.h" | 10 #include "core/inspector/InspectorConsoleInstrumentation.h" |
| 11 | 11 |
| 12 namespace blink { | 12 namespace blink { |
| 13 | 13 |
| 14 static const unsigned maxConsoleMessageCount = 1000; | 14 static const unsigned maxConsoleMessageCount = 1000; |
| 15 | 15 |
| 16 ConsoleMessageStorage::ConsoleMessageStorage(ExecutionContext* context) | 16 ConsoleMessageStorage::ConsoleMessageStorage(ExecutionContext* context) |
| 17 : m_expiredCount(0) | 17 : m_expiredCount(0) |
| 18 , m_context(context) | 18 , m_context(context) |
| 19 , m_frame(nullptr) | 19 , m_frameHost(nullptr) |
| 20 { | 20 { |
| 21 } | 21 } |
| 22 | 22 |
| 23 ConsoleMessageStorage::ConsoleMessageStorage(LocalFrame* frame) | 23 ConsoleMessageStorage::ConsoleMessageStorage(FrameHost* frameHost) |
| 24 : m_expiredCount(0) | 24 : m_expiredCount(0) |
| 25 , m_context(nullptr) | 25 , m_context(nullptr) |
| 26 , m_frame(frame) | 26 , m_frameHost(frameHost) |
| 27 { | 27 { |
| 28 } | 28 } |
| 29 | 29 |
| 30 void ConsoleMessageStorage::reportMessage(PassRefPtrWillBeRawPtr<ConsoleMessage>
prpMessage) | 30 void ConsoleMessageStorage::reportMessage(PassRefPtrWillBeRawPtr<ConsoleMessage>
prpMessage) |
| 31 { | 31 { |
| 32 RefPtrWillBeRawPtr<ConsoleMessage> message = prpMessage; | 32 RefPtrWillBeRawPtr<ConsoleMessage> message = prpMessage; |
| 33 message->collectCallStack(); | 33 message->collectCallStack(); |
| 34 | 34 |
| 35 if (message->type() == ClearMessageType) | 35 if (message->type() == ClearMessageType) |
| 36 clear(); | 36 clear(); |
| 37 | 37 |
| 38 InspectorInstrumentation::addMessageToConsole(executionContext(), message.ge
t()); | 38 if (m_frameHost) |
| 39 InspectorInstrumentation::addMessageToConsole(m_frameHost, message.get()
); |
| 40 else |
| 41 InspectorInstrumentation::addMessageToConsole(m_context, message.get()); |
| 39 | 42 |
| 40 ASSERT(m_messages.size() <= maxConsoleMessageCount); | 43 ASSERT(m_messages.size() <= maxConsoleMessageCount); |
| 41 if (m_messages.size() == maxConsoleMessageCount) { | 44 if (m_messages.size() == maxConsoleMessageCount) { |
| 42 ++m_expiredCount; | 45 ++m_expiredCount; |
| 43 m_messages.removeFirst(); | 46 m_messages.removeFirst(); |
| 44 } | 47 } |
| 45 m_messages.append(message); | 48 m_messages.append(message); |
| 46 } | 49 } |
| 47 | 50 |
| 48 void ConsoleMessageStorage::clear() | 51 void ConsoleMessageStorage::clear() |
| 49 { | 52 { |
| 50 InspectorInstrumentation::consoleMessagesCleared(executionContext()); | 53 if (m_frameHost) |
| 54 InspectorInstrumentation::consoleMessagesCleared(m_frameHost); |
| 55 else |
| 56 InspectorInstrumentation::consoleMessagesCleared(m_context); |
| 51 m_messages.clear(); | 57 m_messages.clear(); |
| 52 m_expiredCount = 0; | 58 m_expiredCount = 0; |
| 53 } | 59 } |
| 54 | 60 |
| 55 Vector<unsigned> ConsoleMessageStorage::argumentCounts() const | 61 Vector<unsigned> ConsoleMessageStorage::argumentCounts() const |
| 56 { | 62 { |
| 57 Vector<unsigned> result(m_messages.size()); | 63 Vector<unsigned> result(m_messages.size()); |
| 58 for (size_t i = 0; i < m_messages.size(); ++i) | 64 for (size_t i = 0; i < m_messages.size(); ++i) |
| 59 result[i] = m_messages[i]->argumentCount(); | 65 result[i] = m_messages[i]->argumentCount(); |
| 60 return result; | 66 return result; |
| (...skipping 21 matching lines...) Expand all Loading... |
| 82 ConsoleMessage* ConsoleMessageStorage::at(size_t index) const | 88 ConsoleMessage* ConsoleMessageStorage::at(size_t index) const |
| 83 { | 89 { |
| 84 return m_messages[index].get(); | 90 return m_messages[index].get(); |
| 85 } | 91 } |
| 86 | 92 |
| 87 int ConsoleMessageStorage::expiredCount() const | 93 int ConsoleMessageStorage::expiredCount() const |
| 88 { | 94 { |
| 89 return m_expiredCount; | 95 return m_expiredCount; |
| 90 } | 96 } |
| 91 | 97 |
| 92 ExecutionContext* ConsoleMessageStorage::executionContext() const | |
| 93 { | |
| 94 return m_frame ? m_frame->document() : m_context; | |
| 95 } | |
| 96 | |
| 97 void ConsoleMessageStorage::trace(Visitor* visitor) | 98 void ConsoleMessageStorage::trace(Visitor* visitor) |
| 98 { | 99 { |
| 99 visitor->trace(m_messages); | 100 visitor->trace(m_messages); |
| 100 visitor->trace(m_context); | 101 visitor->trace(m_context); |
| 101 visitor->trace(m_frame); | 102 visitor->trace(m_frameHost); |
| 102 } | 103 } |
| 103 | 104 |
| 104 } // namespace blink | 105 } // namespace blink |
| OLD | NEW |