// Copyright 2022 The Chromium Authors and Alex313031. 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 "base/command_line.h" #include "base/feature_list.h" #include "build/build_config.h" #include "build/chromeos_buildflags.h" #include "services/network/public/cpp/features.h" #include "third_party/blink/public/common/forcedark/forcedark_switches.h" #include "third_party/blink/public/common/switches.h" namespace blink { namespace features { // Apply lazy-loading to ad frames which have embeds likely impacting Core Web // Vitals. const base::Feature kAutomaticLazyFrameLoadingToAds{ "AutomaticLazyFrameLoadingToAds", base::FEATURE_ENABLED_BY_DEFAULT}; // Apply lazy-loading to frames which have embeds likely impacting Core Web // Vitals. const base::Feature kAutomaticLazyFrameLoadingToEmbeds{ "AutomaticLazyFrameLoadingToEmbeds", base::FEATURE_ENABLED_BY_DEFAULT}; // Define the allowed websites to use LazyEmbeds. The allowed websites need to // be defined separately from kAutomaticLazyFrameLoadingToEmbeds because we want // to gather Blink.AutomaticLazyLoadFrame.LazyEmbedFrameCount UKM data even when // kAutomaticLazyFrameLoadingToEmbeds is disabled. const base::Feature kAutomaticLazyFrameLoadingToEmbedUrls{ "AutomaticLazyFrameLoadingToEmbedUrls", base::FEATURE_DISABLED_BY_DEFAULT}; // Allows pages with DedicatedWorker to stay eligible for the back/forward // cache. const base::Feature kBackForwardCacheDedicatedWorker{ "BackForwardCacheDedicatedWorker", base::FEATURE_DISABLED_BY_DEFAULT}; // Enable intervention for download that was initiated from or occurred in an ad // frame without user activation. const base::Feature kBlockingDownloadsInAdFrameWithoutUserActivation{ "BlockingDownloadsInAdFrameWithoutUserActivation", base::FEATURE_ENABLED_BY_DEFAULT}; // Enable CSS Container Queries. Also implies LayoutNGGrid and CSSContainSize1D. const base::Feature kCSSContainerQueries{"CSSContainerQueries", base::FEATURE_DISABLED_BY_DEFAULT}; // Controls whether the Conversion Measurement API infrastructure is enabled. const base::Feature kConversionMeasurement{"ConversionMeasurement", base::FEATURE_ENABLED_BY_DEFAULT}; // Controls whether LCP calculations should exclude low-entropy images. If // enabled, then the associated parameter sets the cutoff, expressed as the // minimum number of bits of encoded image data used to encode each rendered // pixel. Note that this is not just pixels of decoded image data; the rendered // size includes any scaling applied by the rendering engine to display the // content. const base::Feature kExcludeLowEntropyImagesFromLCP{ "ExcludeLowEntropyImagesFromLCP", base::FEATURE_DISABLED_BY_DEFAULT}; const base::FeatureParam kMinimumEntropyForLCP{ &kExcludeLowEntropyImagesFromLCP, "min_bpp", 2}; const base::Feature kGMSCoreEmoji{"GMSCoreEmoji", base::FEATURE_ENABLED_BY_DEFAULT}; // Enable defer commits to avoid flash of unstyled content, for same origin // navigation only. const base::Feature kPaintHolding{"PaintHolding", base::FEATURE_ENABLED_BY_DEFAULT}; // Enable defer commits to avoid flash of unstyled content, for all navigation. const base::Feature kPaintHoldingCrossOrigin{"PaintHoldingCrossOrigin", base::FEATURE_ENABLED_BY_DEFAULT}; // Enable eagerly setting up a CacheStorage interface pointer and // passing it to service workers on startup as an optimization. // TODO(crbug/1077916): Re-enable once the issue with COOP/COEP is fixed. const base::Feature kEagerCacheStorageSetupForServiceWorkers{ "EagerCacheStorageSetupForServiceWorkers", base::FEATURE_DISABLED_BY_DEFAULT}; // Controls script streaming. const base::Feature kScriptStreaming{"ScriptStreaming", base::FEATURE_ENABLED_BY_DEFAULT}; // Allow streaming small (<30kB) scripts. const base::Feature kSmallScriptStreaming{"SmallScriptStreaming", base::FEATURE_ENABLED_BY_DEFAULT}; // Controls off-thread code cache consumption. const base::Feature kConsumeCodeCacheOffThread{ "ConsumeCodeCacheOffThread", base::FEATURE_ENABLED_BY_DEFAULT}; // Enables user level memory pressure signal generation on Android. const base::Feature kUserLevelMemoryPressureSignal{ "UserLevelMemoryPressureSignal", base::FEATURE_DISABLED_BY_DEFAULT}; // Perform memory purges after freezing only if all pages are frozen. const base::Feature kFreezePurgeMemoryAllPagesFrozen{ "FreezePurgeMemoryAllPagesFrozen", base::FEATURE_DISABLED_BY_DEFAULT}; // Freezes the user-agent as part of https://github.com/WICG/ua-client-hints. const base::Feature kReduceUserAgent{"ReduceUserAgent", base::FEATURE_DISABLED_BY_DEFAULT}; // Enables the `sec-ch-ua-full` client hint to be sent along with the full user // agent string in the HTTP request headers, as well as surfacing the full user // agent string in the JS APIs (navigator.userAgent, etc). const base::Feature kFullUserAgent{"FullUserAgent", base::FEATURE_DISABLED_BY_DEFAULT}; // Enables the frequency capping for detecting overlay popups. Overlay-popups // are the interstitials that pop up and block the main content of the page. const base::Feature kFrequencyCappingForOverlayPopupDetection{ "FrequencyCappingForOverlayPopupDetection", base::FEATURE_ENABLED_BY_DEFAULT}; // Enables the frequency capping for detecting large sticky ads. // Large-sticky-ads are those ads that stick to the bottom of the page // regardless of a user’s efforts to scroll, and take up more than 30% of the // screen’s real estate. const base::Feature kFrequencyCappingForLargeStickyAdDetection{ "FrequencyCappingForLargeStickyAdDetection", base::FEATURE_ENABLED_BY_DEFAULT}; // Enable Display Locking JavaScript APIs. const base::Feature kDisplayLocking{"DisplayLocking", base::FEATURE_DISABLED_BY_DEFAULT}; const base::Feature kJSONModules{"JSONModules", base::FEATURE_ENABLED_BY_DEFAULT}; const base::Feature kDeferredFontShaping{"DeferredShaping", base::FEATURE_DISABLED_BY_DEFAULT}; // Enable LayoutNG. const base::Feature kLayoutNG{"LayoutNG", base::FEATURE_ENABLED_BY_DEFAULT}; // Enables the use of the PaintCache for Path2D objects that are rasterized // out of process. Has no effect when kCanvasOopRasterization is disabled. const base::Feature kPath2DPaintCache{"Path2DPaintCache", base::FEATURE_DISABLED_BY_DEFAULT}; // Enable by default. This feature is for a kill switch. const base::Feature kLayoutNGBlockInInline{"LayoutNGBlockInInline", base::FEATURE_ENABLED_BY_DEFAULT}; const base::Feature kPrivacySandboxAdsAPIs{"PrivacySandboxAdsAPIs", base::FEATURE_DISABLED_BY_DEFAULT}; const base::Feature kMixedContentAutoupgrade{"AutoupgradeMixedContent", base::FEATURE_ENABLED_BY_DEFAULT}; // An experimental replacement for the `User-Agent` header, defined in // https://tools.ietf.org/html/draft-west-ua-client-hints. const base::Feature kUserAgentClientHint{"UserAgentClientHint", base::FEATURE_ENABLED_BY_DEFAULT}; // Enable `sec-ch-ua-full-version-list` client hint. const base::Feature kUserAgentClientHintFullVersionList{ "UserAgentClientHintFullVersionList", base::FEATURE_ENABLED_BY_DEFAULT}; // Handle prefers-color-scheme user preference media feature via client hints. const base::Feature kPrefersColorSchemeClientHintHeader{ "PrefersColorSchemeClientHintHeader", base::FEATURE_ENABLED_BY_DEFAULT}; // Controls whether the Viewport Height client hint can be added to request // headers. const base::Feature kViewportHeightClientHintHeader{ "ViewportHeightClientHintHeader", base::FEATURE_DISABLED_BY_DEFAULT}; // Used to control the collection of anchor element metrics (crbug.com/856683). // 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", #if BUILDFLAG(IS_ANDROID) base::FEATURE_ENABLED_BY_DEFAULT #else base::FEATURE_DISABLED_BY_DEFAULT #endif }; // Anchor Element Interaction const base::Feature kAnchorElementInteraction{ "AnchorElementInteraction", base::FEATURE_DISABLED_BY_DEFAULT}; // Enable browser-initiated dedicated worker script loading // (PlzDedicatedWorker). https://crbug.com/906991 const base::Feature kPlzDedicatedWorker{"PlzDedicatedWorker", base::FEATURE_DISABLED_BY_DEFAULT}; // Enable Portals. https://crbug.com/865123. // Note that default enabling this does not expose the portal // element on its own, but does allow its use with an origin trial. This was the // case for the M85 Android only origin trial (https://crbug.com/1040212). const base::Feature kPortals{"Portals", base::FEATURE_DISABLED_BY_DEFAULT}; // When kPortals is enabled, allow portals to load content that is third-party // (cross-origin) to the hosting page. Otherwise has no effect. // // https://crbug.com/1013389 const base::Feature kPortalsCrossOrigin{"PortalsCrossOrigin", base::FEATURE_DISABLED_BY_DEFAULT}; // Enable the element; see crbug.com/1123606. Note that enabling // this feature does not automatically expose this element to the web, it only // allows the element to be enabled by the runtime enabled feature, for origin // trials. const base::Feature kFencedFrames{"FencedFrames", base::FEATURE_DISABLED_BY_DEFAULT}; const base::FeatureParam::Option fenced_frame_implementation_types[] = { {FencedFramesImplementationType::kShadowDOM, "shadow_dom"}, {FencedFramesImplementationType::kMPArch, "mparch"}}; const base::FeatureParam kFencedFramesImplementationTypeParam{ &kFencedFrames, "implementation_type", FencedFramesImplementationType::kShadowDOM, &fenced_frame_implementation_types}; // Enable the shared storage API. This base::Feature directly controls the // corresponding runtime enabled feature. // https://github.com/pythagoraskitty/shared-storage/blob/main/README.md const base::Feature kSharedStorageAPI{"SharedStorageAPI", base::FEATURE_DISABLED_BY_DEFAULT}; const base::FeatureParam kSharedStorageURLSelectionOperationInputURLSizeLimit{ &kSharedStorageAPI, "url_selection_operation_input_url_size_limit", 8}; const base::FeatureParam kMaxSharedStorageStringLength = { &kSharedStorageAPI, "MaxSharedStorageStringLength", 1024}; const base::FeatureParam kMaxSharedStorageEntriesPerOrigin = { &kSharedStorageAPI, "MaxSharedStorageEntriesPerOrigin", 10000}; const base::FeatureParam kMaxSharedStoragePageSize = { &kSharedStorageAPI, "MaxSharedStoragePageSize", 4096}; const base::FeatureParam kMaxSharedStorageCacheSize = { &kSharedStorageAPI, "MaxSharedStorageCacheSize", 1024}; const base::FeatureParam kMaxSharedStorageInitTries = { &kSharedStorageAPI, "MaxSharedStorageInitTries", 2}; const base::FeatureParam kMaxSharedStorageIteratorBatchSize = { &kSharedStorageAPI, "MaxSharedStorageIteratorBatchSize", 100}; const base::FeatureParam kSharedStorageBitBudget = { &kSharedStorageAPI, "SharedStorageBitBudget", 12}; const base::FeatureParam kSharedStorageBudgetInterval = { &kSharedStorageAPI, "SharedStorageBudgetInterval", base::Hours(24)}; const base::FeatureParam kSharedStorageStaleOriginPurgeInitialInterval = { &kSharedStorageAPI, "SharedStorageStaleOriginPurgeInitialInterval", base::Minutes(15)}; const base::FeatureParam kSharedStorageStaleOriginPurgeRecurringInterval = { &kSharedStorageAPI, "SharedStorageStaleOriginPurgeRecurringInterval", base::Hours(2)}; const base::FeatureParam kSharedStorageOriginStalenessThreshold = { &kSharedStorageAPI, "SharedStorageOriginStalenessThreshold", base::Days(60)}; // Enables the Prerender2 feature: https://crbug.com/1126305 // Note that default enabling this does not enable the Prerender2 features // because kSetOnlyIfOverridden is used for setting WebRuntimeFeatures' // Prerender2. To enable this feature, we need to force-enable this feature // using chrome://flags/#enable-prerender2 or --enable-features=Prerender2 // command line or a valid Origin Trial token in the page. const base::Feature kPrerender2 { "Prerender2", #if BUILDFLAG(IS_ANDROID) base::FEATURE_ENABLED_BY_DEFAULT #else base::FEATURE_DISABLED_BY_DEFAULT #endif }; const base::Feature kPrerender2MemoryControls{"Prerender2MemoryControls", base::FEATURE_ENABLED_BY_DEFAULT}; const char kPrerender2MemoryThresholdParamName[] = "memory_threshold_in_mb"; bool IsPrerender2Enabled() { return base::FeatureList::IsEnabled(blink::features::kPrerender2); } bool IsFencedFramesEnabled() { return base::FeatureList::IsEnabled(blink::features::kFencedFrames); } bool IsFencedFramesMPArchBased() { return blink::features::kFencedFramesImplementationTypeParam.Get() == blink::features::FencedFramesImplementationType::kMPArch; } bool IsFencedFramesShadowDOMBased() { return blink::features::kFencedFramesImplementationTypeParam.Get() == blink::features::FencedFramesImplementationType::kShadowDOM; } const base::Feature kInitialNavigationEntry{"InitialNavigationEntry", base::FEATURE_DISABLED_BY_DEFAULT}; bool IsInitialNavigationEntryEnabled() { return base::FeatureList::IsEnabled(blink::features::kInitialNavigationEntry); } // Enable limiting previews loading hints to specific resource types. const base::Feature kPreviewsResourceLoadingHintsSpecificResourceTypes{ "PreviewsResourceLoadingHintsSpecificResourceTypes", base::FEATURE_DISABLED_BY_DEFAULT}; // Perform a memory purge after a renderer is backgrounded. Formerly labelled as // the "PurgeAndSuspend" experiment. // // TODO(https://crbug.com/926186): Disabled by default on Android for historical // reasons. Consider enabling by default if experiment results are positive. const base::Feature kPurgeRendererMemoryWhenBackgrounded { "PurgeRendererMemoryWhenBackgrounded", #if BUILDFLAG(IS_ANDROID) base::FEATURE_DISABLED_BY_DEFAULT #else base::FEATURE_ENABLED_BY_DEFAULT #endif }; // Enables new behavior for window.open() and BarProp properties. const base::Feature kWindowOpenNewPopupBehavior{ "WindowOpenNewPopupBehavior", base::FEATURE_ENABLED_BY_DEFAULT}; // 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). This was shipped in M72. // The feature is still used by virtual test suites exercising Plan B. const base::Feature kRTCUnifiedPlanByDefault{"RTCUnifiedPlanByDefault", base::FEATURE_ENABLED_BY_DEFAULT}; // Determines if the SDP attrbute extmap-allow-mixed should be offered by // default or not. The default value can be overridden by passing // {offerExtmapAllowMixed:false} as an argument to the RTCPeerConnection // constructor. const base::Feature kRTCOfferExtmapAllowMixed{"RTCOfferExtmapAllowMixed", base::FEATURE_ENABLED_BY_DEFAULT}; // Enables waiting for codec support status notification from GPU factory in RTC // codec factories. const base::Feature kRTCGpuCodecSupportWaiter{"kRTCGpuCodecSupportWaiter", base::FEATURE_ENABLED_BY_DEFAULT}; const base::FeatureParam kRTCGpuCodecSupportWaiterTimeoutParam{ &kRTCGpuCodecSupportWaiter, "timeout_ms", 3000}; // Prevents workers from sending IsolateInBackgroundNotification to V8 // and thus instructs V8 to favor performance over memory on workers. const base::Feature kV8OptimizeWorkersForPerformance{ "V8OptimizeWorkersForPerformance", base::FEATURE_ENABLED_BY_DEFAULT}; // Controls whether the implementation of the performance.measureMemory // web API uses PerformanceManager or not. const base::Feature kWebMeasureMemoryViaPerformanceManager{ "WebMeasureMemoryViaPerformanceManager", base::FEATURE_ENABLED_BY_DEFAULT}; // Enables negotiation of experimental multiplex codec in SDP. const base::Feature kWebRtcMultiplexCodec{"WebRTC-MultiplexCodec", base::FEATURE_DISABLED_BY_DEFAULT}; // Causes WebRTC to replace host ICE candidate IP addresses with generated // names ending in ".local" and resolve them using mDNS. // http://crbug.com/878465 const base::Feature kWebRtcHideLocalIpsWithMdns{ "WebRtcHideLocalIpsWithMdns", base::FEATURE_ENABLED_BY_DEFAULT}; // Causes WebRTC to not set the color space of video frames on the receive side // in case it's unspecified. Otherwise we will guess that the color space is // BT709. http://crbug.com/1129243 const base::Feature kWebRtcIgnoreUnspecifiedColorSpace{ "WebRtcIgnoreUnspecifiedColorSpace", base::FEATURE_DISABLED_BY_DEFAULT}; // When enabled, wake ups from throttleable TaskQueues are limited to 1 per // minute in a page that has been backgrounded for 5 minutes. // // Intensive wake up throttling is enforced in addition to other throttling // mechanisms: // - 1 wake up per second in a background page or hidden cross-origin frame // - 1% CPU time in a page that has been backgrounded for 10 seconds // // Feature tracking bug: https://crbug.com/1075553 // // The base::Feature should not be read from; rather the provided accessors // should be used, which also take into account the managed policy override of // the feature. // // The base::Feature is enabled by default on all platforms. However, on // Android, it has no effect because page freezing kicks in at the same time. It // would have an effect if the grace period ("grace_period_seconds" param) was // reduced. const base::Feature kIntensiveWakeUpThrottling{ "IntensiveWakeUpThrottling", base::FEATURE_ENABLED_BY_DEFAULT}; // Name of the parameter that controls the grace period during which there is no // intensive wake up throttling after a page is hidden. Defined here to allow // access from about_flags.cc. The FeatureParam is defined in // third_party/blink/renderer/platform/scheduler/common/features.cc. const char kIntensiveWakeUpThrottling_GracePeriodSeconds_Name[] = "grace_period_seconds"; // Throttles Javascript timer wake ups on foreground pages. const base::Feature kThrottleForegroundTimers{ "ThrottleForegroundTimers", base::FEATURE_DISABLED_BY_DEFAULT}; #if BUILDFLAG(RTC_USE_H264) && BUILDFLAG(ENABLE_FFMPEG_VIDEO_DECODERS) // Run-time feature for the |rtc_use_h264| encoder/decoder. const base::Feature kWebRtcH264WithOpenH264FFmpeg{ "WebRTC-H264WithOpenH264FFmpeg", base::FEATURE_ENABLED_BY_DEFAULT}; #endif // BUILDFLAG(RTC_USE_H264) && BUILDFLAG(ENABLE_FFMPEG_VIDEO_DECODERS) // Experiment of the delay from navigation to starting an update of a service // worker's script. const base::Feature kServiceWorkerUpdateDelay{ "ServiceWorkerUpdateDelay", base::FEATURE_DISABLED_BY_DEFAULT}; // Enable the use of Speculation Rules in access the private prefetch proxy // (chrome/browser/prefetch/prefetch_proxy/). // https://crbug.com/1190167 const base::Feature kSpeculationRulesPrefetchProxy { "SpeculationRulesPrefetchProxy", #if BUILDFLAG(IS_ANDROID) base::FEATURE_ENABLED_BY_DEFAULT #else base::FEATURE_DISABLED_BY_DEFAULT #endif }; // Freeze scheduler task queues in background after allowed grace time. // "stop" is a legacy name. const base::Feature kStopInBackground { "stop-in-background", #if BUILDFLAG(IS_ANDROID) base::FEATURE_ENABLED_BY_DEFAULT #else base::FEATURE_DISABLED_BY_DEFAULT #endif }; // Enable the Storage Access API. https://crbug.com/989663. const base::Feature kStorageAccessAPI{"StorageAccessAPI", base::FEATURE_DISABLED_BY_DEFAULT}; // Enable text snippets in URL fragments. https://crbug.com/919204. const base::Feature kTextFragmentAnchor{"TextFragmentAnchor", base::FEATURE_ENABLED_BY_DEFAULT}; // Enables CSS selector fragment anchors. https://crbug.com/1252460 const base::Feature kCssSelectorFragmentAnchor{ "CssSelectorFragmentAnchor", base::FEATURE_ENABLED_BY_DEFAULT}; // File handling integration. https://crbug.com/829689 const base::Feature kFileHandlingAPI { "FileHandlingAPI", #if BUILDFLAG(IS_ANDROID) base::FEATURE_DISABLED_BY_DEFAULT #else base::FEATURE_ENABLED_BY_DEFAULT #endif }; // File handling icons. https://crbug.com/1218213 const base::Feature kFileHandlingIcons{"FileHandlingIcons", base::FEATURE_DISABLED_BY_DEFAULT}; // Allows for synchronous XHR requests during page dismissal const base::Feature kAllowSyncXHRInPageDismissal{ "AllowSyncXHRInPageDismissal", base::FEATURE_DISABLED_BY_DEFAULT}; // Font enumeration and data access. https://crbug.com/535764 const base::Feature kFontAccess{"FontAccess", base::FEATURE_DISABLED_BY_DEFAULT}; // Kill switch for the Compute Pressure API. https://crbug.com/1067627 const base::Feature kComputePressure{"ComputePressure", base::FEATURE_ENABLED_BY_DEFAULT}; // Prefetch request properties are updated to be privacy-preserving. See // crbug.com/988956. const base::Feature kPrefetchPrivacyChanges{"PrefetchPrivacyChanges", base::FEATURE_ENABLED_BY_DEFAULT}; // Decodes jpeg 4:2:0 formatted images to YUV instead of RGBX and stores in this // format in the image decode cache. See crbug.com/919627 for details on the // feature. const base::Feature kDecodeJpeg420ImagesToYUV{"DecodeJpeg420ImagesToYUV", base::FEATURE_ENABLED_BY_DEFAULT}; // Decodes lossy WebP images to YUV instead of RGBX and stores in this format // in the image decode cache. See crbug.com/900264 for details on the feature. const base::Feature kDecodeLossyWebPImagesToYUV{ "DecodeLossyWebPImagesToYUV", base::FEATURE_ENABLED_BY_DEFAULT}; // Enables cache-aware WebFonts loading. See https://crbug.com/570205. // The feature is disabled on Android for WebView API issue discussed at // https://crbug.com/942440. const base::Feature kWebFontsCacheAwareTimeoutAdaption { "WebFontsCacheAwareTimeoutAdaption", #if BUILDFLAG(IS_ANDROID) base::FEATURE_DISABLED_BY_DEFAULT #else base::FEATURE_ENABLED_BY_DEFAULT #endif }; // Enabled to block programmatic focus in subframes when not triggered by user // activation (see htpps://crbug.com/954349). const base::Feature kBlockingFocusWithoutUserActivation{ "BlockingFocusWithoutUserActivation", base::FEATURE_DISABLED_BY_DEFAULT}; // A server-side switch for the REALTIME_AUDIO thread priority of // RealtimeAudioWorkletThread object. This can be controlled by a field trial, // it will use the NORMAL priority thread when disabled. const base::Feature kAudioWorkletThreadRealtimePriority{ "AudioWorkletThreadRealtimePriority", base::FEATURE_ENABLED_BY_DEFAULT}; // A feature to reduce the set of resources fetched by No-State Prefetch. const base::Feature kLightweightNoStatePrefetch { "LightweightNoStatePrefetch", #if BUILDFLAG(IS_ANDROID) base::FEATURE_ENABLED_BY_DEFAULT #else base::FEATURE_DISABLED_BY_DEFAULT #endif }; // Automatically convert light-themed pages to use a Blink-generated dark theme const base::Feature kForceWebContentsDarkMode{ "WebContentsForceDark", base::FEATURE_DISABLED_BY_DEFAULT}; // A feature to enable using the smallest image specified within image srcset // for users with Save Data enabled. const base::Feature kSaveDataImgSrcset{"SaveDataImgSrcset", base::FEATURE_DISABLED_BY_DEFAULT}; // Which algorithm should be used for color inversion? const base::FeatureParam::Option forcedark_inversion_method_options[] = { {ForceDarkInversionMethod::kUseBlinkSettings, "use_blink_settings_for_method"}, {ForceDarkInversionMethod::kHslBased, "hsl_based"}, {ForceDarkInversionMethod::kCielabBased, "cielab_based"}, {ForceDarkInversionMethod::kRgbBased, "rgb_based"}}; const base::FeatureParam kForceDarkInversionMethodParam{&kForceWebContentsDarkMode, "inversion_method", ForceDarkInversionMethod::kUseBlinkSettings, &forcedark_inversion_method_options}; // Should images be inverted? const base::FeatureParam::Option forcedark_image_behavior_options[] = { {ForceDarkImageBehavior::kUseBlinkSettings, "use_blink_settings_for_images"}, {ForceDarkImageBehavior::kInvertNone, "none"}, {ForceDarkImageBehavior::kInvertSelectively, "selective"}}; const base::FeatureParam kForceDarkImageBehaviorParam{ &kForceWebContentsDarkMode, "image_behavior", ForceDarkImageBehavior::kUseBlinkSettings, &forcedark_image_behavior_options}; // Do not invert text lighter than this. // Range: 0 (do not invert any text) to 255 (invert all text) // Can also set to -1 to let Blink's internal settings control the value const base::FeatureParam kForceDarkForegroundLightnessThresholdParam{ &kForceWebContentsDarkMode, "foreground_lightness_threshold", -1}; // Do not invert backgrounds darker than this. // Range: 0 (invert all backgrounds) to 255 (invert no backgrounds) // Can also set to -1 to let Blink's internal settings control the value const base::FeatureParam kForceDarkBackgroundLightnessThresholdParam{ &kForceWebContentsDarkMode, "background_lightness_threshold", -1}; const base::FeatureParam::Option forcedark_increase_text_contrast_options[] = { {ForceDarkIncreaseTextContrast::kUseBlinkSettings, "use_blink_settings_for_method"}, {ForceDarkIncreaseTextContrast::kFalse, "false"}, {ForceDarkIncreaseTextContrast::kTrue, "true"}}; // Should text contrast be increased. const base::FeatureParam kForceDarkIncreaseTextContrastParam{ &kForceWebContentsDarkMode, "increase_text_contrast", ForceDarkIncreaseTextContrast::kUseBlinkSettings, &forcedark_increase_text_contrast_options}; // Instructs WebRTC to honor the Min/Max Video Encode Accelerator dimensions. const base::Feature kWebRtcUseMinMaxVEADimensions { "WebRtcUseMinMaxVEADimensions", // TODO(crbug.com/1008491): enable other platforms. #if BUILDFLAG(IS_CHROMEOS_ASH) base::FEATURE_ENABLED_BY_DEFAULT #else base::FEATURE_DISABLED_BY_DEFAULT #endif }; // Blink garbage collection. // Enables compaction of backing stores on Blink's heap. const base::Feature kBlinkHeapCompaction{"BlinkHeapCompaction", base::FEATURE_ENABLED_BY_DEFAULT}; // Enables concurrently marking Blink's heap. const base::Feature kBlinkHeapConcurrentMarking{ "BlinkHeapConcurrentMarking", base::FEATURE_ENABLED_BY_DEFAULT}; // Enables concurrently sweeping Blink's heap. const base::Feature kBlinkHeapConcurrentSweeping{ "BlinkHeapConcurrentSweeping", base::FEATURE_ENABLED_BY_DEFAULT}; // Enables incrementally marking Blink's heap. const base::Feature kBlinkHeapIncrementalMarking{ "BlinkHeapIncrementalMarking", base::FEATURE_ENABLED_BY_DEFAULT}; // Enables a marking stress mode that schedules more garbage collections and // also adds additional verification passes. const base::Feature kBlinkHeapIncrementalMarkingStress{ "BlinkHeapIncrementalMarkingStress", base::FEATURE_DISABLED_BY_DEFAULT}; // Controls whether we use ThreadPriority::DISPLAY for renderer // compositor & IO threads. const base::Feature kBlinkCompositorUseDisplayThreadPriority { "BlinkCompositorUseDisplayThreadPriority", #if BUILDFLAG(IS_ANDROID) || BUILDFLAG(IS_CHROMEOS) || BUILDFLAG(IS_WIN) base::FEATURE_ENABLED_BY_DEFAULT #else base::FEATURE_DISABLED_BY_DEFAULT #endif }; // When enabled, enforces new interoperable semantics for 3D transforms. // See crbug.com/1008483. const base::Feature kBackfaceVisibilityInterop{ "BackfaceVisibilityInterop", base::FEATURE_DISABLED_BY_DEFAULT}; // When enabled, beacons (and friends) have ResourceLoadPriority::kLow, // not ResourceLoadPriority::kVeryLow. const base::Feature kSetLowPriorityForBeacon{"SetLowPriorityForBeacon", base::FEATURE_DISABLED_BY_DEFAULT}; // When enabled allows the header name used in the blink // CacheStorageCodeCacheHint runtime feature to be modified. This runtime // feature disables generating full code cache for responses stored in // cache_storage during a service worker install event. The runtime feature // must be enabled via the blink runtime feature mechanism, however. const base::Feature kCacheStorageCodeCacheHintHeader{ "CacheStorageCodeCacheHintHeader", base::FEATURE_DISABLED_BY_DEFAULT}; const base::FeatureParam kCacheStorageCodeCacheHintHeaderName{ &kCacheStorageCodeCacheHintHeader, "name", "x-CacheStorageCodeCacheHint"}; // When enabled, the beforeunload handler is dispatched when a frame is frozen. // This allows the browser to know whether discarding the frame could result in // lost user data, at the cost of extra CPU usage. The feature will be removed // once we have determine whether the CPU cost is acceptable. const base::Feature kDispatchBeforeUnloadOnFreeze{ "DispatchBeforeUnloadOnFreeze", base::FEATURE_ENABLED_BY_DEFAULT}; // Enables the use of GpuMemoryBuffer images for low latency 2d canvas. // TODO(khushalsagar): Enable this if we're using SurfaceControl and GMBs allow // us to overlay these resources. const base::Feature kLowLatencyCanvas2dImageChromium { "LowLatencyCanvas2dImageChromium", #if BUILDFLAG(IS_CHROMEOS_ASH) base::FEATURE_ENABLED_BY_DEFAULT #else base::FEATURE_DISABLED_BY_DEFAULT #endif // BUILDFLAG(IS_CHROMEOS) }; // Enables the use of shared image swap chains for low latency 2d canvas. const base::Feature kLowLatencyCanvas2dSwapChain{ "LowLatencyCanvas2dSwapChain", base::FEATURE_ENABLED_BY_DEFAULT}; // Enables the use of shared image swap chains for low latency webgl canvas. const base::Feature kLowLatencyWebGLSwapChain{"LowLatencyWebGLSwapChain", base::FEATURE_ENABLED_BY_DEFAULT}; // Enables Dawn-accelerated 2D canvas. const base::Feature kDawn2dCanvas{"Dawn2dCanvas", base::FEATURE_DISABLED_BY_DEFAULT}; // Enables small accelerated canvases for webview (crbug.com/1004304) const base::Feature kWebviewAccelerateSmallCanvases{ "WebviewAccelerateSmallCanvases", base::FEATURE_DISABLED_BY_DEFAULT}; // Let accelerated canvases remain accelerated after readback // (crbug.com/1288118) const base::Feature kCanvas2dStaysGPUOnReadback{ "Canvas2dStaysGPUOnReadback", base::FEATURE_DISABLED_BY_DEFAULT}; // When enabled, frees up CachedMetadata after consumption by script resources // and modules. Needed for the experiment in http://crbug.com/1045052. const base::Feature kDiscardCodeCacheAfterFirstUse{ "DiscardCodeCacheAfterFirstUse", base::FEATURE_DISABLED_BY_DEFAULT}; const base::Feature kCacheCodeOnIdle{"CacheCodeOnIdle", base::FEATURE_DISABLED_BY_DEFAULT}; const base::FeatureParam kCacheCodeOnIdleDelayParam{&kCacheCodeOnIdle, "delay-in-ms", 0}; // Kill switch for the new element.offsetParent behavior. // TODO(crbug.com/920069): Remove this once the feature has // landed and no compat issues are reported. const base::Feature kOffsetParentNewSpecBehavior{ "OffsetParentNewSpecBehavior", base::FEATURE_ENABLED_BY_DEFAULT}; // Makes form elements cancel previous form submissions made by the same form // when the default event handler schedules a form submission. // TODO(crbug.com/1234409): Remove this flag when this feature has been in // stable for a release with no issues const base::Feature kCancelFormSubmissionInDefaultHandler{ "CancelFormSubmissionInDefaultHandler", base::FEATURE_ENABLED_BY_DEFAULT}; // Enables the JPEG XL Image File Format (JXL). const base::Feature kJXL{"JXL", base::FEATURE_ENABLED_BY_DEFAULT}; // Make all pending 'display: auto' web fonts enter the swap or failure period // immediately before reaching the LCP time limit (~2500ms), so that web fonts // do not become a source of bad LCP. const base::Feature kAlignFontDisplayAutoTimeoutWithLCPGoal{ "AlignFontDisplayAutoTimeoutWithLCPGoal", base::FEATURE_ENABLED_BY_DEFAULT}; // The amount of time allowed for 'display: auto' web fonts to load without // intervention, counted from navigation start. const base::FeatureParam kAlignFontDisplayAutoTimeoutWithLCPGoalTimeoutParam{ &kAlignFontDisplayAutoTimeoutWithLCPGoal, "lcp-limit-in-ms", 2000}; const base::FeatureParam::Option align_font_display_auto_timeout_with_lcp_goal_modes[] = { {AlignFontDisplayAutoTimeoutWithLCPGoalMode::kToFailurePeriod, "failure"}, {AlignFontDisplayAutoTimeoutWithLCPGoalMode::kToSwapPeriod, "swap"}}; const base::FeatureParam kAlignFontDisplayAutoTimeoutWithLCPGoalModeParam{ &kAlignFontDisplayAutoTimeoutWithLCPGoal, "intervention-mode", AlignFontDisplayAutoTimeoutWithLCPGoalMode::kToSwapPeriod, &align_font_display_auto_timeout_with_lcp_goal_modes}; // Enable throttling of fetch() requests from service workers in the // installing state. The limit of 3 was chosen to match the limit // in background main frames. In addition, trials showed that this // did not cause excessive timeouts and resulted in a net improvement // in successful install rate on some platforms. const base::Feature kThrottleInstallingServiceWorker{ "ThrottleInstallingServiceWorker", base::FEATURE_ENABLED_BY_DEFAULT}; const base::FeatureParam kInstallingServiceWorkerOutstandingThrottledLimit{ &kThrottleInstallingServiceWorker, "limit", 3}; const base::Feature kInputPredictorTypeChoice{ "InputPredictorTypeChoice", base::FEATURE_DISABLED_BY_DEFAULT}; const base::Feature kResamplingInputEvents{"ResamplingInputEvents", base::FEATURE_DISABLED_BY_DEFAULT}; const base::Feature kInputTargetClientHighPriority{ "InputTargetClientHighPriority", base::FEATURE_ENABLED_BY_DEFAULT}; const base::Feature kResamplingScrollEvents{"ResamplingScrollEvents", base::FEATURE_ENABLED_BY_DEFAULT}; // Enables the device-memory, resource-width, viewport-width and DPR client // hints to be sent to third-party origins if the first-party has opted in to // receiving client hints, regardless of Permissions Policy. const base::Feature kAllowClientHintsToThirdParty { "AllowClientHintsToThirdParty", #if BUILDFLAG(IS_ANDROID) base::FEATURE_ENABLED_BY_DEFAULT #else base::FEATURE_DISABLED_BY_DEFAULT #endif }; const base::Feature kFilteringScrollPrediction{ "FilteringScrollPrediction", base::FEATURE_DISABLED_BY_DEFAULT}; const base::Feature kKalmanHeuristics{"KalmanHeuristics", base::FEATURE_DISABLED_BY_DEFAULT}; const base::Feature kKalmanDirectionCutOff{"KalmanDirectionCutOff", base::FEATURE_DISABLED_BY_DEFAULT}; const base::Feature kSkipTouchEventFilter{"SkipTouchEventFilter", base::FEATURE_ENABLED_BY_DEFAULT}; const char kSkipTouchEventFilterTypeParamName[] = "type"; const char kSkipTouchEventFilterTypeParamValueDiscrete[] = "discrete"; const char kSkipTouchEventFilterTypeParamValueAll[] = "all"; const char kSkipTouchEventFilterFilteringProcessParamName[] = "skip_filtering_process"; const char kSkipTouchEventFilterFilteringProcessParamValueBrowser[] = "browser"; const char kSkipTouchEventFilterFilteringProcessParamValueBrowserAndRenderer[] = "browser_and_renderer"; // Disabling this will cause parkable strings to never be compressed. // This is useful for headless mode + virtual time. Since virtual time advances // quickly, strings may be parked too eagerly in that mode. const base::Feature kCompressParkableStrings{"CompressParkableStrings", base::FEATURE_ENABLED_BY_DEFAULT}; // Enabling this will cause parkable strings to use Snappy for compression iff // kCompressParkableStrings is enabled. const base::Feature kUseSnappyForParkableStrings{ "UseSnappyForParkableStrings", base::FEATURE_DISABLED_BY_DEFAULT}; // Enabling this will delay the first aging of strings by 60 seconds instead of // the default. See comment around the use of the feature for the logic behind // the delay. const base::Feature kDelayFirstParkingOfStrings{ "DelayFirstParkingOfStrings", base::FEATURE_DISABLED_BY_DEFAULT}; bool ParkableStringsUseSnappy() { return base::FeatureList::IsEnabled(kUseSnappyForParkableStrings); } bool IsParkableStringsToDiskEnabled() { // Always enabled as soon as compression is enabled. return base::FeatureList::IsEnabled(kCompressParkableStrings); } const base::Feature kCLSScrollAnchoring{"CLSScrollAnchoring", base::FEATURE_ENABLED_BY_DEFAULT}; // Reduce the amount of information in the default 'referer' header for // cross-origin requests. const base::Feature kReducedReferrerGranularity{ "ReducedReferrerGranularity", base::FEATURE_ENABLED_BY_DEFAULT}; // Enables the constant streaming in the ContentCapture task. const base::Feature kContentCaptureConstantStreaming = { "ContentCaptureConstantStreaming", base::FEATURE_ENABLED_BY_DEFAULT}; // Dispatches a fake fetch event to a service worker to check the offline // capability of the site before promoting installation. // See https://crbug.com/965802 for more details. const base::Feature kCheckOfflineCapability{"CheckOfflineCapability", base::FEATURE_DISABLED_BY_DEFAULT}; const base::FeatureParam::Option check_offline_capability_types[] = { {CheckOfflineCapabilityMode::kWarnOnly, "warn_only"}, {CheckOfflineCapabilityMode::kEnforce, "enforce"}}; const base::FeatureParam kCheckOfflineCapabilityParam{&kCheckOfflineCapability, "check_mode", CheckOfflineCapabilityMode::kWarnOnly, &check_offline_capability_types}; // The "BackForwardCacheABExperimentControl" feature indicates the state of the // same-site BackForwardCache experiment. This information is used when sending // the "Sec-bfcache-experiment" HTTP Header on resource requests. The header // value is determined by the value of the "experiment_group_for_http_header" // feature parameter. const base::Feature kBackForwardCacheABExperimentControl{ "BackForwardCacheABExperimentControl", base::FEATURE_DISABLED_BY_DEFAULT}; const char kBackForwardCacheABExperimentGroup[] = "experiment_group_for_http_header"; // Whether we should composite a PLSA (paint layer scrollable area) even if it // means losing lcd text. const base::Feature kPreferCompositingToLCDText = { "PreferCompositingToLCDText", base::FEATURE_DISABLED_BY_DEFAULT}; const base::Feature kLogUnexpectedIPCPostedToBackForwardCachedDocuments{ "LogUnexpectedIPCPostedToBackForwardCachedDocuments", base::FEATURE_ENABLED_BY_DEFAULT}; // Enables web apps to provide theme color and background color overrides for // dark mode. const base::Feature kWebAppEnableDarkMode{"WebAppEnableDarkMode", base::FEATURE_DISABLED_BY_DEFAULT}; // Enables the "handle_links" manifest field for web apps. // Explainer: // https://github.com/WICG/pwa-url-handler/blob/main/handle_links/explainer.md const base::Feature kWebAppEnableHandleLinks{"WebAppEnableHandleLinks", base::FEATURE_DISABLED_BY_DEFAULT}; // Enables the "launch_handler" manifest field for web apps. // Explainer: https://github.com/WICG/sw-launch/blob/main/launch_handler.md const base::Feature kWebAppEnableLaunchHandler{ "WebAppEnableLaunchHandler", base::FEATURE_DISABLED_BY_DEFAULT}; // Enables the deprecated syntax for the above "launch_handler": { // "route_to": "existing-client", // "navigate_existing_client: "always" | "never" // } const base::Feature kWebAppEnableLaunchHandlerV1API{ "WebAppEnableLaunchHandlerV1API", base::FEATURE_ENABLED_BY_DEFAULT}; // Enables Unique ID feature in web apps. Controls parsing of "id" field in web // app manifests. See explainer for more information: // https://github.com/philloooo/pwa-unique-id const base::Feature kWebAppEnableManifestId{"WebAppEnableManifestId", base::FEATURE_ENABLED_BY_DEFAULT}; // Enables the "translations" manifest field for web apps. const base::Feature kWebAppEnableTranslations{ "WebAppEnableTranslations", base::FEATURE_DISABLED_BY_DEFAULT}; // Controls URL handling feature in web apps. Controls parsing of "url_handlers" // field in web app manifests. See explainer for more information: // https://github.com/WICG/pwa-url-handler/blob/main/explainer.md const base::Feature kWebAppEnableUrlHandlers{"WebAppEnableUrlHandlers", base::FEATURE_DISABLED_BY_DEFAULT}; // Controls parsing of the "lock_screen" dictionary field and its "start_url" // entry in web app manifests. See explainer for more information: // https://github.com/WICG/lock-screen/ // Note: the lock screen API and OS integration is separately controlled by // the content feature `kWebLockScreenApi`. const base::Feature kWebAppManifestLockScreen{ "WebAppManifestLockScreen", base::FEATURE_DISABLED_BY_DEFAULT}; // Makes network loading tasks unfreezable so that they can be processed while // the page is frozen. const base::Feature kLoadingTasksUnfreezable{"LoadingTasksUnfreezable", base::FEATURE_ENABLED_BY_DEFAULT}; // Controls how max frame rates are enforced in MediaStreamTracks. // TODO(crbug.com/1152307): Remove in M91. const base::Feature kMediaStreamTrackUseConfigMaxFrameRate{ "MediaStreamTrackUseConfigMaxFrameRate", base::FEATURE_DISABLED_BY_DEFAULT}; // When enabled, the SubresourceFilter receives calls from the ResourceLoader // to perform additional checks against any aliases found from DNS CNAME records // for the requested URL. const base::Feature kSendCnameAliasesToSubresourceFilterFromRenderer{ "SendCnameAliasesToSubresourceFilterFromRenderer", base::FEATURE_DISABLED_BY_DEFAULT}; const base::Feature kDisableDocumentDomainByDefault{ "DisableDocumentDomainByDefault", base::FEATURE_DISABLED_BY_DEFAULT}; // Scopes the memory cache to a fetcher i.e. document/frame. Any resource cached // in the blink cache will only be reused if the most recent fetcher that // fetched it was the same as the current document. const base::Feature kScopeMemoryCachePerContext{ "ScopeMemoryCachePerContext", base::FEATURE_DISABLED_BY_DEFAULT}; // Allow image context menu selections to penetrate through transparent // elements. const base::Feature kEnablePenetratingImageSelection{ "EnablePenetratingImageSelection", base::FEATURE_ENABLED_BY_DEFAULT}; // When enabled, permits shared/root element transitions. See // https://github.com/WICG/shared-element-transitions. const base::Feature kDocumentTransition{"DocumentTransition", base::FEATURE_DISABLED_BY_DEFAULT}; // Used to configure a per-origin allowlist of performance.mark events that are // permitted to be included in slow reports traces. See crbug.com/1181774. const base::Feature kBackgroundTracingPerformanceMark{ "BackgroundTracingPerformanceMark", base::FEATURE_DISABLED_BY_DEFAULT}; const base::FeatureParam kBackgroundTracingPerformanceMark_AllowList{ &kBackgroundTracingPerformanceMark, "allow_list", ""}; // Controls whether the Sanitizer API is available. const base::Feature kSanitizerAPI{"SanitizerAPI", base::FEATURE_DISABLED_BY_DEFAULT}; // Controls whether the Sanitizer API allows namespaced content (SVG + MathML). // // This feature is unlikely to be launched as-is. The primary purpose is to // allow testing of different non-standard configurations. const base::Feature kSanitizerAPINamespaces{"SanitizerAPINamespacesForTesting", base::FEATURE_DISABLED_BY_DEFAULT}; // Kill switch for the blocking of the navigation of top from a cross origin // iframe to a different protocol. TODO(https://crbug.com/1151507): Remove in // M92. const base::Feature kBlockCrossOriginTopNavigationToDiffentScheme{ "BlockCrossOriginTopNavigationToDiffentScheme", base::FEATURE_ENABLED_BY_DEFAULT}; // Enables a Web API for websites to access admin-provided configuration. const base::Feature kManagedConfiguration{"ManagedConfiguration", base::FEATURE_ENABLED_BY_DEFAULT}; // Causes all cross-origin iframes, both same-process and out-of-process, to // have their rendering throttled on display:none or zero-area. const base::Feature kThrottleDisplayNoneAndVisibilityHiddenCrossOriginIframes{ "ThrottleDisplayNoneAndVisibilityHiddenCrossOriginIframes", base::FEATURE_ENABLED_BY_DEFAULT}; // Kill switch for the Interest Group API, i.e. if disabled, the // API exposure will be disabled regardless of the OT config. const base::Feature kInterestGroupStorage{"InterestGroupStorage", base::FEATURE_DISABLED_BY_DEFAULT}; // TODO(crbug.com/1197209): Adjust these limits in response to usage. const base::FeatureParam kInterestGroupStorageMaxOwners{ &kInterestGroupStorage, "max_owners", 1000}; const base::FeatureParam kInterestGroupStorageMaxGroupsPerOwner{ &kInterestGroupStorage, "max_groups_per_owner", 1000}; const base::FeatureParam kInterestGroupStorageMaxOpsBeforeMaintenance{ &kInterestGroupStorage, "max_ops_before_maintenance", 1000000}; // Enable the availability of the ad interest group API as part of the // origin trial for FLEDGE or PARAKEET. const base::Feature kAdInterestGroupAPI{"AdInterestGroupAPI", base::FEATURE_DISABLED_BY_DEFAULT}; // Feature flag to enable PARAKEET implementation (See // https://github.com/WICG/privacy-preserving-ads/blob/main/Parakeet.md). // See also https://crbug.com/1249186. const base::Feature kParakeet{"Parakeet", base::FEATURE_DISABLED_BY_DEFAULT}; // See https://github.com/WICG/turtledove/blob/main/FLEDGE.md // Enables FLEDGE implementation. See https://crbug.com/1186444. const base::Feature kFledge{"Fledge", base::FEATURE_DISABLED_BY_DEFAULT}; // See https://github.com/WICG/turtledove/blob/main/FLEDGE.md // Changes default Permissions Policy for features join-ad-interest-group and // run-ad-auction to a more restricted EnableForSelf. const base::Feature kAdInterestGroupAPIRestrictedPolicyByDefault{ "AdInterestGroupAPIRestrictedPolicyByDefault", base::FEATURE_DISABLED_BY_DEFAULT}; // See https://github.com/WICG/turtledove/blob/main/FLEDGE.md // Feature flag to enable debug reporting APIs. const base::Feature kBiddingAndScoringDebugReportingAPI{ "BiddingAndScoringDebugReportingAPI", base::FEATURE_DISABLED_BY_DEFAULT}; // Enables URN URLs like those produced by FLEDGE auctions to be displayed by // iframes (instead of requiring fenced frames). This is only intended to be // enabled as part of the FLEDGE origin trial. const base::Feature kAllowURNsInIframes{"AllowURNsInIframes", base::FEATURE_DISABLED_BY_DEFAULT}; BLINK_COMMON_EXPORT bool IsAllowURNsInIframeEnabled() { return base::FeatureList::IsEnabled(blink::features::kAllowURNsInIframes); } // https://github.com/jkarlin/topics // Kill switch for the Topics API. const base::Feature kBrowsingTopics{"BrowsingTopics", base::FEATURE_DISABLED_BY_DEFAULT}; // The number of epochs from where to calculate the topics to give to a // requesting contexts. const base::FeatureParam kBrowsingTopicsNumberOfEpochsToExpose{ &kBrowsingTopics, "number_of_epochs_to_expose", 3}; // The periodic topics calculation interval. const base::FeatureParam kBrowsingTopicsTimePeriodPerEpoch{ &kBrowsingTopics, "time_period_per_epoch", base::Days(7)}; // The number of top topics to derive and to keep for each epoch (week). const base::FeatureParam kBrowsingTopicsNumberOfTopTopicsPerEpoch{ &kBrowsingTopics, "number_of_top_topics_per_epoch", 5}; // The probability (in percent number) to return the random topic to a site. The // "random topic" is per-site, and is selected from the full taxonomy uniformly // at random, and each site has a // `kBrowsingTopicsUseRandomTopicProbabilityPercent`% chance to see their random // topic instead of one of the top topics. const base::FeatureParam kBrowsingTopicsUseRandomTopicProbabilityPercent{ &kBrowsingTopics, "use_random_topic_probability_percent", 5}; // How many epochs (weeks) of API usage data (i.e. topics observations) will be // based off for the filtering of topics for a calling context. const base::FeatureParam kBrowsingTopicsNumberOfEpochsOfObservationDataToUseForFiltering{ &kBrowsingTopics, "number_of_epochs_of_observation_data_to_use_for_filtering", 3}; // The max number of observed-by context domains to keep for each top topic. // The intent is to cap the in-use memory. const base::FeatureParam kBrowsingTopicsMaxNumberOfApiUsageContextDomainsToKeepPerTopic{ &kBrowsingTopics, "max_number_of_api_usage_context_domains_to_keep_per_topic", 1000}; // The max number of entries allowed to be retrieved from the // `BrowsingTopicsSiteDataStorage` database for each query for the API usage // contexts. The query will occur once per epoch (week) at topics calculation // time. The intent is to cap the peak memory usage. const base::FeatureParam kBrowsingTopicsMaxNumberOfApiUsageContextEntriesToLoadPerEpoch{ &kBrowsingTopics, "max_number_of_api_usage_context_entries_to_load_per_epoch", 100000}; // The max number of API usage context domains allowed to be stored per page // load. const base::FeatureParam kBrowsingTopicsMaxNumberOfApiUsageContextDomainsToStorePerPageLoad{ &kBrowsingTopics, "max_number_of_api_usage_context_domains_to_store_per_page_load", 30}; // Encodes the configuration parameters above. Each version number should only // be mapped to one configuration set. In practice, this can be guaranteed by // always bumping up the version number whenever parameters are updated. const base::FeatureParam kBrowsingTopicsConfigVersion{&kBrowsingTopics, "config_version", 1}; // The taxonomy version. This only affects the topics classification that occurs // during this browser session, and doesn't affect the pre-existing epochs. const base::FeatureParam kBrowsingTopicsTaxonomyVersion{ &kBrowsingTopics, "taxonomy_version", 1}; // If enabled, the check for whether the IP address is publicly routable will be // bypassed when determining the eligibility for a page to be included in topics // calculation. This is useful for developers to test in local environment. const base::Feature kBrowsingTopicsBypassIPIsPubliclyRoutableCheck{ "BrowsingTopicsBypassIPIsPubliclyRoutableCheck", base::FEATURE_DISABLED_BY_DEFAULT}; // When s are closed, this focuses the "previously focused" element // which had focus when the was first opened. // TODO(crbug.com/649162): Remove DialogFocusNewSpecBehavior after // the feature is in stable with no issues. const base::Feature kDialogFocusNewSpecBehavior{ "DialogFocusNewSpecBehavior", base::FEATURE_ENABLED_BY_DEFAULT}; // Makes autofill look across shadow boundaries when collecting form controls to // fill. const base::Feature kAutofillShadowDOM{"AutofillShadowDOM", base::FEATURE_DISABLED_BY_DEFAULT}; // Allows read/write of custom formats with unsanitized clipboard content. See // crbug.com/106449. const base::Feature kClipboardCustomFormats{"ClipboardCustomFormats", base::FEATURE_DISABLED_BY_DEFAULT}; // Uses page viewport instead of frame viewport in the Largest Contentful Paint // heuristic where images occupying the full viewport are ignored. const base::Feature kUsePageViewportInLCP{"UsePageViewportInLCP", base::FEATURE_ENABLED_BY_DEFAULT}; // Enable `Sec-CH-UA-Platform` client hint and request header to be sent by // default const base::Feature kUACHPlatformEnabledByDefault{ "UACHPlatformEnabledByDefault", base::FEATURE_ENABLED_BY_DEFAULT}; // When enabled, allow dropping alpha on media streams for rendering sinks if // other sinks connected do not use alpha. const base::Feature kAllowDropAlphaForMediaStream{ "AllowDropAlphaForMediaStream", base::FEATURE_ENABLED_BY_DEFAULT}; // Enables partitioning of third party storage (IndexedDB, CacheStorage, etc.) // by the top level site to reduce fingerprinting. const base::Feature kThirdPartyStoragePartitioning{ "ThirdPartyStoragePartitioning", base::FEATURE_DISABLED_BY_DEFAULT}; // API that allows installed PWAs to add additional shortcuts by means of // installing sub app components. const base::Feature kDesktopPWAsSubApps{"DesktopPWAsSubApps", base::FEATURE_DISABLED_BY_DEFAULT}; // Suppresses console errors for CORS problems which report an associated // inspector issue anyway. const base::Feature kCORSErrorsIssueOnly{"CORSErrorsIssueOnly", base::FEATURE_DISABLED_BY_DEFAULT}; const base::Feature kPersistentQuotaIsTemporaryQuota{ "PersistentQuotaIsTemporaryQuota", base::FEATURE_DISABLED_BY_DEFAULT}; const base::Feature kDelayLowPriorityRequestsAccordingToNetworkState{ "DelayLowPriorityRequestsAccordingToNetworkState", base::FEATURE_DISABLED_BY_DEFAULT}; const base::Feature kIncludeInitiallyInvisibleImagesInLCP{ "IncludeInitiallyInvisibleImagesInLCP", base::FEATURE_DISABLED_BY_DEFAULT}; const base::Feature kIncludeBackgroundSVGInLCP{ "IncludeBackgroundSVGInLCP", base::FEATURE_DISABLED_BY_DEFAULT}; const base::FeatureParam kMaxNumOfThrottleableRequestsInTightMode{ &kDelayLowPriorityRequestsAccordingToNetworkState, "MaxNumOfThrottleableRequestsInTightMode", 5}; const base::Feature kHTMLParamElementUrlSupport{ "HTMLParamElementUrlSupport", base::FEATURE_ENABLED_BY_DEFAULT}; const base::FeatureParam kHttpRttThreshold{ &kDelayLowPriorityRequestsAccordingToNetworkState, "HttpRttThreshold", base::Milliseconds(450)}; const base::FeatureParam kCostReductionOfMultiplexedRequests{ &kDelayLowPriorityRequestsAccordingToNetworkState, "CostReductionOfMultiplexedRequests", 0.5}; const base::Feature kForceMajorVersionInMinorPositionInUserAgent{ "ForceMajorVersionInMinorPositionInUserAgent", base::FEATURE_DISABLED_BY_DEFAULT}; // Enable `sec-ch-device-memory` client hint. const base::Feature kClientHintsDeviceMemory{"ClientHintsDeviceMemory", base::FEATURE_ENABLED_BY_DEFAULT}; // Enable `sec-ch-dpr` client hint. const base::Feature kClientHintsDPR{"ClientHintsDPR", base::FEATURE_ENABLED_BY_DEFAULT}; // Enable `sec-ch-width` client hint. const base::Feature kClientHintsResourceWidth{"ClientHintsResourceWidth", base::FEATURE_ENABLED_BY_DEFAULT}; // Enable `sec-ch-viewport-width` client hint. const base::Feature kClientHintsViewportWidth{"ClientHintsViewportWidth", base::FEATURE_ENABLED_BY_DEFAULT}; // Enable legacy `device-memory` client hint. const base::Feature kClientHintsDeviceMemory_DEPRECATED{ "ClientHintsDeviceMemory_DEPRECATED", base::FEATURE_ENABLED_BY_DEFAULT}; // Enable legacy `dpr` client hint. const base::Feature kClientHintsDPR_DEPRECATED{ "ClientHintsDPR_DEPRECATED", base::FEATURE_ENABLED_BY_DEFAULT}; // Enable legacy `width` client hint. const base::Feature kClientHintsResourceWidth_DEPRECATED{ "ClientHintsResourceWidth_DEPRECATED", base::FEATURE_ENABLED_BY_DEFAULT}; // Enable legacy `viewport-width` client hint. const base::Feature kClientHintsViewportWidth_DEPRECATED{ "ClientHintsViewportWidth_DEPRECATED", base::FEATURE_ENABLED_BY_DEFAULT}; // If enabled, the setTimeout(..., 0) will not clamp to 1ms. // Tracking bug: https://crbug.com/402694. const base::Feature kSetTimeoutWithoutClamp{"SetTimeoutWithoutClamp", base::FEATURE_DISABLED_BY_DEFAULT}; namespace { enum class SetTimeoutWithout1MsClampPolicyOverride { kNoOverride, kForceDisable, kForceEnable }; bool g_set_timeout_without_1m_clamp_policy_override_cached = false; // Returns the SetTimeoutWithout1MsClamp policy settings. This is calculated // once on first access and cached. SetTimeoutWithout1MsClampPolicyOverride GetSetTimeoutWithout1MsClampPolicyOverride() { static SetTimeoutWithout1MsClampPolicyOverride policy = SetTimeoutWithout1MsClampPolicyOverride::kNoOverride; if (g_set_timeout_without_1m_clamp_policy_override_cached) return policy; // Otherwise, check the command-line for the renderer. Only values of "0" // and "1" are valid, anything else is ignored (and allows the base::Feature // to control the feature). This slow path will only be hit once per renderer // process. std::string value = base::CommandLine::ForCurrentProcess()->GetSwitchValueASCII( switches::kSetTimeoutWithout1MsClampPolicy); if (value == switches::kSetTimeoutWithout1MsClampPolicy_ForceEnable) { policy = SetTimeoutWithout1MsClampPolicyOverride::kForceEnable; } else if (value == switches::kSetTimeoutWithout1MsClampPolicy_ForceDisable) { policy = SetTimeoutWithout1MsClampPolicyOverride::kForceDisable; } else { policy = SetTimeoutWithout1MsClampPolicyOverride::kNoOverride; } g_set_timeout_without_1m_clamp_policy_override_cached = true; return policy; } } // namespace void ClearSetTimeoutWithout1MsClampPolicyOverrideCacheForTesting() { // Tests may want to force recalculation of the cached policy value when // exercising different configs. g_set_timeout_without_1m_clamp_policy_override_cached = false; } bool IsSetTimeoutWithoutClampEnabled() { // If policy is present then respect it. auto policy = GetSetTimeoutWithout1MsClampPolicyOverride(); if (policy != SetTimeoutWithout1MsClampPolicyOverride::kNoOverride) return policy == SetTimeoutWithout1MsClampPolicyOverride::kForceEnable; // Otherwise respect the base::Feature. return base::FeatureList::IsEnabled(features::kSetTimeoutWithoutClamp); } // If enabled, the setTimeout(..., 0) will clamp to 4ms after a custom `nesting` // level. // Tracking bug: https://crbug.com/1108877. const base::Feature kMaxUnthrottledTimeoutNestingLevel{ "MaxUnthrottledTimeoutNestingLevel", base::FEATURE_DISABLED_BY_DEFAULT}; const base::FeatureParam kMaxUnthrottledTimeoutNestingLevelParam{ &kMaxUnthrottledTimeoutNestingLevel, "nesting", 10}; bool IsMaxUnthrottledTimeoutNestingLevelEnabled() { return base::FeatureList::IsEnabled( blink::features::kMaxUnthrottledTimeoutNestingLevel); } int GetMaxUnthrottledTimeoutNestingLevel() { return kMaxUnthrottledTimeoutNestingLevelParam.Get(); } const base::Feature kTabSwitchMetrics2{"TabSwitchMetrics2", base::FEATURE_DISABLED_BY_DEFAULT}; // Enables reporting and web-exposure (respectively) of the time the first frame // of an animated image was painted. const base::Feature kLCPAnimatedImagesReporting{ "LCPAnimatedImagesReporting", base::FEATURE_DISABLED_BY_DEFAULT}; // TODO(crbug.com/1185950): Remove this flag when the feature is fully launched // and released to stable with no issues. const base::Feature kAutoExpandDetailsElement{"AutoExpandDetailsElement", base::FEATURE_ENABLED_BY_DEFAULT}; // Enables loading the response body earlier in navigation. const base::Feature kEarlyBodyLoad{"EarlyBodyLoad", base::FEATURE_ENABLED_BY_DEFAULT}; // Enables fetching the code cache earlier in navigation. const base::Feature kEarlyCodeCache{"EarlyCodeCache", base::FEATURE_ENABLED_BY_DEFAULT}; // Allow use of an http-equiv meta tag to set client hints. const base::Feature kClientHintsMetaHTTPEquivAcceptCH{ "ClientHintsMetaHTTPEquivAcceptCH", base::FEATURE_ENABLED_BY_DEFAULT}; // Allow use of a named meta tag to set client hints. const base::Feature kClientHintsMetaNameAcceptCH{ "ClientHintsMetaNameAcceptCH", base::FEATURE_ENABLED_BY_DEFAULT}; const base::Feature kOriginAgentClusterDefaultEnabled{ "OriginAgentClusterDefaultEnable", base::FEATURE_DISABLED_BY_DEFAULT}; const base::Feature kOriginAgentClusterDefaultWarning{ "OriginAgentClusterDefaultWarning", base::FEATURE_ENABLED_BY_DEFAULT}; // Allow third-party delegation of client hint information. const base::Feature kClientHintThirdPartyDelegation{ "ClientHintThirdPartyDelegation", base::FEATURE_ENABLED_BY_DEFAULT}; #if BUILDFLAG(IS_ANDROID) // Enables prefetching Android fonts on renderer startup. const base::Feature kPrefetchAndroidFonts{"PrefetchAndroidFonts", base::FEATURE_ENABLED_BY_DEFAULT}; #endif const base::Feature kCompositedCaret{"CompositedCaret", base::FEATURE_ENABLED_BY_DEFAULT}; const base::Feature kBackForwardCacheAppBanner{ "BackForwardCacheAppBanner", base::FEATURE_DISABLED_BY_DEFAULT}; // Initialize CSSDefaultStyleSheets early in renderer startup. const base::Feature kDefaultStyleSheetsEarlyInit{ "DefaultStyleSheetsEarlyInit", base::FEATURE_ENABLED_BY_DEFAULT}; const base::Feature kSystemColorChooser{"SystemColorChooser", base::FEATURE_DISABLED_BY_DEFAULT}; const base::Feature kNoForcedFrameUpdatesForWebTests{ "NoForcedFrameUpdatesForWebTests", base::FEATURE_DISABLED_BY_DEFAULT}; // This flag makes ElementRareData lazily initialize infrequently used fields as // another class called ElementSuperRareData to improve memory usage. const base::Feature kElementSuperRareData{"ElementSuperRareData", base::FEATURE_DISABLED_BY_DEFAULT}; const base::Feature kClientHintsPartitionedCookies{ "ClientHintsPartitionedCookies", base::FEATURE_DISABLED_BY_DEFAULT}; // If enabled, the memory limit used for tiles is scaled by // `kScaleTileMemoryLimitFactor`. const base::Feature kScaleTileMemoryLimit{"ScaleTileMemoryLimit", base::FEATURE_DISABLED_BY_DEFAULT}; const base::FeatureParam kScaleTileMemoryLimitFactor{ &kScaleTileMemoryLimit, "Factor", 1.0}; const base::Feature kDurableClientHintsCache{"DurableClientHintsCache", base::FEATURE_ENABLED_BY_DEFAULT}; // If enabled, allows web pages to use the experimental EditContext API to // better control text input. See crbug.com/999184. const base::Feature kEditContext{"EditContext", base::FEATURE_DISABLED_BY_DEFAULT}; // Enables basic Multi-Screen Window Placement functionality. const base::Feature kWindowPlacement{"WindowPlacement", base::FEATURE_ENABLED_BY_DEFAULT}; // Allows sites to request fullscreen and open a popup from a single gesture. const base::Feature kWindowPlacementFullscreenCompanionWindow{ "WindowPlacementFullscreenCompanionWindow", base::FEATURE_DISABLED_BY_DEFAULT}; // Allows sites to request fullscreen when the set of screens change. const base::Feature kWindowPlacementFullscreenOnScreensChange{ "WindowPlacementFullscreenOnScreensChange", base::FEATURE_DISABLED_BY_DEFAULT}; // TODO(crbug.com/1277431): This flag should be eventually disabled. const base::Feature kEventPath{"EventPath", base::FEATURE_ENABLED_BY_DEFAULT}; // Removes a paint invalidation of viewport constrained objects (sticky or // fixed) after scrolling. const base::Feature kOptimizeViewportConstrainedPaintInvalidation{ "OptimizeViewportConstrainedPaintInvalidation", base::FEATURE_ENABLED_BY_DEFAULT}; const base::Feature kReduceUserAgentMinorVersion{ "ReduceUserAgentMinorVersion", base::FEATURE_DISABLED_BY_DEFAULT}; const base::FeatureParam kUserAgentFrozenBuildVersion{ &kReduceUserAgentMinorVersion, "build_version", "0"}; const base::Feature kReportFCPOnlyOnSuccessfulCommit{ "ReportFCPOnlyOnSuccessfulCommit", base::FEATURE_DISABLED_BY_DEFAULT}; // Enables correctly computing whether dedicated workers are secure contexts. // TODO(https://crbug.com/780031): Remove this once fully shipped. const base::Feature kSecureContextFixForWorkers{ "SecureContextFixForWorkers", base::FEATURE_ENABLED_BY_DEFAULT}; const base::Feature kZeroCopyTabCapture{"ZeroCopyTabCapture", base::FEATURE_DISABLED_BY_DEFAULT}; const base::Feature kUserAgentOverrideExperiment{ "UserAgentOverrideExperiment", base::FEATURE_DISABLED_BY_DEFAULT}; // Allow access to WebSQL APIs. const base::Feature kWebSQLAccess{"kWebSQLAccess", base::FEATURE_ENABLED_BY_DEFAULT}; // Changes behavior of User-Agent Client Hints to send blank headers when the // User-Agent string is overridden, instead of disabling the headers altogether. const base::Feature kUACHOverrideBlank{"UACHOverrideBlank", base::FEATURE_DISABLED_BY_DEFAULT}; #if BUILDFLAG(IS_WIN) const base::Feature kPrewarmDefaultFontFamilies{ "PrewarmDefaultFontFamilies", base::FEATURE_DISABLED_BY_DEFAULT}; const base::FeatureParam kPrewarmStandard = {&kPrewarmDefaultFontFamilies, "prewarm_standard", true}; const base::FeatureParam kPrewarmFixed = {&kPrewarmDefaultFontFamilies, "prewarm_fixed", true}; const base::FeatureParam kPrewarmSerif = {&kPrewarmDefaultFontFamilies, "prewarm_serif", true}; const base::FeatureParam kPrewarmSansSerif = { &kPrewarmDefaultFontFamilies, "prewarm_sans_serif", true}; const base::FeatureParam kPrewarmCursive = {&kPrewarmDefaultFontFamilies, "prewarm_cursive", true}; const base::FeatureParam kPrewarmFantasy = {&kPrewarmDefaultFontFamilies, "prewarm_fantasy", true}; #endif // Enable `save-data` client hint. const base::Feature kClientHintsSaveData{"ClientHintsSaveData", base::FEATURE_ENABLED_BY_DEFAULT}; const base::Feature kEstablishGpuChannelAsync{ "EstablishGpuChannelAsync", base::FEATURE_DISABLED_BY_DEFAULT}; const base::Feature kDeferBeginMainFrameDuringLoading{ "DeferBeginMainFrameDuringLoading", base::FEATURE_DISABLED_BY_DEFAULT}; const base::FeatureParam kRecentBeginMainFrameCutoff = { &kDeferBeginMainFrameDuringLoading, "recent_begin_main_frame_cutoff", base::Milliseconds(150)}; const base::Feature kDecodeScriptSourceOffThread{ "DecodeScriptSourceOffThread", base::FEATURE_DISABLED_BY_DEFAULT}; const base::Feature kAllowSourceSwitchOnPausedVideoMediaStream{ "AllowSourceSwitchOnPausedVideoMediaStream", base::FEATURE_ENABLED_BY_DEFAULT}; const base::Feature kDispatchPopstateSync{"DispatchPopstateSync", base::FEATURE_ENABLED_BY_DEFAULT}; // Exposes non-standard stats in the WebRTC getStats() API. const base::Feature kWebRtcExposeNonStandardStats{ "WebRtc-ExposeNonStandardStats", base::FEATURE_DISABLED_BY_DEFAULT}; } // namespace features } // namespace blink