Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(43)

Unified Diff: src/inspector/v8-console.cc

Issue 2505493002: [inspector] make console.assert much faster (Closed)
Patch Set: Created 4 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | src/isolate.cc » ('j') | test/inspector/console/console-assert.js » ('J')
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: src/inspector/v8-console.cc
diff --git a/src/inspector/v8-console.cc b/src/inspector/v8-console.cc
index fee61177e7a134183ca4208aaaeaed831b85d1c7..3e39e4321b5852995d6ca4c42ef59d0cf2409ffa 100644
--- a/src/inspector/v8-console.cc
+++ b/src/inspector/v8-console.cc
@@ -714,6 +714,24 @@ v8::Local<v8::Object> V8Console::createConsole(
createBoundFunctionProperty(context, console, "timeStamp",
V8Console::timeStampCallback);
+ const char* jsConsoleAssert =
+ "(function(){\n"
+ "var assert = this.assert;\n"
+ "this.assert = (value, ...args) => value ? undefined : assert(value, "
+ "...args);\n"
+ "})";
+ v8::Local<v8::String> jsConsoleAssertSource =
+ toV8StringInternalized(isolate, jsConsoleAssert);
+ V8InspectorImpl* inspector = inspectedContext->inspector();
+ v8::Local<v8::Value> consoleAssertValue;
+ if (inspector->compileAndRunInternalScript(context, jsConsoleAssertSource)
+ .ToLocal(&consoleAssertValue) &&
+ consoleAssertValue->IsFunction()) {
+ v8::Local<v8::Function> consoleAssert =
+ v8::Local<v8::Function>::Cast(consoleAssertValue);
+ inspector->callFunction(consoleAssert, context, console, 0, nullptr);
+ }
+
if (hasMemoryAttribute)
console->SetAccessorProperty(
toV8StringInternalized(isolate, "memory"),
« no previous file with comments | « no previous file | src/isolate.cc » ('j') | test/inspector/console/console-assert.js » ('J')

Powered by Google App Engine
This is Rietveld 408576698