File: resource_tracker.h

package info (click to toggle)
chromium 138.0.7204.183-1~deb12u1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm-proposed-updates
  • size: 6,080,960 kB
  • sloc: cpp: 34,937,079; ansic: 7,176,967; javascript: 4,110,704; python: 1,419,954; asm: 946,768; xml: 739,971; pascal: 187,324; sh: 89,623; perl: 88,663; objc: 79,944; sql: 50,304; cs: 41,786; fortran: 24,137; makefile: 21,811; php: 13,980; tcl: 13,166; yacc: 8,925; ruby: 7,485; awk: 3,720; lisp: 3,096; lex: 1,327; ada: 727; jsp: 228; sed: 36
file content (69 lines) | stat: -rw-r--r-- 2,726 bytes parent folder | download | duplicates (8)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
// Copyright 2019 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef COMPONENTS_PAGE_LOAD_METRICS_BROWSER_RESOURCE_TRACKER_H_
#define COMPONENTS_PAGE_LOAD_METRICS_BROWSER_RESOURCE_TRACKER_H_

#include <map>
#include <memory>
#include <vector>

#include "components/page_load_metrics/common/page_load_metrics.mojom.h"
#include "content/public/browser/global_request_id.h"

namespace page_load_metrics {

// Tracks individual resource loads on the page. Only tracks resources loaded
// by the network stack (including HTTP cache).
class ResourceTracker {
 public:
  // Maps a request id for a blink resource to the metadata for the resource
  // load.  GlobalRequestIDs are used because this map may aggregate across
  // renderers and blink request ids are unique per-renderer.
  using ResourceMap = std::map<content::GlobalRequestID,
                               page_load_metrics::mojom::ResourceDataUpdatePtr>;

  ResourceTracker();
  ~ResourceTracker();

  // Updates map of ongoing resource loads given a new update. |process_id| is
  // the id of renderer process where the update originated and is used to
  // create globally unique resource ids.
  void UpdateResourceDataUse(
      int process_id,
      const std::vector<page_load_metrics::mojom::ResourceDataUpdatePtr>&
          resources);

  const ResourceMap& unfinished_resources() const {
    return unfinished_resources_;
  }

  // Previous ResourceDataUseUpdate objects are only stored for resources that
  // are still actively loaded. These methods should only be used for resources
  // that were received by observers in
  // PageLoadMetricsObserver::OnResourceDataUseObserved().
  bool HasPreviousUpdateForResource(content::GlobalRequestID request_id) const;
  const page_load_metrics::mojom::ResourceDataUpdatePtr&
  GetPreviousUpdateForResource(content::GlobalRequestID request_id) const;

 private:
  void ProcessResourceUpdate(
      int process_id,
      const page_load_metrics::mojom::ResourceDataUpdatePtr& resource);

  // Stores all resources that have started loading on the page but have
  // not completed loading.
  ResourceMap unfinished_resources_;

  // Maps a request_id for a blink resource to the previous ResourceDataUpdate
  // received for the resource. This only stores previous updates for
  // resources that are still actively receiving updates. A resource that was
  // unfinished then completes will have its previous update in this map until
  // the next call to UpdateResourceDataUse().
  ResourceMap previous_resource_updates_;
};

}  // namespace page_load_metrics

#endif  // COMPONENTS_PAGE_LOAD_METRICS_BROWSER_RESOURCE_TRACKER_H_