blob: 0c0ea5ae8d979e867a6b9feaecd82ce012e39a46 [file] [log] [blame]
// Copyright 2018 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "third_party/blink/public/common/features.h"
#include "build/build_config.h"
namespace blink {
namespace features {
const base::Feature kAutofillPreviewStyleExperiment{
"AutofillPreviewStyleExperiment", base::FEATURE_DISABLED_BY_DEFAULT};
// Enable defer commits a bit to avoid flash.
const base::Feature kAvoidFlashBetweenNavigation{
"AvoidFlashBetweenNavigation", base::FEATURE_DISABLED_BY_DEFAULT};
// Enable eagerly setting up a CacheStorage interface pointer and
// passing it to service workers on startup as an optimization.
const base::Feature kEagerCacheStorageSetupForServiceWorkers{
// Controls the user-specified viewport restriction for GPU Rasterization on
// mobile. See
const base::Feature kEnableGpuRasterizationViewportRestriction{
// Controls script streaming.
const base::Feature kScriptStreaming{"ScriptStreaming",
// Enable FCP++ by experiment. See
const base::Feature kFirstContentfulPaintPlusPlus{
"FirstContentfulPaintPlusPlus", base::FEATURE_DISABLED_BY_DEFAULT};
// Tracks "jank" from layout objects changing their visual location between
// animation frames (see
const base::Feature kJankTracking{"JankTracking",
const base::Feature kJankTrackingSweepLine{"JankTrackingSweepLine",
// Enable a new compositing mode called BlinkGenPropertyTrees where Blink
// generates the compositor property trees. See:
const base::Feature kBlinkGenPropertyTrees{"BlinkGenPropertyTrees",
// Enable LayoutNG.
const base::Feature kLayoutNG{"LayoutNG", base::FEATURE_DISABLED_BY_DEFAULT};
const base::Feature kMixedContentAutoupgrade{"AutoupgradeMixedContent",
// Enable mojo Blob URL interface and better blob URL lifetime management.
// Can be enabled independently of NetworkService.
const base::Feature kMojoBlobURLs{"MojoBlobURLs",
// Used to control the collection of anchor element metrics (
// If kNavigationPredictor is enabled, then metrics of anchor elements
// in the first viewport after the page load and the metrics of the clicked
// anchor element will be extracted and recorded. Additionally, navigation
// predictor may preconnect/prefetch to resources/origins to make the
// future navigations faster.
const base::Feature kNavigationPredictor{"NavigationPredictor",
// Onion souping for all DOMStorage.
const base::Feature kOnionSoupDOMStorage{"OnionSoupDOMStorage",
// Enable browser-initiated dedicated worker script loading
// (PlzDedicatedWorker).
const base::Feature kPlzDedicatedWorker{"PlzDedicatedWorker",
// Enable Portals.
const base::Feature kPortals{"Portals", base::FEATURE_DISABLED_BY_DEFAULT};
// Enable Implicit Root Scroller.
const base::Feature kImplicitRootScroller{"ImplicitRootScroller",
// Enables usage of getDisplayMedia() that allows capture of web content, see
const base::Feature kRTCGetDisplayMedia{"RTCGetDisplayMedia",
// Changes the default RTCPeerConnection constructor behavior to use Unified
// Plan as the SDP semantics. When the feature is enabled, Unified Plan is used
// unless the default is overridden (by passing {sdpSemantics:'plan-b'} as the
// argument).
const base::Feature kRTCUnifiedPlanByDefault{"RTCUnifiedPlanByDefault",
// Determines if the SDP attrbute extmap-allow-mixed should be offered by
// default or not. The default value can be overridden by passing
// {offerExtmapAllowMixed:true} as an argument to the RTCPeerConnection
// constructor.
const base::Feature kRTCOfferExtmapAllowMixed{
"RTCOfferExtmapAllowMixed", base::FEATURE_DISABLED_BY_DEFAULT};
// Enables to load the response body through Mojo data pipe passed by
// WebURLLoaderClient::DidStartLoadingResponseBody() instead of
// WebURLLoaderClient::DidReceiveData().
const base::Feature kResourceLoadViaDataPipe{"ResourceLoadViaDataPipe",
const base::Feature kServiceWorkerImportedScriptUpdateCheck{
// Enables reading a subresource's body data and side data in parallel.
const base::Feature kServiceWorkerParallelSideDataReading{
"ServiceWorkerParallelSideDataReading", base::FEATURE_ENABLED_BY_DEFAULT};
const base::Feature kServiceWorkerAggressiveCodeCache{
"ServiceWorkerAggressiveCodeCache", base::FEATURE_DISABLED_BY_DEFAULT};
// Enable new service worker glue for NetworkService. Can be
// enabled independently of NetworkService.
const base::Feature kServiceWorkerServicification{
"ServiceWorkerServicification", base::FEATURE_ENABLED_BY_DEFAULT};
// Freeze scheduler task queues in background after allowed grace time.
// "stop" is a legacy name.
const base::Feature kStopInBackground {
#if defined(OS_ANDROID)
// Freeze non-timer task queues in background, after allowed grace time.
// "stop" is a legacy name.
const base::Feature kStopNonTimersInBackground {
#if defined(OS_ANDROID)
// Enables the site isolated Wasm code cache that is keyed on the resource URL
// and the origin lock of the renderer that is requesting the resource. When
// this flag is enabled, content/GeneratedCodeCache handles code cache requests.
const base::Feature kWasmCodeCache = {"WasmCodeCache",
// Writable files and native filesystem access.
const base::Feature kWritableFilesAPI{"WritableFilesAPI",
// Allows for synchronous XHR requests during page dismissal
const base::Feature kForbidSyncXHRInPageDismissal{
"ForbidSyncXHRInPageDismissal", base::FEATURE_DISABLED_BY_DEFAULT};
const char kAutofillPreviewStyleExperimentBgColorParameterName[] = "bg_color";
const char kAutofillPreviewStyleExperimentColorParameterName[] = "color";
const char kMixedContentAutoupgradeModeParamName[] = "mode";
const char kMixedContentAutoupgradeModeBlockable[] = "blockable";
const char kMixedContentAutoupgradeModeOptionallyBlockable[] =
// Decodes lossy WebP images to YUV instead of RGBX and stores in this format
// in the image decode cache. See for details on the feature.
const base::Feature kDecodeLossyWebPImagesToYUV{
// Use accelerated canvases whenever possible see
const base::Feature kAlwaysAccelerateCanvas{"AlwaysAccelerateCanvas",
// Enables cache-aware WebFonts loading. See
const base::Feature kWebFontsCacheAwareTimeoutAdaption{
"WebFontsCacheAwareTimeoutAdaption", base::FEATURE_ENABLED_BY_DEFAULT};
} // namespace features
} // namespace blink