mirror of
https://github.com/Alex313031/thorium.git
synced 2025-01-10 03:47:44 -03:00
M130 stage 3
This commit is contained in:
parent
b41032d110
commit
62e861d336
17 changed files with 708 additions and 504 deletions
|
@ -2232,6 +2232,9 @@ config("no_chromium_code") {
|
||||||
# third-party libraries.
|
# third-party libraries.
|
||||||
"-Wno-c++11-narrowing",
|
"-Wno-c++11-narrowing",
|
||||||
]
|
]
|
||||||
|
if (is_full_optimization_build) {
|
||||||
|
cflags += [ "-Xclang", "-O3" ]
|
||||||
|
}
|
||||||
if (!is_nacl) {
|
if (!is_nacl) {
|
||||||
cflags += [
|
cflags += [
|
||||||
# Disabled for similar reasons as -Wunused-variable.
|
# Disabled for similar reasons as -Wunused-variable.
|
||||||
|
|
130
other/thor_ver_linux/wrapper-raspi
Normal file
130
other/thor_ver_linux/wrapper-raspi
Normal file
|
@ -0,0 +1,130 @@
|
||||||
|
#!/bin/bash
|
||||||
|
#
|
||||||
|
# Copyright 2024 The Chromium Authors, the AUR, and Alex313031
|
||||||
|
# Use of this source code is governed by a BSD-style license that can be
|
||||||
|
# found in the LICENSE file.
|
||||||
|
|
||||||
|
# Let the wrapped binary know that it has been run through the wrapper.
|
||||||
|
export CHROME_WRAPPER="`readlink -f "$0"`"
|
||||||
|
|
||||||
|
HERE="`dirname "$CHROME_WRAPPER"`"
|
||||||
|
|
||||||
|
# We include some xdg utilities next to the binary, and we want to prefer them
|
||||||
|
# over the system versions when we know the system versions are very old. We
|
||||||
|
# detect whether the system xdg utilities are sufficiently new to be likely to
|
||||||
|
# work for us by looking for xdg-settings. If we find it, we leave $PATH alone,
|
||||||
|
# so that the system xdg utilities (including any distro patches) will be used.
|
||||||
|
if ! command -v xdg-settings &> /dev/null; then
|
||||||
|
# Old xdg utilities. Prepend $HERE to $PATH to use ours instead.
|
||||||
|
export PATH="$HERE:$PATH"
|
||||||
|
else
|
||||||
|
# Use system xdg utilities. But first create mimeapps.list if it doesn't
|
||||||
|
# exist; some systems have bugs in xdg-mime that make it fail without it.
|
||||||
|
xdg_app_dir="${XDG_DATA_HOME:-$HOME/.local/share/applications}"
|
||||||
|
mkdir -p "$xdg_app_dir"
|
||||||
|
[ -f "$xdg_app_dir/mimeapps.list" ] || touch "$xdg_app_dir/mimeapps.list"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Always use our versions of ffmpeg libs.
|
||||||
|
# This also makes RPMs find the compatibly-named library symlinks.
|
||||||
|
if [[ -n "$LD_LIBRARY_PATH" ]]; then
|
||||||
|
LD_LIBRARY_PATH="$HERE/lib:$LD_LIBRARY_PATH"
|
||||||
|
else
|
||||||
|
LD_LIBRARY_PATH="$HERE/lib"
|
||||||
|
fi
|
||||||
|
export LD_LIBRARY_PATH
|
||||||
|
|
||||||
|
# Clean up old crash reports (see https://bugs.debian.org/1015931)
|
||||||
|
# after 30 days.
|
||||||
|
find "$HOME/.config/thorium/Crash Reports/pending/" -mtime +30 \
|
||||||
|
\( -name "*.meta" -o -name "*.dmp" \) -exec rm \{\} \;
|
||||||
|
|
||||||
|
# APPNAME for GTK.
|
||||||
|
APPNAME=thorium
|
||||||
|
|
||||||
|
# Set DESKTOP variable
|
||||||
|
# DESKTOP="thorium-browser"
|
||||||
|
|
||||||
|
# Set XDG Title variable
|
||||||
|
TITLE="Thorium Browser"
|
||||||
|
|
||||||
|
# Set the correct file name for the desktop file
|
||||||
|
export CHROME_DESKTOP="thorium-browser.desktop"
|
||||||
|
|
||||||
|
# Set CHROME_VERSION_EXTRA text, which is displayed in the About dialog on chrome://help
|
||||||
|
# DIST=`cat /etc/debian_version`
|
||||||
|
export CHROME_VERSION_EXTRA="@@CHANNEL@@, built on Ubuntu (arm64)"
|
||||||
|
|
||||||
|
# We don't want bug-buddy intercepting our crashes. http://crbug.com/24120
|
||||||
|
export GNOME_DISABLE_CRASH_DIALOG=SET_BY_THORIUM
|
||||||
|
|
||||||
|
# Set config home.
|
||||||
|
XDG_CONFIG_HOME=${XDG_CONFIG_HOME:-~/.config}
|
||||||
|
|
||||||
|
usage () {
|
||||||
|
echo "thorium-browser [-h|--help] [--temp-profile] [options] [URL]"
|
||||||
|
echo
|
||||||
|
echo " -h, -help, or --help This help screen"
|
||||||
|
echo " --temp-profile Start with a new and temporary profile"
|
||||||
|
echo " --safe-mode Disable all chrome://flags flags"
|
||||||
|
echo
|
||||||
|
echo " Other supported options are:"
|
||||||
|
MANWIDTH=80 man thorium-browser | sed -e '1,/OPTIONS/d; /ENVIRONMENT/,$d'
|
||||||
|
echo " See 'man thorium-browser' for more details"
|
||||||
|
}
|
||||||
|
|
||||||
|
want_temp_profile=0
|
||||||
|
is_safe_mode=0
|
||||||
|
while [ $# -gt 0 ]; do
|
||||||
|
case "$1" in
|
||||||
|
-h | --h | -help | --help )
|
||||||
|
usage
|
||||||
|
exit 0 ;;
|
||||||
|
--temp-profile )
|
||||||
|
want_temp_profile=1
|
||||||
|
shift ;;
|
||||||
|
--safe-mode )
|
||||||
|
is_safe_mode=1
|
||||||
|
shift ;;
|
||||||
|
-- ) # Stop option processing
|
||||||
|
shift
|
||||||
|
break ;;
|
||||||
|
* ) # Else
|
||||||
|
break ;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
# Allow users to override command-line options with a file.
|
||||||
|
if [[ -f $XDG_CONFIG_HOME/thorium/thorium-flags.conf ]]; then
|
||||||
|
CHROME_USER_FLAGS="$(cat $XDG_CONFIG_HOME/thorium/thorium-flags.conf)"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Sanitize std{in,out,err} because they'll be shared with untrusted child
|
||||||
|
# processes (http://crbug.com/376567).
|
||||||
|
exec < /dev/null
|
||||||
|
exec > >(exec cat)
|
||||||
|
exec 2> >(exec cat >&2)
|
||||||
|
|
||||||
|
if [ $want_temp_profile -eq 1 ] ; then
|
||||||
|
TEMP_PROFILE=`mktemp -d`
|
||||||
|
echo "Using temporary profile: $TEMP_PROFILE"
|
||||||
|
PROFILE="$TEMP_PROFILE"
|
||||||
|
CACHE="$TEMP_PROFILE/cache"
|
||||||
|
export PROFILE
|
||||||
|
export CACHE
|
||||||
|
CHROME_USER_FLAGS="$CHROME_USER_FLAGS --user-data-dir=$TEMP_PROFILE --disk-cache-dir=$CACHE"
|
||||||
|
else
|
||||||
|
PROFILE="$XDG_CONFIG_HOME/thorium"
|
||||||
|
CACHE="$XDG_CONFIG_HOME/thorium"
|
||||||
|
export PROFILE
|
||||||
|
export CACHE
|
||||||
|
CHROME_USER_FLAGS="$CHROME_USER_FLAGS"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ $is_safe_mode -eq 1 ] ; then
|
||||||
|
CHROME_USER_FLAGS="$CHROME_USER_FLAGS --no-experiments"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Launch Thorium
|
||||||
|
# Note: exec -a below is a bashism.
|
||||||
|
exec -a "$0" "$HERE/@@PROGNAME@@" "$CHROME_USER_FLAGS" "$@"
|
|
@ -1651,7 +1651,7 @@ new file mode 100644
|
||||||
index 0000000000000..04703d70ecf9b
|
index 0000000000000..04703d70ecf9b
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/chrome/browser/ui/views/frame/window_caption_util.cc
|
+++ b/chrome/browser/ui/views/frame/window_caption_util.cc
|
||||||
@@ -0,0 +1,24 @@
|
@@ -0,0 +1,26 @@
|
||||||
+// Copyright 2024 The Chromium Authors and Alex313031
|
+// Copyright 2024 The Chromium Authors and Alex313031
|
||||||
+// Use of this source code is governed by a BSD-style license that can be
|
+// Use of this source code is governed by a BSD-style license that can be
|
||||||
+// found in the LICENSE file.
|
+// found in the LICENSE file.
|
||||||
|
@ -1670,8 +1670,10 @@ index 0000000000000..04703d70ecf9b
|
||||||
+ base::CommandLine::ForCurrentProcess()->HasSwitch("remove-tabsearch-button");
|
+ base::CommandLine::ForCurrentProcess()->HasSwitch("remove-tabsearch-button");
|
||||||
+ static const bool disable_caption_button =
|
+ static const bool disable_caption_button =
|
||||||
+ base::CommandLine::ForCurrentProcess()->HasSwitch("disable-caption-button");
|
+ base::CommandLine::ForCurrentProcess()->HasSwitch("disable-caption-button");
|
||||||
|
+ static const bool left_aligned_tab_search_button =
|
||||||
|
+ base::CommandLine::ForCurrentProcess()->HasSwitch("left-aligned-tab-search-button");
|
||||||
+ return features::IsThorium2024() && browser->is_type_normal() &&
|
+ return features::IsThorium2024() && browser->is_type_normal() &&
|
||||||
+ !remove_tabsearch_button && !disable_caption_button;
|
+ !remove_tabsearch_button && !disable_caption_button && !left_aligned_tab_search_button;
|
||||||
+#else
|
+#else
|
||||||
+ return false;
|
+ return false;
|
||||||
+#endif // BUILDFLAG(IS_WIN)
|
+#endif // BUILDFLAG(IS_WIN)
|
||||||
|
|
11
setup.sh
11
setup.sh
|
@ -173,6 +173,7 @@ copyRaspi () {
|
||||||
cp -r -v arm/build/* ${CR_SRC_DIR}/build/ &&
|
cp -r -v arm/build/* ${CR_SRC_DIR}/build/ &&
|
||||||
cp -r -v arm/third_party/* ${CR_SRC_DIR}/third_party/ &&
|
cp -r -v arm/third_party/* ${CR_SRC_DIR}/third_party/ &&
|
||||||
cp -r -v arm/raspi/* ${CR_SRC_DIR}/ &&
|
cp -r -v arm/raspi/* ${CR_SRC_DIR}/ &&
|
||||||
|
cp -v other/thor_ver_linux/wrapper-raspi ${CR_SRC_DIR}/chrome/installer/linux/common/wrapper &&
|
||||||
cp -v pak_src/binaries/pak_arm64 ${CR_SRC_DIR}/out/thorium/pak &&
|
cp -v pak_src/binaries/pak_arm64 ${CR_SRC_DIR}/out/thorium/pak &&
|
||||||
#./infra/fix_libaom.sh &&
|
#./infra/fix_libaom.sh &&
|
||||||
printf "\n" &&
|
printf "\n" &&
|
||||||
|
@ -211,7 +212,7 @@ copyAVX512 () {
|
||||||
printf "${YEL}Copying AVX-512 build files...${c0}\n" &&
|
printf "${YEL}Copying AVX-512 build files...${c0}\n" &&
|
||||||
cp -r -v other/AVX2/third_party/* ${CR_SRC_DIR}/third_party/ &&
|
cp -r -v other/AVX2/third_party/* ${CR_SRC_DIR}/third_party/ &&
|
||||||
cp -v other/AVX512/thor_ver ${CR_SRC_DIR}/out/thorium/ &&
|
cp -v other/AVX512/thor_ver ${CR_SRC_DIR}/out/thorium/ &&
|
||||||
cp -v infra/thor_ver_linux/wrapper-avx512 ${CR_SRC_DIR}/chrome/installer/linux/common/wrapper &&
|
cp -v other/thor_ver_linux/wrapper-avx512 ${CR_SRC_DIR}/chrome/installer/linux/common/wrapper &&
|
||||||
[ -f ${CR_SRC_DIR}/third_party/ffmpeg/ffmpeg_hevc_ac3.patch ] || patchAC3;
|
[ -f ${CR_SRC_DIR}/third_party/ffmpeg/ffmpeg_hevc_ac3.patch ] || patchAC3;
|
||||||
printf "\n"
|
printf "\n"
|
||||||
}
|
}
|
||||||
|
@ -225,7 +226,7 @@ copyAVX2 () {
|
||||||
printf "${YEL}Copying AVX2 build files...${c0}\n" &&
|
printf "${YEL}Copying AVX2 build files...${c0}\n" &&
|
||||||
cp -r -v other/AVX2/third_party/* ${CR_SRC_DIR}/third_party/ &&
|
cp -r -v other/AVX2/third_party/* ${CR_SRC_DIR}/third_party/ &&
|
||||||
cp -v other/AVX2/thor_ver ${CR_SRC_DIR}/out/thorium/ &&
|
cp -v other/AVX2/thor_ver ${CR_SRC_DIR}/out/thorium/ &&
|
||||||
cp -v infra/thor_ver_linux/wrapper-avx2 ${CR_SRC_DIR}/chrome/installer/linux/common/wrapper &&
|
cp -v other/thor_ver_linux/wrapper-avx2 ${CR_SRC_DIR}/chrome/installer/linux/common/wrapper &&
|
||||||
[ -f ${CR_SRC_DIR}/third_party/ffmpeg/ffmpeg_hevc_ac3.patch ] || patchAC3;
|
[ -f ${CR_SRC_DIR}/third_party/ffmpeg/ffmpeg_hevc_ac3.patch ] || patchAC3;
|
||||||
printf "\n"
|
printf "\n"
|
||||||
}
|
}
|
||||||
|
@ -238,7 +239,7 @@ copySSE4 () {
|
||||||
printf "\n" &&
|
printf "\n" &&
|
||||||
printf "${YEL}Copying SSE4.1 build files...${c0}\n" &&
|
printf "${YEL}Copying SSE4.1 build files...${c0}\n" &&
|
||||||
cp -v other/SSE4.1/thor_ver ${CR_SRC_DIR}/out/thorium/ &&
|
cp -v other/SSE4.1/thor_ver ${CR_SRC_DIR}/out/thorium/ &&
|
||||||
cp -v infra/thor_ver_linux/wrapper-sse4 ${CR_SRC_DIR}/chrome/installer/linux/common/wrapper &&
|
cp -v other/thor_ver_linux/wrapper-sse4 ${CR_SRC_DIR}/chrome/installer/linux/common/wrapper &&
|
||||||
[ -f ${CR_SRC_DIR}/third_party/ffmpeg/ffmpeg_hevc_ac3.patch ] || patchAC3;
|
[ -f ${CR_SRC_DIR}/third_party/ffmpeg/ffmpeg_hevc_ac3.patch ] || patchAC3;
|
||||||
printf "\n"
|
printf "\n"
|
||||||
}
|
}
|
||||||
|
@ -251,7 +252,7 @@ copySSE3 () {
|
||||||
printf "\n" &&
|
printf "\n" &&
|
||||||
printf "${YEL}Copying SSE3 build files...${c0}\n" &&
|
printf "${YEL}Copying SSE3 build files...${c0}\n" &&
|
||||||
cp -v other/SSE3/thor_ver ${CR_SRC_DIR}/out/thorium/ &&
|
cp -v other/SSE3/thor_ver ${CR_SRC_DIR}/out/thorium/ &&
|
||||||
cp -v infra/thor_ver_linux/wrapper-sse3 ${CR_SRC_DIR}/chrome/installer/linux/common/wrapper &&
|
cp -v other/thor_ver_linux/wrapper-sse3 ${CR_SRC_DIR}/chrome/installer/linux/common/wrapper &&
|
||||||
cd ${CR_SRC_DIR} &&
|
cd ${CR_SRC_DIR} &&
|
||||||
python3 tools/update_pgo_profiles.py --target=win32 update --gs-url-base=chromium-optimization-profiles/pgo_profiles &&
|
python3 tools/update_pgo_profiles.py --target=win32 update --gs-url-base=chromium-optimization-profiles/pgo_profiles &&
|
||||||
cd ~/thorium &&
|
cd ~/thorium &&
|
||||||
|
@ -267,7 +268,7 @@ copySSE2 () {
|
||||||
printf "\n" &&
|
printf "\n" &&
|
||||||
printf "${YEL}Copying SSE2 (32-bit) build files...${c0}\n" &&
|
printf "${YEL}Copying SSE2 (32-bit) build files...${c0}\n" &&
|
||||||
cp -v other/SSE2/thor_ver ${CR_SRC_DIR}/out/thorium/ &&
|
cp -v other/SSE2/thor_ver ${CR_SRC_DIR}/out/thorium/ &&
|
||||||
cp -v infra/thor_ver_linux/wrapper-sse2 ${CR_SRC_DIR}/chrome/installer/linux/common/wrapper &&
|
cp -v other/thor_ver_linux/wrapper-sse2 ${CR_SRC_DIR}/chrome/installer/linux/common/wrapper &&
|
||||||
cd ${CR_SRC_DIR} &&
|
cd ${CR_SRC_DIR} &&
|
||||||
python3 tools/update_pgo_profiles.py --target=win32 update --gs-url-base=chromium-optimization-profiles/pgo_profiles &&
|
python3 tools/update_pgo_profiles.py --target=win32 update --gs-url-base=chromium-optimization-profiles/pgo_profiles &&
|
||||||
cd ~/thorium &&
|
cd ~/thorium &&
|
||||||
|
|
|
@ -2331,6 +2331,9 @@ config("no_chromium_code") {
|
||||||
# third-party libraries.
|
# third-party libraries.
|
||||||
"-Wno-c++11-narrowing",
|
"-Wno-c++11-narrowing",
|
||||||
]
|
]
|
||||||
|
if (is_full_optimization_build) {
|
||||||
|
cflags += [ "-Xclang", "-O3" ]
|
||||||
|
}
|
||||||
if (!is_nacl) {
|
if (!is_nacl) {
|
||||||
cflags += [
|
cflags += [
|
||||||
# Disabled for similar reasons as -Wunused-variable.
|
# Disabled for similar reasons as -Wunused-variable.
|
||||||
|
|
|
@ -104,11 +104,6 @@ BASE_FEATURE(kAccessCodeCastUI,
|
||||||
base::FEATURE_ENABLED_BY_DEFAULT);
|
base::FEATURE_ENABLED_BY_DEFAULT);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Enables showing the EV certificate details in the Page Info bubble.
|
|
||||||
BASE_FEATURE(kEvDetailsInPageInfo,
|
|
||||||
"EvDetailsInPageInfo",
|
|
||||||
base::FEATURE_ENABLED_BY_DEFAULT);
|
|
||||||
|
|
||||||
#if BUILDFLAG(IS_WIN) || BUILDFLAG(IS_MAC) || BUILDFLAG(IS_LINUX)
|
#if BUILDFLAG(IS_WIN) || BUILDFLAG(IS_MAC) || BUILDFLAG(IS_LINUX)
|
||||||
// Enables the feature to remove the last confirmation dialog when relaunching
|
// Enables the feature to remove the last confirmation dialog when relaunching
|
||||||
// to update Chrome.
|
// to update Chrome.
|
||||||
|
@ -118,11 +113,6 @@ BASE_FEATURE(kFewerUpdateConfirmations,
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if !BUILDFLAG(IS_ANDROID) && BUILDFLAG(GOOGLE_CHROME_BRANDING)
|
#if !BUILDFLAG(IS_ANDROID) && BUILDFLAG(GOOGLE_CHROME_BRANDING)
|
||||||
// Enables showing the "Get the most out of Chrome" section in settings.
|
|
||||||
BASE_FEATURE(kGetTheMostOutOfChrome,
|
|
||||||
"GetTheMostOutOfChrome",
|
|
||||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
|
||||||
|
|
||||||
// This feature controls whether the user can be shown the Chrome for iOS promo
|
// This feature controls whether the user can be shown the Chrome for iOS promo
|
||||||
// when saving or updating passwords.
|
// when saving or updating passwords.
|
||||||
BASE_FEATURE(kIOSPromoRefreshedPasswordBubble,
|
BASE_FEATURE(kIOSPromoRefreshedPasswordBubble,
|
||||||
|
@ -187,6 +177,7 @@ BASE_FEATURE(kLightweightExtensionOverrideConfirmations,
|
||||||
BASE_FEATURE(kPreloadTopChromeWebUI,
|
BASE_FEATURE(kPreloadTopChromeWebUI,
|
||||||
"PreloadTopChromeWebUI",
|
"PreloadTopChromeWebUI",
|
||||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||||
|
|
||||||
const char kPreloadTopChromeWebUIModeName[] = "preload-mode";
|
const char kPreloadTopChromeWebUIModeName[] = "preload-mode";
|
||||||
const char kPreloadTopChromeWebUIModePreloadOnWarmupName[] =
|
const char kPreloadTopChromeWebUIModePreloadOnWarmupName[] =
|
||||||
"preload-on-warmup";
|
"preload-on-warmup";
|
||||||
|
@ -203,16 +194,26 @@ const base::FeatureParam<PreloadTopChromeWebUIMode> kPreloadTopChromeWebUIMode{
|
||||||
&kPreloadTopChromeWebUI, kPreloadTopChromeWebUIModeName,
|
&kPreloadTopChromeWebUI, kPreloadTopChromeWebUIModeName,
|
||||||
PreloadTopChromeWebUIMode::kPreloadOnMakeContents,
|
PreloadTopChromeWebUIMode::kPreloadOnMakeContents,
|
||||||
&kPreloadTopChromeWebUIModeOptions};
|
&kPreloadTopChromeWebUIModeOptions};
|
||||||
|
|
||||||
const char kPreloadTopChromeWebUISmartPreloadName[] = "smart-preload";
|
const char kPreloadTopChromeWebUISmartPreloadName[] = "smart-preload";
|
||||||
const base::FeatureParam<bool> kPreloadTopChromeWebUISmartPreload{
|
const base::FeatureParam<bool> kPreloadTopChromeWebUISmartPreload{
|
||||||
&kPreloadTopChromeWebUI, kPreloadTopChromeWebUISmartPreloadName, false};
|
&kPreloadTopChromeWebUI, kPreloadTopChromeWebUISmartPreloadName, false};
|
||||||
|
|
||||||
|
const char kPreloadTopChromeWebUIDelayPreloadName[] = "delay-preload";
|
||||||
|
const base::FeatureParam<bool> kPreloadTopChromeWebUIDelayPreload{
|
||||||
|
&kPreloadTopChromeWebUI, kPreloadTopChromeWebUIDelayPreloadName, false};
|
||||||
|
|
||||||
|
const char kPreloadTopChromeWebUIExcludeOriginsName[] = "exclude-origins";
|
||||||
|
const base::FeatureParam<std::string> kPreloadTopChromeWebUIExcludeOrigins{
|
||||||
|
&kPreloadTopChromeWebUI, kPreloadTopChromeWebUIExcludeOriginsName, ""};
|
||||||
|
|
||||||
// Enables exiting browser fullscreen (users putting the browser itself into the
|
// Enables exiting browser fullscreen (users putting the browser itself into the
|
||||||
// fullscreen mode via the browser UI or shortcuts) with press-and-hold Esc.
|
// fullscreen mode via the browser UI or shortcuts) with press-and-hold Esc.
|
||||||
#if !BUILDFLAG(IS_ANDROID)
|
#if !BUILDFLAG(IS_ANDROID)
|
||||||
BASE_FEATURE(kPressAndHoldEscToExitBrowserFullscreen,
|
BASE_FEATURE(kPressAndHoldEscToExitBrowserFullscreen,
|
||||||
"PressAndHoldEscToExitBrowserFullscreen",
|
"PressAndHoldEscToExitBrowserFullscreen",
|
||||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
base::FEATURE_ENABLED_BY_DEFAULT
|
||||||
|
);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Enable responsive toolbar. Toolbar buttons overflow to a chevron button when
|
// Enable responsive toolbar. Toolbar buttons overflow to a chevron button when
|
||||||
|
@ -266,6 +267,10 @@ BASE_FEATURE(kSidePanelResizing,
|
||||||
"SidePanelResizing",
|
"SidePanelResizing",
|
||||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||||
|
|
||||||
|
BASE_FEATURE(kTabDuplicateMetrics,
|
||||||
|
"TabDuplicateMetrics",
|
||||||
|
base::FEATURE_ENABLED_BY_DEFAULT);
|
||||||
|
|
||||||
// Enables buttons when scrolling the tabstrip https://crbug.com/951078
|
// Enables buttons when scrolling the tabstrip https://crbug.com/951078
|
||||||
BASE_FEATURE(kTabScrollingButtonPosition,
|
BASE_FEATURE(kTabScrollingButtonPosition,
|
||||||
"TabScrollingButtonPosition",
|
"TabScrollingButtonPosition",
|
||||||
|
@ -301,12 +306,20 @@ const char kTabHoverCardAdditionalMaxWidthDelay[] =
|
||||||
|
|
||||||
BASE_FEATURE(kTabOrganization,
|
BASE_FEATURE(kTabOrganization,
|
||||||
"TabOrganization",
|
"TabOrganization",
|
||||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
base::FEATURE_ENABLED_BY_DEFAULT);
|
||||||
|
|
||||||
bool IsTabOrganization() {
|
bool IsTabOrganization() {
|
||||||
return base::FeatureList::IsEnabled(features::kTabOrganization);
|
return base::FeatureList::IsEnabled(features::kTabOrganization);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
BASE_FEATURE(kTabstripDeclutter,
|
||||||
|
"TabstripDeclutter",
|
||||||
|
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||||
|
|
||||||
|
bool IsTabstripDeclutterEnabled() {
|
||||||
|
return base::FeatureList::IsEnabled(features::kTabstripDeclutter);
|
||||||
|
}
|
||||||
|
|
||||||
BASE_FEATURE(kMultiTabOrganization,
|
BASE_FEATURE(kMultiTabOrganization,
|
||||||
"MultiTabOrganization",
|
"MultiTabOrganization",
|
||||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||||
|
@ -323,6 +336,14 @@ BASE_FEATURE(kTabReorganizationDivider,
|
||||||
"TabReorganizationDivider",
|
"TabReorganizationDivider",
|
||||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||||
|
|
||||||
|
BASE_FEATURE(kTabOrganizationModelStrategy,
|
||||||
|
"TabOrganizationModelStrategy",
|
||||||
|
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||||
|
|
||||||
|
BASE_FEATURE(kTabOrganizationEnableNudgeForEnterprise,
|
||||||
|
"TabOrganizationEnableNudgeForEnterprise",
|
||||||
|
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||||
|
|
||||||
const base::FeatureParam<base::TimeDelta> kTabOrganizationTriggerPeriod{
|
const base::FeatureParam<base::TimeDelta> kTabOrganizationTriggerPeriod{
|
||||||
&kTabOrganization, "trigger_period", base::Hours(6)};
|
&kTabOrganization, "trigger_period", base::Hours(6)};
|
||||||
|
|
||||||
|
@ -338,6 +359,7 @@ const base::FeatureParam<double> kTabOrganizationTriggerSensitivityThreshold{
|
||||||
const base::FeatureParam<bool> KTabOrganizationTriggerDemoMode{
|
const base::FeatureParam<bool> KTabOrganizationTriggerDemoMode{
|
||||||
&kTabOrganization, "trigger_demo_mode", false};
|
&kTabOrganization, "trigger_demo_mode", false};
|
||||||
|
|
||||||
|
// Alex313031: Investigate
|
||||||
BASE_FEATURE(kTabSearchChevronIcon,
|
BASE_FEATURE(kTabSearchChevronIcon,
|
||||||
"TabSearchChevronIcon",
|
"TabSearchChevronIcon",
|
||||||
base::FEATURE_ENABLED_BY_DEFAULT);
|
base::FEATURE_ENABLED_BY_DEFAULT);
|
||||||
|
@ -347,8 +369,6 @@ BASE_FEATURE(kTabSearchFeedback,
|
||||||
"TabSearchFeedback",
|
"TabSearchFeedback",
|
||||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Controls feature parameters for Tab Search's `Recently Closed` entries.
|
// Controls feature parameters for Tab Search's `Recently Closed` entries.
|
||||||
BASE_FEATURE(kTabSearchRecentlyClosed,
|
BASE_FEATURE(kTabSearchRecentlyClosed,
|
||||||
"TabSearchRecentlyClosed",
|
"TabSearchRecentlyClosed",
|
||||||
|
@ -401,19 +421,19 @@ BASE_FEATURE(kEnterpriseProfileBadging,
|
||||||
"EnterpriseProfileBadging",
|
"EnterpriseProfileBadging",
|
||||||
base::FEATURE_ENABLED_BY_DEFAULT);
|
base::FEATURE_ENABLED_BY_DEFAULT);
|
||||||
|
|
||||||
// Enables the management button on the toolbar.
|
// Enables the management button on the toolbar for all managed browsers.
|
||||||
BASE_FEATURE(kManagementToolbarButton,
|
BASE_FEATURE(kManagementToolbarButton,
|
||||||
"ManagementToolbarButton",
|
"ManagementToolbarButton",
|
||||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||||
|
|
||||||
BASE_FEATURE(kEnterpriseUpdatedProfileCreationScreen,
|
// Enables the management button on the toolbar by default for browser managed
|
||||||
"EnterpriseUpdatedProfileCreationScreen",
|
// by trusted sources.
|
||||||
|
BASE_FEATURE(kManagementToolbarButtonForTrustedManagementSources,
|
||||||
|
"ManagementToolbarButtonForTrustedManagementSources",
|
||||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||||
|
|
||||||
// This enables enables persistence of a WebContents in a 1-to-1 association
|
BASE_FEATURE(kEnterpriseUpdatedProfileCreationScreen,
|
||||||
// with the current Profile for WebUI bubbles. See https://crbug.com/1177048.
|
"EnterpriseUpdatedProfileCreationScreen",
|
||||||
BASE_FEATURE(kWebUIBubblePerProfilePersistence,
|
|
||||||
"WebUIBubblePerProfilePersistence",
|
|
||||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||||
|
|
||||||
// Enables a web-based tab strip. See https://crbug.com/989131. Note this
|
// Enables a web-based tab strip. See https://crbug.com/989131. Note this
|
||||||
|
@ -423,7 +443,8 @@ BASE_FEATURE(kWebUITabStrip,
|
||||||
#if BUILDFLAG(IS_CHROMEOS)
|
#if BUILDFLAG(IS_CHROMEOS)
|
||||||
base::FEATURE_ENABLED_BY_DEFAULT
|
base::FEATURE_ENABLED_BY_DEFAULT
|
||||||
#else
|
#else
|
||||||
base::FEATURE_ENABLED_BY_DEFAULT
|
// Test on and off
|
||||||
|
base::FEATURE_DISABLED_BY_DEFAULT
|
||||||
#endif
|
#endif
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -444,10 +465,6 @@ BASE_FEATURE(kViewsFirstRunDialog,
|
||||||
"ViewsFirstRunDialog",
|
"ViewsFirstRunDialog",
|
||||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||||
|
|
||||||
BASE_FEATURE(kViewsTaskManager,
|
|
||||||
"ViewsTaskManager",
|
|
||||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
|
||||||
|
|
||||||
BASE_FEATURE(kViewsJSAppModalDialog,
|
BASE_FEATURE(kViewsJSAppModalDialog,
|
||||||
"ViewsJSAppModalDialog",
|
"ViewsJSAppModalDialog",
|
||||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||||
|
@ -465,4 +482,10 @@ BASE_FEATURE(kUsePortalAccentColor,
|
||||||
base::FEATURE_ENABLED_BY_DEFAULT);
|
base::FEATURE_ENABLED_BY_DEFAULT);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
BASE_FEATURE(kCompactMode, "CompactMode", base::FEATURE_DISABLED_BY_DEFAULT);
|
||||||
|
|
||||||
|
BASE_FEATURE(kPageSpecificDataDialogRelatedInstalledAppsSection,
|
||||||
|
"PageSpecificDataDialogRelatedInstalledAppsSection",
|
||||||
|
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||||
|
|
||||||
} // namespace features
|
} // namespace features
|
||||||
|
|
|
@ -41,9 +41,11 @@ ReloadButton::ReloadButton(CommandUpdater* command_updater)
|
||||||
CreateMenuModel(),
|
CreateMenuModel(),
|
||||||
nullptr),
|
nullptr),
|
||||||
command_updater_(command_updater),
|
command_updater_(command_updater),
|
||||||
reload_icon_(base::CommandLine::ForCurrentProcess()->HasSwitch("disable-thorium-icons")
|
static const bool disable_thorium_icons =
|
||||||
? vector_icons::kReloadChromeRefreshIcon
|
base::CommandLine::ForCurrentProcess()->HasSwitch("disable-thorium-icons");
|
||||||
: vector_icons::kReloadChromeRefreshThoriumIcon),
|
reload_icon_(disable_thorium_icons
|
||||||
|
? vector_icons::kReloadChromeRefreshIcon
|
||||||
|
: vector_icons::kReloadChromeRefreshThoriumIcon),
|
||||||
reload_touch_icon_(kReloadTouchIcon),
|
reload_touch_icon_(kReloadTouchIcon),
|
||||||
stop_icon_(kNavigateStopChromeRefreshIcon),
|
stop_icon_(kNavigateStopChromeRefreshIcon),
|
||||||
stop_touch_icon_(kNavigateStopTouchIcon),
|
stop_touch_icon_(kNavigateStopTouchIcon),
|
||||||
|
|
|
@ -71,6 +71,10 @@ const InstallConstants kInstallModes[] = {
|
||||||
.app_icon_resource_index =
|
.app_icon_resource_index =
|
||||||
icon_resources::kApplicationIndex, // App icon resource index.
|
icon_resources::kApplicationIndex, // App icon resource index.
|
||||||
.app_icon_resource_id = IDR_MAINFRAME, // App icon resource id.
|
.app_icon_resource_id = IDR_MAINFRAME, // App icon resource id.
|
||||||
|
.html_doc_icon_resource_index =
|
||||||
|
icon_resources::kHtmlDocIndex, // HTML doc icon resource index.
|
||||||
|
.pdf_doc_icon_resource_index =
|
||||||
|
icon_resources::kPDFDocIndex, // PDF doc icon resource index.
|
||||||
.sandbox_sid_prefix =
|
.sandbox_sid_prefix =
|
||||||
L"S-1-15-2-3251537155-1984446955-2931258699-841473695-1938553385-"
|
L"S-1-15-2-3251537155-1984446955-2931258699-841473695-1938553385-"
|
||||||
L"924012148-", // App container sid prefix for sandbox.
|
L"924012148-", // App container sid prefix for sandbox.
|
||||||
|
|
|
@ -13,16 +13,17 @@
|
||||||
|
|
||||||
namespace dom_distiller {
|
namespace dom_distiller {
|
||||||
|
|
||||||
BASE_FEATURE(kReaderMode, "ReaderMode", base::FEATURE_ENABLED_BY_DEFAULT);
|
static const bool kReaderModeDesktop =
|
||||||
|
base::CommandLine::ForCurrentProcess()->HasSwitch("reader-mode");
|
||||||
|
|
||||||
bool IsDomDistillerEnabled() {
|
bool IsDomDistillerEnabled() {
|
||||||
return true;
|
return base::CommandLine::ForCurrentProcess()->HasSwitch(
|
||||||
|
switches::kEnableDomDistiller) || kReaderModeDesktop;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ShouldStartDistillabilityService() {
|
bool ShouldStartDistillabilityService() {
|
||||||
return base::CommandLine::ForCurrentProcess()->HasSwitch(
|
return base::CommandLine::ForCurrentProcess()->HasSwitch(
|
||||||
switches::kEnableDistillabilityService) ||
|
switches::kEnableDistillabilityService) || kReaderModeDesktop;
|
||||||
base::FeatureList::IsEnabled(kReaderMode);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace dom_distiller
|
} // namespace dom_distiller
|
||||||
|
|
|
@ -2,11 +2,6 @@
|
||||||
// Use of this source code is governed by a BSD-style license that can be
|
// Use of this source code is governed by a BSD-style license that can be
|
||||||
// found in the LICENSE file.
|
// found in the LICENSE file.
|
||||||
|
|
||||||
#ifdef UNSAFE_BUFFERS_BUILD
|
|
||||||
// TODO(crbug.com/40284755): Remove this and spanify to fix the errors.
|
|
||||||
#pragma allow_unsafe_buffers
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "net/cert/x509_util.h"
|
#include "net/cert/x509_util.h"
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
@ -188,7 +183,7 @@ bssl::ParsedCertificateList ParseAllValidCerts(
|
||||||
std::shared_ptr<const bssl::ParsedCertificate> cert =
|
std::shared_ptr<const bssl::ParsedCertificate> cert =
|
||||||
bssl::ParsedCertificate::Create(
|
bssl::ParsedCertificate::Create(
|
||||||
bssl::UpRef(x509_cert->cert_buffer()),
|
bssl::UpRef(x509_cert->cert_buffer()),
|
||||||
net::x509_util::DefaultParseCertificateOptions(), NULL);
|
net::x509_util::DefaultParseCertificateOptions(), nullptr);
|
||||||
if (cert) {
|
if (cert) {
|
||||||
parsed_certs.push_back(std::move(cert));
|
parsed_certs.push_back(std::move(cert));
|
||||||
}
|
}
|
||||||
|
@ -272,15 +267,16 @@ bool GetTLSServerEndPointChannelBinding(const X509Certificate& certificate,
|
||||||
if (!digest_evp_md)
|
if (!digest_evp_md)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
uint8_t digest[EVP_MAX_MD_SIZE];
|
std::array<uint8_t, EVP_MAX_MD_SIZE> digest;
|
||||||
unsigned int out_size;
|
unsigned int out_size;
|
||||||
if (!EVP_Digest(der_encoded_certificate.data(),
|
if (!EVP_Digest(der_encoded_certificate.data(),
|
||||||
der_encoded_certificate.size(), digest, &out_size,
|
der_encoded_certificate.size(), digest.data(), &out_size,
|
||||||
digest_evp_md, nullptr))
|
digest_evp_md, nullptr)) {
|
||||||
return false;
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
token->assign(kChannelBindingPrefix);
|
token->assign(kChannelBindingPrefix);
|
||||||
token->append(digest, digest + out_size);
|
token->append(base::as_string_view(digest).substr(0, out_size));
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -440,9 +436,7 @@ bssl::UniquePtr<CRYPTO_BUFFER> CreateCryptoBuffer(
|
||||||
}
|
}
|
||||||
|
|
||||||
bssl::UniquePtr<CRYPTO_BUFFER> CreateCryptoBuffer(std::string_view data) {
|
bssl::UniquePtr<CRYPTO_BUFFER> CreateCryptoBuffer(std::string_view data) {
|
||||||
return bssl::UniquePtr<CRYPTO_BUFFER>(
|
return CreateCryptoBuffer(base::as_byte_span(data));
|
||||||
CRYPTO_BUFFER_new(reinterpret_cast<const uint8_t*>(data.data()),
|
|
||||||
data.size(), GetBufferPool()));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bssl::UniquePtr<CRYPTO_BUFFER> CreateCryptoBufferFromStaticDataUnsafe(
|
bssl::UniquePtr<CRYPTO_BUFFER> CreateCryptoBufferFromStaticDataUnsafe(
|
||||||
|
@ -456,19 +450,18 @@ bool CryptoBufferEqual(const CRYPTO_BUFFER* a, const CRYPTO_BUFFER* b) {
|
||||||
DCHECK(a && b);
|
DCHECK(a && b);
|
||||||
if (a == b)
|
if (a == b)
|
||||||
return true;
|
return true;
|
||||||
return CRYPTO_BUFFER_len(a) == CRYPTO_BUFFER_len(b) &&
|
return CryptoBufferAsSpan(a) == CryptoBufferAsSpan(b);
|
||||||
memcmp(CRYPTO_BUFFER_data(a), CRYPTO_BUFFER_data(b),
|
|
||||||
CRYPTO_BUFFER_len(a)) == 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string_view CryptoBufferAsStringPiece(const CRYPTO_BUFFER* buffer) {
|
std::string_view CryptoBufferAsStringPiece(const CRYPTO_BUFFER* buffer) {
|
||||||
return std::string_view(
|
return base::as_string_view(CryptoBufferAsSpan(buffer));
|
||||||
reinterpret_cast<const char*>(CRYPTO_BUFFER_data(buffer)),
|
|
||||||
CRYPTO_BUFFER_len(buffer));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
base::span<const uint8_t> CryptoBufferAsSpan(const CRYPTO_BUFFER* buffer) {
|
base::span<const uint8_t> CryptoBufferAsSpan(const CRYPTO_BUFFER* buffer) {
|
||||||
return base::make_span(CRYPTO_BUFFER_data(buffer), CRYPTO_BUFFER_len(buffer));
|
// SAFETY: CRYPTO_BUFFER_data(buffer) returns a pointer to data that is
|
||||||
|
// CRYPTO_BUFFER_len(buffer) bytes in length.
|
||||||
|
return UNSAFE_BUFFERS(
|
||||||
|
base::make_span(CRYPTO_BUFFER_data(buffer), CRYPTO_BUFFER_len(buffer)));
|
||||||
}
|
}
|
||||||
|
|
||||||
scoped_refptr<X509Certificate> CreateX509CertificateFromBuffers(
|
scoped_refptr<X509Certificate> CreateX509CertificateFromBuffers(
|
||||||
|
@ -570,8 +563,7 @@ bool HasRsaPkcs1Sha1Signature(const CRYPTO_BUFFER* cert_buffer) {
|
||||||
bssl::der::Input tbs_certificate_tlv;
|
bssl::der::Input tbs_certificate_tlv;
|
||||||
bssl::der::Input signature_algorithm_tlv;
|
bssl::der::Input signature_algorithm_tlv;
|
||||||
bssl::der::BitString signature_value;
|
bssl::der::BitString signature_value;
|
||||||
if (!bssl::ParseCertificate(bssl::der::Input(CRYPTO_BUFFER_data(cert_buffer),
|
if (!bssl::ParseCertificate(bssl::der::Input(CryptoBufferAsSpan(cert_buffer)),
|
||||||
CRYPTO_BUFFER_len(cert_buffer)),
|
|
||||||
&tbs_certificate_tlv, &signature_algorithm_tlv,
|
&tbs_certificate_tlv, &signature_algorithm_tlv,
|
||||||
&signature_value, /*out_errors=*/nullptr)) {
|
&signature_value, /*out_errors=*/nullptr)) {
|
||||||
return false;
|
return false;
|
||||||
|
|
|
@ -303,7 +303,7 @@ if (is_linux || is_chromeos) {
|
||||||
|
|
||||||
# These files have a suspicious comparison.
|
# These files have a suspicious comparison.
|
||||||
# TODO fix this and re-enable this warning.
|
# TODO fix this and re-enable this warning.
|
||||||
"-Wno-sign-compare",
|
# "-Wno-sign-compare",
|
||||||
"-O3",
|
"-O3",
|
||||||
"-fPIE",
|
"-fPIE",
|
||||||
]
|
]
|
||||||
|
|
925
src/third_party/blink/common/features.cc
vendored
925
src/third_party/blink/common/features.cc
vendored
File diff suppressed because it is too large
Load diff
Loading…
Reference in a new issue