From d25d658219d40e306bcd075d17aa33d1cceeb484 Mon Sep 17 00:00:00 2001 From: Shinichi Morimoto Date: Sun, 8 Dec 2019 02:25:58 +0900 Subject: #24468 call update_entry API from process_response_eof --- components/script/dom/servoparser/mod.rs | 17 ++++++++++++++--- 1 file changed, 14 insertions(+), 3 deletions(-) (limited to 'components/script/dom') diff --git a/components/script/dom/servoparser/mod.rs b/components/script/dom/servoparser/mod.rs index 6c8b8ede013..b968aa47274 100644 --- a/components/script/dom/servoparser/mod.rs +++ b/components/script/dom/servoparser/mod.rs @@ -689,6 +689,8 @@ pub struct ParserContext { url: ServoUrl, /// timing data for this resource resource_timing: ResourceFetchTiming, + /// pushed entry index + pushed_entry_index: Option, } impl ParserContext { @@ -699,6 +701,7 @@ impl ParserContext { id: id, url: url, resource_timing: ResourceFetchTiming::new(ResourceTimingType::Navigation), + pushed_entry_index: None, } } } @@ -883,8 +886,16 @@ impl FetchResponseListener for ParserContext { parser.parse_sync(); } - //TODO only submit if this is the current document resource - self.submit_resource_timing(); + //TODO only update if this is the current document resource + if let Some(pushed_index) = self.pushed_entry_index { + let document = &parser.document; + let performance_entry = + PerformanceNavigationTiming::new(&document.global(), 0, 0, &document); + document + .global() + .performance() + .update_entry(pushed_index, performance_entry.upcast::()); + } } fn resource_timing_mut(&mut self) -> &mut ResourceFetchTiming { @@ -910,7 +921,7 @@ impl FetchResponseListener for ParserContext { //TODO nav_start and nav_start_precise let performance_entry = PerformanceNavigationTiming::new(&document.global(), 0, 0, &document); - document + self.pushed_entry_index = document .global() .performance() .queue_entry(performance_entry.upcast::()); -- cgit v1.2.3