summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMustafa Emre Acer - Google <meacer@google.com>2016-03-10 15:50:23 -0800
committerMustafa Emre Acer - Google <meacer@google.com>2016-03-10 23:54:38 +0000
commit2f26cabbf82b53dfb49198598b14238bfaa84165 (patch)
treea4ec0866a4b18e595530f202842d81b1a25204c4
parenta99a391f699f0f5d15f3c249dc404a84d6f3bde1 (diff)
downloadchromium_src-2f26cabbf82b53dfb49198598b14238bfaa84165.zip
chromium_src-2f26cabbf82b53dfb49198598b14238bfaa84165.tar.gz
chromium_src-2f26cabbf82b53dfb49198598b14238bfaa84165.tar.bz2
[Merge to 2623] Cache csi info before passing it to JS setters.
JS setters invalidate the pointers frame, data_source and document_state. BUG=590455 Review URL: https://codereview.chromium.org/1751553002 Cr-Commit-Position: refs/heads/master@{#379047} (cherry picked from commit 9d92ff158726601ae5c044d62050614f076eaae4) Review URL: https://codereview.chromium.org/1782323002 . Cr-Commit-Position: refs/branch-heads/2623@{#611} Cr-Branched-From: 92d77538a86529ca35f9220bd3cd512cbea1f086-refs/heads/master@{#369907}
-rw-r--r--chrome/renderer/loadtimes_extension_bindings.cc231
1 files changed, 171 insertions, 60 deletions
diff --git a/chrome/renderer/loadtimes_extension_bindings.cc b/chrome/renderer/loadtimes_extension_bindings.cc
index 692b808..4488781 100644
--- a/chrome/renderer/loadtimes_extension_bindings.cc
+++ b/chrome/renderer/loadtimes_extension_bindings.cc
@@ -98,19 +98,17 @@ class LoadTimesExtensionWrapper : public v8::Extension {
}
static void GetLoadTimes(const v8::FunctionCallbackInfo<v8::Value>& args) {
+ args.GetReturnValue().SetNull();
WebLocalFrame* frame = WebLocalFrame::frameForCurrentContext();
if (!frame) {
- args.GetReturnValue().SetNull();
return;
}
WebDataSource* data_source = frame->dataSource();
if (!data_source) {
- args.GetReturnValue().SetNull();
return;
}
DocumentState* document_state = DocumentState::FromDataSource(data_source);
if (!document_state) {
- args.GetReturnValue().SetNull();
return;
}
double request_time = document_state->request_time().ToDoubleT();
@@ -136,70 +134,183 @@ class LoadTimesExtensionWrapper : public v8::Extension {
// referred to below this line, as JS setters below can invalidate these
// pointers.
v8::Isolate* isolate = args.GetIsolate();
+ v8::Local<v8::Context> ctx = isolate->GetCurrentContext();
v8::Local<v8::Object> load_times = v8::Object::New(isolate);
- load_times->Set(v8::String::NewFromUtf8(isolate, "requestTime"),
- v8::Number::New(isolate, request_time));
- load_times->Set(v8::String::NewFromUtf8(isolate, "startLoadTime"),
- v8::Number::New(isolate, start_load_time));
- load_times->Set(v8::String::NewFromUtf8(isolate, "commitLoadTime"),
- v8::Number::New(isolate, commit_load_time));
- load_times->Set(v8::String::NewFromUtf8(isolate, "finishDocumentLoadTime"),
- v8::Number::New(isolate, finish_document_load_time));
- load_times->Set(v8::String::NewFromUtf8(isolate, "finishLoadTime"),
- v8::Number::New(isolate, finish_load_time));
- load_times->Set(v8::String::NewFromUtf8(isolate, "firstPaintTime"),
- v8::Number::New(isolate, first_paint_time));
- load_times->Set(v8::String::NewFromUtf8(isolate, "firstPaintAfterLoadTime"),
- v8::Number::New(isolate, first_paint_after_load_time));
- load_times->Set(v8::String::NewFromUtf8(isolate, "navigationType"),
- v8::String::NewFromUtf8(isolate, navigation_type.c_str()));
- load_times->Set(v8::String::NewFromUtf8(isolate, "wasFetchedViaSpdy"),
- v8::Boolean::New(isolate, was_fetched_via_spdy));
- load_times->Set(v8::String::NewFromUtf8(isolate, "wasNpnNegotiated"),
- v8::Boolean::New(isolate, was_npn_negotiated));
- load_times->Set(
- v8::String::NewFromUtf8(isolate, "npnNegotiatedProtocol"),
- v8::String::NewFromUtf8(isolate, npn_negotiated_protocol.c_str()));
- load_times->Set(
- v8::String::NewFromUtf8(isolate, "wasAlternateProtocolAvailable"),
- v8::Boolean::New(isolate, was_alternate_protocol_available));
- load_times->Set(v8::String::NewFromUtf8(isolate, "connectionInfo"),
- v8::String::NewFromUtf8(isolate, connection_info.c_str()));
+ if (!load_times
+ ->Set(ctx, v8::String::NewFromUtf8(isolate, "requestTime",
+ v8::NewStringType::kNormal)
+ .ToLocalChecked(),
+ v8::Number::New(isolate, request_time))
+ .FromMaybe(false)) {
+ return;
+ }
+
+ if (!load_times
+ ->Set(ctx, v8::String::NewFromUtf8(isolate, "startLoadTime",
+ v8::NewStringType::kNormal)
+ .ToLocalChecked(),
+ v8::Number::New(isolate, start_load_time))
+ .FromMaybe(false)) {
+ return;
+ }
+ if (!load_times
+ ->Set(ctx, v8::String::NewFromUtf8(isolate, "commitLoadTime",
+ v8::NewStringType::kNormal)
+ .ToLocalChecked(),
+ v8::Number::New(isolate, commit_load_time))
+ .FromMaybe(false)) {
+ return;
+ }
+ if (!load_times
+ ->Set(ctx,
+ v8::String::NewFromUtf8(isolate, "finishDocumentLoadTime",
+ v8::NewStringType::kNormal)
+ .ToLocalChecked(),
+ v8::Number::New(isolate, finish_document_load_time))
+ .FromMaybe(false)) {
+ return;
+ }
+ if (!load_times
+ ->Set(ctx, v8::String::NewFromUtf8(isolate, "finishLoadTime",
+ v8::NewStringType::kNormal)
+ .ToLocalChecked(),
+ v8::Number::New(isolate, finish_load_time))
+ .FromMaybe(false)) {
+ return;
+ }
+ if (!load_times
+ ->Set(ctx, v8::String::NewFromUtf8(isolate, "firstPaintTime",
+ v8::NewStringType::kNormal)
+ .ToLocalChecked(),
+ v8::Number::New(isolate, first_paint_time))
+ .FromMaybe(false)) {
+ return;
+ }
+ if (!load_times
+ ->Set(ctx,
+ v8::String::NewFromUtf8(isolate, "firstPaintAfterLoadTime",
+ v8::NewStringType::kNormal)
+ .ToLocalChecked(),
+ v8::Number::New(isolate, first_paint_after_load_time))
+ .FromMaybe(false)) {
+ return;
+ }
+ if (!load_times
+ ->Set(ctx, v8::String::NewFromUtf8(isolate, "navigationType",
+ v8::NewStringType::kNormal)
+ .ToLocalChecked(),
+ v8::String::NewFromUtf8(isolate, navigation_type.c_str(),
+ v8::NewStringType::kNormal)
+ .ToLocalChecked())
+ .FromMaybe(false)) {
+ return;
+ }
+ if (!load_times
+ ->Set(ctx, v8::String::NewFromUtf8(isolate, "wasFetchedViaSpdy",
+ v8::NewStringType::kNormal)
+ .ToLocalChecked(),
+ v8::Boolean::New(isolate, was_fetched_via_spdy))
+ .FromMaybe(false)) {
+ return;
+ }
+ if (!load_times
+ ->Set(ctx, v8::String::NewFromUtf8(isolate, "wasNpnNegotiated",
+ v8::NewStringType::kNormal)
+ .ToLocalChecked(),
+ v8::Boolean::New(isolate, was_npn_negotiated))
+ .FromMaybe(false)) {
+ return;
+ }
+ if (!load_times
+ ->Set(ctx,
+ v8::String::NewFromUtf8(isolate, "npnNegotiatedProtocol",
+ v8::NewStringType::kNormal)
+ .ToLocalChecked(),
+ v8::String::NewFromUtf8(isolate,
+ npn_negotiated_protocol.c_str(),
+ v8::NewStringType::kNormal)
+ .ToLocalChecked())
+ .FromMaybe(false)) {
+ return;
+ }
+ if (!load_times
+ ->Set(ctx, v8::String::NewFromUtf8(isolate,
+ "wasAlternateProtocolAvailable",
+ v8::NewStringType::kNormal)
+ .ToLocalChecked(),
+ v8::Boolean::New(isolate, was_alternate_protocol_available))
+ .FromMaybe(false)) {
+ return;
+ }
+ if (!load_times
+ ->Set(ctx, v8::String::NewFromUtf8(isolate, "connectionInfo",
+ v8::NewStringType::kNormal)
+ .ToLocalChecked(),
+ v8::String::NewFromUtf8(isolate, connection_info.c_str(),
+ v8::NewStringType::kNormal)
+ .ToLocalChecked())
+ .FromMaybe(false)) {
+ return;
+ }
args.GetReturnValue().Set(load_times);
}
static void GetCSI(const v8::FunctionCallbackInfo<v8::Value>& args) {
+ args.GetReturnValue().SetNull();
WebLocalFrame* frame = WebLocalFrame::frameForCurrentContext();
- if (frame) {
- WebDataSource* data_source = frame->dataSource();
- if (data_source) {
- DocumentState* document_state =
- DocumentState::FromDataSource(data_source);
- v8::Isolate* isolate = args.GetIsolate();
- v8::Local<v8::Object> csi = v8::Object::New(isolate);
- base::Time now = base::Time::Now();
- base::Time start = document_state->request_time().is_null() ?
- document_state->start_load_time() :
- document_state->request_time();
- base::Time onload = document_state->finish_document_load_time();
- base::TimeDelta page = now - start;
- csi->Set(v8::String::NewFromUtf8(isolate, "startE"),
- v8::Number::New(isolate, floor(start.ToDoubleT() * 1000)));
- csi->Set(v8::String::NewFromUtf8(isolate, "onloadT"),
- v8::Number::New(isolate, floor(onload.ToDoubleT() * 1000)));
- csi->Set(v8::String::NewFromUtf8(isolate, "pageT"),
- v8::Number::New(isolate, page.InMillisecondsF()));
- csi->Set(
- v8::String::NewFromUtf8(isolate, "tran"),
- v8::Number::New(
- isolate, GetCSITransitionType(data_source->navigationType())));
-
- args.GetReturnValue().Set(csi);
- return;
- }
+ if (!frame) {
+ return;
}
- args.GetReturnValue().SetNull();
- return;
+ WebDataSource* data_source = frame->dataSource();
+ if (!data_source) {
+ return;
+ }
+ DocumentState* document_state = DocumentState::FromDataSource(data_source);
+ if (!document_state) {
+ return;
+ }
+ base::Time now = base::Time::Now();
+ base::Time start = document_state->request_time().is_null()
+ ? document_state->start_load_time()
+ : document_state->request_time();
+ base::Time onload = document_state->finish_document_load_time();
+ base::TimeDelta page = now - start;
+ int navigation_type = GetCSITransitionType(data_source->navigationType());
+ // Important: |frame|, |data_source| and |document_state| should not be
+ // referred to below this line, as JS setters below can invalidate these
+ // pointers.
+ v8::Isolate* isolate = args.GetIsolate();
+ v8::Local<v8::Context> ctx = isolate->GetCurrentContext();
+ v8::Local<v8::Object> csi = v8::Object::New(isolate);
+ if (!csi->Set(ctx, v8::String::NewFromUtf8(isolate, "startE",
+ v8::NewStringType::kNormal)
+ .ToLocalChecked(),
+ v8::Number::New(isolate, floor(start.ToDoubleT() * 1000)))
+ .FromMaybe(false)) {
+ return;
+ }
+ if (!csi->Set(ctx, v8::String::NewFromUtf8(isolate, "onloadT",
+ v8::NewStringType::kNormal)
+ .ToLocalChecked(),
+ v8::Number::New(isolate, floor(onload.ToDoubleT() * 1000)))
+ .FromMaybe(false)) {
+ return;
+ }
+ if (!csi->Set(ctx, v8::String::NewFromUtf8(isolate, "pageT",
+ v8::NewStringType::kNormal)
+ .ToLocalChecked(),
+ v8::Number::New(isolate, page.InMillisecondsF()))
+ .FromMaybe(false)) {
+ return;
+ }
+ if (!csi->Set(ctx, v8::String::NewFromUtf8(isolate, "tran",
+ v8::NewStringType::kNormal)
+ .ToLocalChecked(),
+ v8::Number::New(isolate, navigation_type))
+ .FromMaybe(false)) {
+ return;
+ }
+ args.GetReturnValue().Set(csi);
}
};