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

content / browser / preloading / preloading.h [blame]

// Copyright 2022 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef CONTENT_BROWSER_PRELOADING_PRELOADING_H_
#define CONTENT_BROWSER_PRELOADING_PRELOADING_H_

#include <string_view>

#include "content/public/browser/preloading.h"
#include "content/public/browser/preloading_trigger_type.h"

namespace content {

// Defines various //content triggering mechanisms which trigger different
// preloading operations mentioned in content/public/browser/preloading.h.

// These values are persisted to logs. Entries should not be renumbered and
// numeric values should never be reused.

// If you change this, please follow the process in
// go/preloading-dashboard-updates to update the mapping reflected in
// dashboard, or if you are not a Googler, please file an FYI bug on
// https://crbug.new with component Internals>Preload.
//
// LINT.IfChange
namespace content_preloading_predictor {
// Advance numbering by +1 when adding a new element.
//
// Please limit content-internal `PreloadingPredictor` between 50 to 99
// (inclusive) as 0 to 49 are reserved for content-public definitions, and 100
// and beyond are reserved for embedder definitions. Both the value and the name
// should be unique across all the namespaces.

// This API allows an origin to list possible navigation URLs that the user
// might navigate to in order to perform preloading operations.
// For more details please see:
// https://wicg.github.io/nav-speculation/prerendering.html#speculation-rules
static constexpr PreloadingPredictor kSpeculationRules(50, "SpeculationRules");

// When a mouse down of a mouse back button is seen.
static constexpr PreloadingPredictor kMouseBackButton(51, "MouseBackButton");

// Same with the kSpeculationRules, but the rules are injected from an isolated
// world, i.e. extensions or embedder's built-in features.
static constexpr PreloadingPredictor kSpeculationRulesFromIsolatedWorld(
    52,
    "SpeculationRulesFromIsolatedWorld");

// Same with the kSpeculationRules, but the rules are injected by the browser
// as part of the auto speculation rules feature.
static constexpr PreloadingPredictor kSpeculationRulesFromAutoSpeculationRules(
    53,
    "SpeculationRulesFromAutoSpeculationRules");
}  // namespace content_preloading_predictor
// LINT.ThenChange()

CONTENT_EXPORT std::string_view PreloadingTypeToString(PreloadingType type);

CONTENT_EXPORT PreloadingPredictor
GetPredictorForPreloadingTriggerType(PreloadingTriggerType trigger_type);

}  // namespace content

#endif  // CONTENT_BROWSER_PRELOADING_PRELOADING_H_