| OLD | NEW |
| 1 /* | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
| 2 * Copyright (C) 2007, 2008 Apple Inc. All rights reserved. | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 * Copyright (C) 2008 Matt Lilek <webkit@mattlilek.com> | 3 // found in the LICENSE file. |
| 4 * Copyright (C) 2009, 2010 Google Inc. All rights reserved. | |
| 5 * | |
| 6 * Redistribution and use in source and binary forms, with or without | |
| 7 * modification, are permitted provided that the following conditions | |
| 8 * are met: | |
| 9 * | |
| 10 * 1. Redistributions of source code must retain the above copyright | |
| 11 * notice, this list of conditions and the following disclaimer. | |
| 12 * 2. Redistributions in binary form must reproduce the above copyright | |
| 13 * notice, this list of conditions and the following disclaimer in the | |
| 14 * documentation and/or other materials provided with the distribution. | |
| 15 * 3. Neither the name of Apple Computer, Inc. ("Apple") nor the names of | |
| 16 * its contributors may be used to endorse or promote products derived | |
| 17 * from this software without specific prior written permission. | |
| 18 * | |
| 19 * THIS SOFTWARE IS PROVIDED BY APPLE AND ITS CONTRIBUTORS "AS IS" AND ANY | |
| 20 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | |
| 21 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | |
| 22 * DISCLAIMED. IN NO EVENT SHALL APPLE OR ITS CONTRIBUTORS BE LIABLE FOR ANY | |
| 23 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | |
| 24 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | |
| 25 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | |
| 26 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | |
| 27 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | |
| 28 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | |
| 29 */ | |
| 30 | 4 |
| 31 #include "config.h" | 5 #include "config.h" |
| 32 | 6 |
| 33 | 7 |
| 34 #include "core/inspector/ConsoleMessage.h" | 8 #include "core/inspector/ConsoleMessage.h" |
| 35 | 9 |
| 36 #include "bindings/core/v8/ScriptCallStackFactory.h" | 10 #include "bindings/core/v8/ScriptCallStackFactory.h" |
| 37 #include "bindings/core/v8/ScriptValue.h" | 11 #include "bindings/core/v8/ScriptValue.h" |
| 38 #include "core/dom/ExecutionContext.h" | 12 #include "core/dom/ExecutionContext.h" |
| 39 #include "core/inspector/IdentifiersFactory.h" | 13 #include "core/inspector/IdentifiersFactory.h" |
| 40 #include "core/inspector/InjectedScript.h" | 14 #include "core/inspector/InjectedScript.h" |
| 41 #include "core/inspector/InjectedScriptManager.h" | 15 #include "core/inspector/InjectedScriptManager.h" |
| 42 #include "core/inspector/ScriptArguments.h" | 16 #include "core/inspector/ScriptArguments.h" |
| 43 #include "core/inspector/ScriptAsyncCallStack.h" | |
| 44 #include "core/inspector/ScriptCallFrame.h" | 17 #include "core/inspector/ScriptCallFrame.h" |
| 45 #include "core/inspector/ScriptCallStack.h" | 18 #include "core/inspector/ScriptCallStack.h" |
| 46 #include "wtf/CurrentTime.h" | 19 #include "wtf/CurrentTime.h" |
| 47 | 20 |
| 48 namespace WebCore { | 21 namespace WebCore { |
| 49 | 22 |
| 50 ConsoleMessage::ConsoleMessage(bool canGenerateCallStack, MessageSource source,
MessageType type, MessageLevel level, const String& message) | 23 ConsoleMessage::ConsoleMessage() |
| 24 : m_lineNumber(0) |
| 25 , m_columnNumber(0) |
| 26 , m_scriptState(nullptr) |
| 27 , m_requestIdentifier(0) |
| 28 , m_corsStatus(NotSharableCrossOrigin) |
| 29 { |
| 30 } |
| 31 |
| 32 ConsoleMessage::ConsoleMessage(MessageSource source, |
| 33 MessageLevel level, |
| 34 const String& message, |
| 35 const String& url, |
| 36 unsigned lineNumber, |
| 37 unsigned columnNumber, |
| 38 PassRefPtrWillBeRawPtr<ScriptCallStack> callStack, |
| 39 ScriptState* scriptState, |
| 40 unsigned long requestIdentifier, |
| 41 AccessControlStatus corsStatus) |
| 51 : m_source(source) | 42 : m_source(source) |
| 52 , m_type(type) | |
| 53 , m_level(level) | 43 , m_level(level) |
| 54 , m_message(message) | 44 , m_message(message) |
| 55 , m_scriptState(0) | 45 , m_url(url) |
| 56 , m_url() | 46 , m_lineNumber(lineNumber) |
| 57 , m_line(0) | 47 , m_columnNumber(columnNumber) |
| 58 , m_column(0) | 48 , m_callStack(callStack) |
| 59 , m_requestId(IdentifiersFactory::requestId(0)) | 49 , m_scriptState(scriptState) |
| 60 , m_timestamp(WTF::currentTime()) | 50 , m_requestIdentifier(requestIdentifier) |
| 51 , m_corsStatus(corsStatus) |
| 61 { | 52 { |
| 62 autogenerateMetadata(canGenerateCallStack); | |
| 63 } | 53 } |
| 64 | 54 |
| 65 ConsoleMessage::ConsoleMessage(bool canGenerateCallStack, MessageSource source,
MessageType type, MessageLevel level, const String& message, const String& url,
unsigned line, unsigned column, ScriptState* scriptState, unsigned long requestI
dentifier) | 55 MessageSource ConsoleMessage::source() const |
| 66 : m_source(source) | |
| 67 , m_type(type) | |
| 68 , m_level(level) | |
| 69 , m_message(message) | |
| 70 , m_scriptState(scriptState) | |
| 71 , m_url(url) | |
| 72 , m_line(line) | |
| 73 , m_column(column) | |
| 74 , m_requestId(IdentifiersFactory::requestId(requestIdentifier)) | |
| 75 , m_timestamp(WTF::currentTime()) | |
| 76 { | 56 { |
| 77 autogenerateMetadata(canGenerateCallStack, scriptState); | 57 return m_source; |
| 78 } | 58 } |
| 79 | 59 |
| 80 ConsoleMessage::ConsoleMessage(bool, MessageSource source, MessageType type, Mes
sageLevel level, const String& message, PassRefPtrWillBeRawPtr<ScriptCallStack>
callStack, unsigned long requestIdentifier) | 60 void ConsoleMessage::setSource(MessageSource source) |
| 81 : m_source(source) | |
| 82 , m_type(type) | |
| 83 , m_level(level) | |
| 84 , m_message(message) | |
| 85 , m_scriptState(0) | |
| 86 , m_arguments(nullptr) | |
| 87 , m_line(0) | |
| 88 , m_column(0) | |
| 89 , m_requestId(IdentifiersFactory::requestId(requestIdentifier)) | |
| 90 , m_timestamp(WTF::currentTime()) | |
| 91 { | 61 { |
| 92 if (callStack && callStack->size()) { | 62 m_source = source; |
| 93 const ScriptCallFrame& frame = callStack->at(0); | 63 } |
| 94 m_url = frame.sourceURL(); | 64 |
| 95 m_line = frame.lineNumber(); | 65 MessageLevel ConsoleMessage::level() const |
| 96 m_column = frame.columnNumber(); | 66 { |
| 97 } | 67 return m_level; |
| 68 } |
| 69 |
| 70 void ConsoleMessage::setLevel(MessageLevel level) |
| 71 { |
| 72 m_level = level; |
| 73 } |
| 74 |
| 75 const String& ConsoleMessage::message() const |
| 76 { |
| 77 return m_message; |
| 78 } |
| 79 |
| 80 void ConsoleMessage::setMessage(const String& message) |
| 81 { |
| 82 m_message = message; |
| 83 } |
| 84 |
| 85 const String& ConsoleMessage::url() const |
| 86 { |
| 87 return m_url; |
| 88 } |
| 89 |
| 90 void ConsoleMessage::setURL(const String& url) |
| 91 { |
| 92 m_url = url; |
| 93 } |
| 94 |
| 95 unsigned ConsoleMessage::lineNumber() const |
| 96 { |
| 97 return m_lineNumber; |
| 98 } |
| 99 |
| 100 void ConsoleMessage::setLineNumber(unsigned lineNumber) |
| 101 { |
| 102 m_lineNumber = lineNumber; |
| 103 } |
| 104 |
| 105 unsigned ConsoleMessage::columnNumber() const |
| 106 { |
| 107 return m_columnNumber; |
| 108 } |
| 109 |
| 110 void ConsoleMessage::setColumnNumber(unsigned columnNumber) |
| 111 { |
| 112 m_columnNumber = columnNumber; |
| 113 } |
| 114 |
| 115 RefPtrWillBeRawPtr<ScriptCallStack> ConsoleMessage::callStack() |
| 116 { |
| 117 return m_callStack; |
| 118 } |
| 119 |
| 120 void ConsoleMessage::setCallStack(RefPtrWillBeRawPtr<ScriptCallStack> callStack) |
| 121 { |
| 98 m_callStack = callStack; | 122 m_callStack = callStack; |
| 99 } | 123 } |
| 100 | 124 |
| 101 ConsoleMessage::ConsoleMessage(bool canGenerateCallStack, MessageSource source,
MessageType type, MessageLevel level, const String& message, PassRefPtrWillBeRaw
Ptr<ScriptArguments> arguments, ScriptState* scriptState, unsigned long requestI
dentifier) | 125 ScriptState* ConsoleMessage::scriptState() const |
| 102 : m_source(source) | |
| 103 , m_type(type) | |
| 104 , m_level(level) | |
| 105 , m_message(message) | |
| 106 , m_scriptState(scriptState) | |
| 107 , m_arguments(arguments) | |
| 108 , m_url() | |
| 109 , m_line(0) | |
| 110 , m_column(0) | |
| 111 , m_requestId(IdentifiersFactory::requestId(requestIdentifier)) | |
| 112 , m_timestamp(WTF::currentTime()) | |
| 113 { | 126 { |
| 114 autogenerateMetadata(canGenerateCallStack, scriptState); | 127 return m_scriptState; |
| 115 } | 128 } |
| 116 | 129 |
| 117 ConsoleMessage::~ConsoleMessage() | 130 void ConsoleMessage::setScriptState(ScriptState* scriptState) |
| 118 { | 131 { |
| 132 m_scriptState = scriptState; |
| 119 } | 133 } |
| 120 | 134 |
| 121 void ConsoleMessage::autogenerateMetadata(bool canGenerateCallStack, ScriptState
* scriptState) | 135 unsigned long ConsoleMessage::requestIdentifier() const |
| 122 { | 136 { |
| 123 if (m_type == EndGroupMessageType) | 137 return m_requestIdentifier; |
| 124 return; | |
| 125 | |
| 126 if (scriptState) | |
| 127 m_callStack = createScriptCallStackForConsole(scriptState); | |
| 128 else if (canGenerateCallStack) | |
| 129 m_callStack = createScriptCallStack(ScriptCallStack::maxCallStackSizeToC
apture, true); | |
| 130 else | |
| 131 return; | |
| 132 | |
| 133 if (m_callStack && m_callStack->size()) { | |
| 134 const ScriptCallFrame& frame = m_callStack->at(0); | |
| 135 m_url = frame.sourceURL(); | |
| 136 m_line = frame.lineNumber(); | |
| 137 m_column = frame.columnNumber(); | |
| 138 return; | |
| 139 } | |
| 140 | |
| 141 m_callStack.clear(); | |
| 142 } | 138 } |
| 143 | 139 |
| 144 static TypeBuilder::Console::ConsoleMessage::Source::Enum messageSourceValue(Mes
sageSource source) | 140 void ConsoleMessage::setRequestIdentifier(unsigned long requestIdentifier) |
| 145 { | 141 { |
| 146 switch (source) { | 142 m_requestIdentifier = requestIdentifier; |
| 147 case XMLMessageSource: return TypeBuilder::Console::ConsoleMessage::Source::
Xml; | |
| 148 case JSMessageSource: return TypeBuilder::Console::ConsoleMessage::Source::J
avascript; | |
| 149 case NetworkMessageSource: return TypeBuilder::Console::ConsoleMessage::Sour
ce::Network; | |
| 150 case ConsoleAPIMessageSource: return TypeBuilder::Console::ConsoleMessage::S
ource::Console_api; | |
| 151 case StorageMessageSource: return TypeBuilder::Console::ConsoleMessage::Sour
ce::Storage; | |
| 152 case AppCacheMessageSource: return TypeBuilder::Console::ConsoleMessage::Sou
rce::Appcache; | |
| 153 case RenderingMessageSource: return TypeBuilder::Console::ConsoleMessage::So
urce::Rendering; | |
| 154 case CSSMessageSource: return TypeBuilder::Console::ConsoleMessage::Source::
Css; | |
| 155 case SecurityMessageSource: return TypeBuilder::Console::ConsoleMessage::Sou
rce::Security; | |
| 156 case OtherMessageSource: return TypeBuilder::Console::ConsoleMessage::Source
::Other; | |
| 157 case DeprecationMessageSource: return TypeBuilder::Console::ConsoleMessage::
Source::Deprecation; | |
| 158 } | |
| 159 return TypeBuilder::Console::ConsoleMessage::Source::Other; | |
| 160 } | 143 } |
| 161 | 144 |
| 162 static TypeBuilder::Console::ConsoleMessage::Type::Enum messageTypeValue(Message
Type type) | 145 AccessControlStatus ConsoleMessage::corsStatus() const |
| 163 { | 146 { |
| 164 switch (type) { | 147 return m_corsStatus; |
| 165 case LogMessageType: return TypeBuilder::Console::ConsoleMessage::Type::Log; | |
| 166 case ClearMessageType: return TypeBuilder::Console::ConsoleMessage::Type::Cl
ear; | |
| 167 case DirMessageType: return TypeBuilder::Console::ConsoleMessage::Type::Dir; | |
| 168 case DirXMLMessageType: return TypeBuilder::Console::ConsoleMessage::Type::D
irxml; | |
| 169 case TableMessageType: return TypeBuilder::Console::ConsoleMessage::Type::Ta
ble; | |
| 170 case TraceMessageType: return TypeBuilder::Console::ConsoleMessage::Type::Tr
ace; | |
| 171 case StartGroupMessageType: return TypeBuilder::Console::ConsoleMessage::Typ
e::StartGroup; | |
| 172 case StartGroupCollapsedMessageType: return TypeBuilder::Console::ConsoleMes
sage::Type::StartGroupCollapsed; | |
| 173 case EndGroupMessageType: return TypeBuilder::Console::ConsoleMessage::Type:
:EndGroup; | |
| 174 case AssertMessageType: return TypeBuilder::Console::ConsoleMessage::Type::A
ssert; | |
| 175 } | |
| 176 return TypeBuilder::Console::ConsoleMessage::Type::Log; | |
| 177 } | 148 } |
| 178 | 149 |
| 179 static TypeBuilder::Console::ConsoleMessage::Level::Enum messageLevelValue(Messa
geLevel level) | 150 void ConsoleMessage::setCorsStatus(AccessControlStatus corsStatus) |
| 180 { | 151 { |
| 181 switch (level) { | 152 m_corsStatus = corsStatus; |
| 182 case DebugMessageLevel: return TypeBuilder::Console::ConsoleMessage::Level::
Debug; | |
| 183 case LogMessageLevel: return TypeBuilder::Console::ConsoleMessage::Level::Lo
g; | |
| 184 case WarningMessageLevel: return TypeBuilder::Console::ConsoleMessage::Level
::Warning; | |
| 185 case ErrorMessageLevel: return TypeBuilder::Console::ConsoleMessage::Level::
Error; | |
| 186 case InfoMessageLevel: return TypeBuilder::Console::ConsoleMessage::Level::I
nfo; | |
| 187 } | |
| 188 return TypeBuilder::Console::ConsoleMessage::Level::Log; | |
| 189 } | |
| 190 | |
| 191 void ConsoleMessage::addToFrontend(InspectorFrontend::Console* frontend, Injecte
dScriptManager* injectedScriptManager, bool generatePreview) | |
| 192 { | |
| 193 RefPtr<TypeBuilder::Console::ConsoleMessage> jsonObj = TypeBuilder::Console:
:ConsoleMessage::create() | |
| 194 .setSource(messageSourceValue(m_source)) | |
| 195 .setLevel(messageLevelValue(m_level)) | |
| 196 .setText(m_message) | |
| 197 .setTimestamp(m_timestamp); | |
| 198 // FIXME: only send out type for ConsoleAPI source messages. | |
| 199 jsonObj->setType(messageTypeValue(m_type)); | |
| 200 jsonObj->setLine(static_cast<int>(m_line)); | |
| 201 jsonObj->setColumn(static_cast<int>(m_column)); | |
| 202 jsonObj->setUrl(m_url); | |
| 203 ScriptState* scriptState = m_scriptState.get(); | |
| 204 if (scriptState) | |
| 205 jsonObj->setExecutionContextId(injectedScriptManager->injectedScriptIdFo
r(scriptState)); | |
| 206 if (m_source == NetworkMessageSource && !m_requestId.isEmpty()) | |
| 207 jsonObj->setNetworkRequestId(m_requestId); | |
| 208 if (m_arguments && m_arguments->argumentCount()) { | |
| 209 InjectedScript injectedScript = injectedScriptManager->injectedScriptFor
(m_arguments->scriptState()); | |
| 210 if (!injectedScript.isEmpty()) { | |
| 211 RefPtr<TypeBuilder::Array<TypeBuilder::Runtime::RemoteObject> > json
Args = TypeBuilder::Array<TypeBuilder::Runtime::RemoteObject>::create(); | |
| 212 if (m_type == TableMessageType && generatePreview && m_arguments->ar
gumentCount()) { | |
| 213 ScriptValue table = m_arguments->argumentAt(0); | |
| 214 ScriptValue columns = m_arguments->argumentCount() > 1 ? m_argum
ents->argumentAt(1) : ScriptValue(); | |
| 215 RefPtr<TypeBuilder::Runtime::RemoteObject> inspectorValue = inje
ctedScript.wrapTable(table, columns); | |
| 216 if (!inspectorValue) { | |
| 217 ASSERT_NOT_REACHED(); | |
| 218 return; | |
| 219 } | |
| 220 jsonArgs->addItem(inspectorValue); | |
| 221 } else { | |
| 222 for (unsigned i = 0; i < m_arguments->argumentCount(); ++i) { | |
| 223 RefPtr<TypeBuilder::Runtime::RemoteObject> inspectorValue =
injectedScript.wrapObject(m_arguments->argumentAt(i), "console", generatePreview
); | |
| 224 if (!inspectorValue) { | |
| 225 ASSERT_NOT_REACHED(); | |
| 226 return; | |
| 227 } | |
| 228 jsonArgs->addItem(inspectorValue); | |
| 229 } | |
| 230 } | |
| 231 jsonObj->setParameters(jsonArgs); | |
| 232 } | |
| 233 } | |
| 234 if (m_callStack) | |
| 235 jsonObj->setStackTrace(m_callStack->buildInspectorArray()); | |
| 236 if (m_asyncCallStack) | |
| 237 jsonObj->setAsyncStackTrace(m_asyncCallStack->buildInspectorObject()); | |
| 238 frontend->messageAdded(jsonObj); | |
| 239 frontend->flush(); | |
| 240 } | |
| 241 | |
| 242 void ConsoleMessage::setAsyncStackTrace(PassRefPtrWillBeRawPtr<ScriptAsyncCallSt
ack> asyncCallStack) | |
| 243 { | |
| 244 m_asyncCallStack = asyncCallStack; | |
| 245 } | |
| 246 | |
| 247 void ConsoleMessage::windowCleared(LocalDOMWindow* window) | |
| 248 { | |
| 249 if (m_scriptState.get() && m_scriptState.get()->domWindow() == window) | |
| 250 m_scriptState.clear(); | |
| 251 | |
| 252 if (!m_arguments) | |
| 253 return; | |
| 254 if (m_arguments->scriptState()->domWindow() != window) | |
| 255 return; | |
| 256 if (!m_message) | |
| 257 m_message = "<message collected>"; | |
| 258 m_arguments.clear(); | |
| 259 } | |
| 260 | |
| 261 unsigned ConsoleMessage::argumentCount() | |
| 262 { | |
| 263 if (m_arguments) | |
| 264 return m_arguments->argumentCount(); | |
| 265 return 0; | |
| 266 } | 153 } |
| 267 | 154 |
| 268 } // namespace WebCore | 155 } // namespace WebCore |
| OLD | NEW |