
NOTREACHED() and NOTREACHED_IN_MIGRATION() are both CHECK-fatal now. The former is [[noreturn]] so this CL also performs dead-code removal after the NOTREACHED(). This CL does not attempt to do additional rewrites of any surrounding code, like: if (!foo) { NOTREACHED(); } to CHECK(foo); Those transforms take a non-trivial amount of time (and there are thousands of instances). Cleanup can be left as an exercise for the reader. This does clean up kCrashOnDanglingBrowserContext as both paths of the kill switch are currently fatal. This has been rolled out for a long time. Bug: 40580068, 40062641 Change-Id: Ib88e710d003e2e48df3fc502ca54d2341d157a0e Cq-Include-Trybots: luci.chromium.try:linux-dcheck-off-rel Low-Coverage-Reason: OTHER Should-be-unreachable code Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/5974816 Reviewed-by: Łukasz Anforowicz <lukasza@chromium.org> Commit-Queue: Łukasz Anforowicz <lukasza@chromium.org> Reviewed-by: Rakina Zata Amni <rakina@chromium.org> Auto-Submit: Peter Boström <pbos@chromium.org> Reviewed-by: Sam McNally <sammc@chromium.org> Cr-Commit-Position: refs/heads/main@{#1376522}
56 lines
1.9 KiB
C++
56 lines
1.9 KiB
C++
// Copyright 2023 The Chromium Authors
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#include "content/browser/preloading/preloading.h"
|
|
|
|
#include <string_view>
|
|
|
|
#include "base/notreached.h"
|
|
#include "content/public/browser/preloading.h"
|
|
#include "content/public/browser/preloading_trigger_type.h"
|
|
|
|
namespace content {
|
|
|
|
std::string_view PreloadingTypeToString(PreloadingType type) {
|
|
switch (type) {
|
|
case PreloadingType::kUnspecified:
|
|
return "Unspecified";
|
|
case PreloadingType::kPreconnect:
|
|
return "Preconnect";
|
|
case PreloadingType::kPrefetch:
|
|
return "Prefetch";
|
|
case PreloadingType::kPrerender:
|
|
return "Prerender";
|
|
case PreloadingType::kNoStatePrefetch:
|
|
return "NoStatePrefetch";
|
|
case PreloadingType::kLinkPreview:
|
|
return "LinkPreview";
|
|
}
|
|
NOTREACHED();
|
|
}
|
|
|
|
PreloadingPredictor GetPredictorForPreloadingTriggerType(
|
|
PreloadingTriggerType type) {
|
|
switch (type) {
|
|
case PreloadingTriggerType::kSpeculationRule:
|
|
return content_preloading_predictor::kSpeculationRules;
|
|
case PreloadingTriggerType::kSpeculationRuleFromIsolatedWorld:
|
|
return content_preloading_predictor::kSpeculationRulesFromIsolatedWorld;
|
|
case PreloadingTriggerType::kSpeculationRuleFromAutoSpeculationRules:
|
|
return content_preloading_predictor::
|
|
kSpeculationRulesFromAutoSpeculationRules;
|
|
case PreloadingTriggerType::kEmbedder:
|
|
// GetPredictorForPreloadingTriggerType is currently called for
|
|
// speculation rules code-path only, thus NOTREACHED().
|
|
// However there is nothing fundamentally wrong with calling it
|
|
// for embedder trigger code-path (while you might want to be specific
|
|
// about the `PreloadingPredictor` more than just "embedder").
|
|
// Revisit if needed.
|
|
NOTREACHED();
|
|
}
|
|
NOTREACHED();
|
|
}
|
|
|
|
} // namespace content
|