M128 stage 5

This commit is contained in:
Alexander Frick 2024-10-03 12:02:49 -05:00
parent 20b6c37ea4
commit bb9267f41d
15 changed files with 2595 additions and 2558 deletions

View file

@ -152,8 +152,8 @@
<DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/128.0.6613.181:components/offline_pages/core/offline_page_model.cc;bpv=1" ADD_DATE="1661054752" ICON="">offline_page_model.cc - Chromium Code Search</A> <DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/128.0.6613.181:components/offline_pages/core/offline_page_model.cc;bpv=1" ADD_DATE="1661054752" ICON="">offline_page_model.cc - Chromium Code Search</A>
<DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/128.0.6613.181:content/common/url_schemes.cc;bpv=1" ADD_DATE="1661054752" ICON="">url_schemes.cc - Chromium Code Search</A> <DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/128.0.6613.181:content/common/url_schemes.cc;bpv=1" ADD_DATE="1661054752" ICON="">url_schemes.cc - Chromium Code Search</A>
<DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/128.0.6613.181:content/public/common/url_utils.cc;bpv=1" ADD_DATE="1661054752" ICON="">url_utils.cc - Chromium Code Search</A> <DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/128.0.6613.181:content/public/common/url_utils.cc;bpv=1" ADD_DATE="1661054752" ICON="">url_utils.cc - Chromium Code Search</A>
<DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/128.0.6613.181:ui/views/examples/examples_window.cc;bpv=1" ADD_DATE="1661054752" ICON="">examples_window.cc - Chromium Code Search</A>
<DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/128.0.6613.181:ui/views/examples/BUILD.gn;bpv=1" ADD_DATE="1661054752" ICON="">BUILD.gn - Chromium Code Search</A> <DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/128.0.6613.181:ui/views/examples/BUILD.gn;bpv=1" ADD_DATE="1661054752" ICON="">BUILD.gn - Chromium Code Search</A>
<DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/128.0.6613.181:ui/views/examples/examples_window.cc;bpv=1" ADD_DATE="1661054752" ICON="">examples_window.cc - Chromium Code Search</A>
<DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/128.0.6613.181:components/BUILD.gn;bpv=1" ADD_DATE="1661054752" ICON="">BUILD.gn - Chromium Code Search</A> <DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/128.0.6613.181:components/BUILD.gn;bpv=1" ADD_DATE="1661054752" ICON="">BUILD.gn - Chromium Code Search</A>
<DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/128.0.6613.181:tools/clang/scripts/build.py;bpv=1" ADD_DATE="1661054752" ICON="">build.py - Chromium Code Search</A> <DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/128.0.6613.181:tools/clang/scripts/build.py;bpv=1" ADD_DATE="1661054752" ICON="">build.py - Chromium Code Search</A>
<DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/128.0.6613.181:third_party/opus/src/configure.ac;bpv=1" ADD_DATE="1665798387" ICON="">configure.ac - Chromium Code Search</A> <DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/128.0.6613.181:third_party/opus/src/configure.ac;bpv=1" ADD_DATE="1665798387" ICON="">configure.ac - Chromium Code Search</A>

File diff suppressed because it is too large Load diff

File diff suppressed because it is too large Load diff

View file

@ -5,6 +5,7 @@
#include "chrome/browser/ui/browser_commands.h" #include "chrome/browser/ui/browser_commands.h"
#include <memory> #include <memory>
#include <optional>
#include <utility> #include <utility>
#include <vector> #include <vector>
@ -209,11 +210,6 @@
#include "components/rlz/rlz_tracker.h" // nogncheck #include "components/rlz/rlz_tracker.h" // nogncheck
#endif #endif
#if BUILDFLAG(ENABLE_SCREEN_AI_SERVICE)
#include "chrome/browser/accessibility/ax_screen_ai_annotator.h"
#include "chrome/browser/accessibility/ax_screen_ai_annotator_factory.h"
#endif
#if BUILDFLAG(IS_CHROMEOS_LACROS) #if BUILDFLAG(IS_CHROMEOS_LACROS)
#include "chromeos/crosapi/mojom/task_manager.mojom.h" #include "chromeos/crosapi/mojom/task_manager.mojom.h"
#include "chromeos/lacros/lacros_service.h" #include "chromeos/lacros/lacros_service.h"
@ -609,6 +605,12 @@ Browser* OpenEmptyWindow(Profile* profile,
Browser::CreationStatus::kOk) { Browser::CreationStatus::kOk) {
return nullptr; return nullptr;
} }
// Don't create a new window when the profile is shutting down.
if (profile->ShutdownStarted()) {
return nullptr;
}
Browser::CreateParams params = Browser::CreateParams params =
Browser::CreateParams(Browser::TYPE_NORMAL, profile, true); Browser::CreateParams(Browser::TYPE_NORMAL, profile, true);
params.should_trigger_session_restore = should_trigger_session_restore; params.should_trigger_session_restore = should_trigger_session_restore;
@ -1108,35 +1110,29 @@ void MoveTabsToNewWindow(Browser* browser,
Browser::Create(Browser::CreateParams(browser->profile(), true)); Browser::Create(Browser::CreateParams(browser->profile(), true));
} }
std::optional<base::Uuid> paused_saved_guid = std::nullopt;
tab_groups::SavedTabGroupKeyedService* const service =
tab_groups::SavedTabGroupServiceFactory::GetForProfile(
browser->profile());
tab_groups::TabGroupVisualData visual_data;
if (group.has_value()) { if (group.has_value()) {
tab_groups::SavedTabGroupKeyedService* const service =
tab_groups::SavedTabGroupServiceFactory::GetForProfile(
browser->profile());
if (service && service->model()->Contains(group.value())) {
// If the group we are looking to move is saved:
// 1) Stop listening to changes on it
// 2) Close the group in the browser
// 3) Open the group in a new browser and link it to the saved guid.
const base::Uuid& saved_guid =
service->model()->Get(group.value())->saved_guid();
service->DisconnectLocalTabGroup(group.value());
browser->tab_strip_model()->CloseAllTabsInGroup(group.value());
service->OpenSavedTabGroupInBrowser(new_browser, saved_guid);
return;
}
const tab_groups::TabGroupVisualData* old_visual_data = const tab_groups::TabGroupVisualData* old_visual_data =
browser->tab_strip_model() browser->tab_strip_model()
->group_model() ->group_model()
->GetTabGroup(group.value()) ->GetTabGroup(group.value())
->visual_data(); ->visual_data();
tab_groups::TabGroupVisualData new_visual_data(old_visual_data->title(),
old_visual_data->color(),
false /* is_collapsed */);
new_browser->tab_strip_model()->group_model()->AddTabGroup(group.value(), visual_data = tab_groups::TabGroupVisualData(old_visual_data->title(),
new_visual_data); old_visual_data->color(),
false /* is_collapsed */);
if (service && service->model()->Contains(group.value())) {
paused_saved_guid = service->model()->Get(group.value())->saved_guid();
service->PauseTrackingLocalTabGroup(group.value());
}
} }
int indices_size = tab_indices.size(); int indices_size = tab_indices.size();
@ -1147,8 +1143,6 @@ void MoveTabsToNewWindow(Browser* browser,
bool pinned = browser->tab_strip_model()->IsTabPinned(adjusted_index); bool pinned = browser->tab_strip_model()->IsTabPinned(adjusted_index);
std::unique_ptr<tabs::TabModel> tab_model = std::unique_ptr<tabs::TabModel> tab_model =
browser->tab_strip_model()->DetachTabAtForInsertion(adjusted_index); browser->tab_strip_model()->DetachTabAtForInsertion(adjusted_index);
std::unique_ptr<content::WebContents> contents_move =
tabs::TabModel::DestroyAndTakeWebContents(std::move(tab_model));
int add_types = pinned ? AddTabTypes::ADD_PINNED : 0; int add_types = pinned ? AddTabTypes::ADD_PINNED : 0;
// The last tab made active takes precedence, so activate the last active // The last tab made active takes precedence, so activate the last active
@ -1158,10 +1152,24 @@ void MoveTabsToNewWindow(Browser* browser,
add_types = add_types | AddTabTypes::ADD_ACTIVE; add_types = add_types | AddTabTypes::ADD_ACTIVE;
} }
new_browser->tab_strip_model()->AddWebContents(std::move(contents_move), -1, new_browser->tab_strip_model()->AddTab(std::move(tab_model), -1,
ui::PAGE_TRANSITION_TYPED, ui::PAGE_TRANSITION_TYPED, add_types,
add_types, group); std::nullopt);
} }
// Add all the tabs in the new browser to the group if it belonged in a group.
if (group.has_value()) {
std::vector<int> indices(new_browser->tab_strip_model()->GetTabCount());
std::iota(indices.begin(), indices.end(), 0);
new_browser->tab_strip_model()->AddToNewGroup(indices, group.value(),
visual_data);
if (paused_saved_guid.has_value()) {
service->ResumeTrackingLocalTabGroup(paused_saved_guid.value(),
group.value());
}
}
new_browser->window()->Show(); new_browser->window()->Show();
} }
@ -1229,12 +1237,10 @@ void MoveTabsToExistingWindow(Browser* source,
bool pinned = source->tab_strip_model()->IsTabPinned(adjusted_index); bool pinned = source->tab_strip_model()->IsTabPinned(adjusted_index);
std::unique_ptr<tabs::TabModel> tab_model = std::unique_ptr<tabs::TabModel> tab_model =
source->tab_strip_model()->DetachTabAtForInsertion(adjusted_index); source->tab_strip_model()->DetachTabAtForInsertion(adjusted_index);
std::unique_ptr<content::WebContents> contents_move =
tabs::TabModel::DestroyAndTakeWebContents(std::move(tab_model));
int add_types = int add_types =
AddTabTypes::ADD_ACTIVE | (pinned ? AddTabTypes::ADD_PINNED : 0); AddTabTypes::ADD_ACTIVE | (pinned ? AddTabTypes::ADD_PINNED : 0);
target->tab_strip_model()->AddWebContents( target->tab_strip_model()->AddTab(std::move(tab_model), -1,
std::move(contents_move), -1, ui::PAGE_TRANSITION_TYPED, add_types); ui::PAGE_TRANSITION_TYPED, add_types);
} }
target->window()->Show(); target->window()->Show();
} }
@ -1306,6 +1312,11 @@ void ConvertPopupToTabbedBrowser(Browser* browser) {
TabStripModel* tab_strip = browser->tab_strip_model(); TabStripModel* tab_strip = browser->tab_strip_model();
std::unique_ptr<tabs::TabModel> tab_model = std::unique_ptr<tabs::TabModel> tab_model =
tab_strip->DetachTabAtForInsertion(tab_strip->active_index()); tab_strip->DetachTabAtForInsertion(tab_strip->active_index());
// This method moves a WebContents from a non-normal browser window to a
// normal browser window. We cannot move the Tab over directly since TabModel
// enforces the requirement that it cannot move between window types.
// https://crbug.com/334281979): Non-normal browser windows should not have a
// tab to begin with.
std::unique_ptr<content::WebContents> contents_move = std::unique_ptr<content::WebContents> contents_move =
tabs::TabModel::DestroyAndTakeWebContents(std::move(tab_model)); tabs::TabModel::DestroyAndTakeWebContents(std::move(tab_model));
Browser* b = Browser::Create(Browser::CreateParams(browser->profile(), true)); Browser* b = Browser::Create(Browser::CreateParams(browser->profile(), true));
@ -1525,7 +1536,7 @@ void SaveAutofillAddress(Browser* browser) {
browser->tab_strip_model()->GetActiveWebContents(); browser->tab_strip_model()->GetActiveWebContents();
autofill::AddressBubblesController* controller = autofill::AddressBubblesController* controller =
autofill::AddressBubblesController::FromWebContents(web_contents); autofill::AddressBubblesController::FromWebContents(web_contents);
controller->OnPageActionIconClicked(); controller->OnIconClicked();
} }
void ShowVirtualCardManualFallbackBubble(Browser* browser) { void ShowVirtualCardManualFallbackBubble(Browser* browser) {
@ -1555,6 +1566,7 @@ void StartTabOrganizationRequest(Browser* browser) {
TabOrganizationServiceFactory::GetForProfile(browser->profile()); TabOrganizationServiceFactory::GetForProfile(browser->profile());
UMA_HISTOGRAM_BOOLEAN("Tab.Organization.AllEntrypoints.Clicked", true); UMA_HISTOGRAM_BOOLEAN("Tab.Organization.AllEntrypoints.Clicked", true);
UMA_HISTOGRAM_BOOLEAN("Tab.Organization.ThreeDotMenu.Clicked", true); UMA_HISTOGRAM_BOOLEAN("Tab.Organization.ThreeDotMenu.Clicked", true);
browser->window()->NotifyPromoFeatureUsed(features::kTabOrganization);
service->RestartSessionAndShowUI(browser, service->RestartSessionAndShowUI(browser,
TabOrganizationEntryPoint::kThreeDotMenu); TabOrganizationEntryPoint::kThreeDotMenu);
@ -1934,7 +1946,7 @@ void OpenTaskManager(Browser* browser) {
base::RecordAction(UserMetricsAction("TaskManager")); base::RecordAction(UserMetricsAction("TaskManager"));
chrome::ShowTaskManager(browser); chrome::ShowTaskManager(browser);
#else #else
NOTREACHED(); NOTREACHED_IN_MIGRATION();
#endif #endif
} }
@ -1960,6 +1972,13 @@ void ToggleShowFullURLs(Browser* browser) {
omnibox::kPreventUrlElisionsInOmnibox, !pref_enabled); omnibox::kPreventUrlElisionsInOmnibox, !pref_enabled);
} }
void ToggleShowGoogleLensShortcut(Browser* browser) {
bool pref_enabled = browser->profile()->GetPrefs()->GetBoolean(
omnibox::kShowGoogleLensShortcut);
browser->profile()->GetPrefs()->SetBoolean(omnibox::kShowGoogleLensShortcut,
!pref_enabled);
}
void ShowAppMenu(Browser* browser) { void ShowAppMenu(Browser* browser) {
// We record the user metric for this event in AppMenu::RunMenu. // We record the user metric for this event in AppMenu::RunMenu.
browser->window()->ShowAppMenu(); browser->window()->ShowAppMenu();
@ -1970,12 +1989,22 @@ void ShowAvatarMenu(Browser* browser) {
/*is_source_accelerator=*/true); /*is_source_accelerator=*/true);
} }
// TODO(crbug.com/345770406): Rename the function name.
// We removed the extra confirmation step in the Chrome update flow. After the
// full rollout of the code, this name will be misleading. We will clean up the
// code and its related source enums.
void OpenUpdateChromeDialog(Browser* browser) { void OpenUpdateChromeDialog(Browser* browser) {
if (UpgradeDetector::GetInstance()->is_outdated_install()) { if (UpgradeDetector::GetInstance()->is_outdated_install()) {
UpgradeDetector::GetInstance()->NotifyOutdatedInstall(); UpgradeDetector::GetInstance()->NotifyOutdatedInstall();
} else if (UpgradeDetector::GetInstance()->is_outdated_install_no_au()) { } else if (UpgradeDetector::GetInstance()->is_outdated_install_no_au()) {
UpgradeDetector::GetInstance()->NotifyOutdatedInstallNoAutoUpdate(); UpgradeDetector::GetInstance()->NotifyOutdatedInstallNoAutoUpdate();
} else { } else {
#if BUILDFLAG(IS_WIN) || BUILDFLAG(IS_MAC) || BUILDFLAG(IS_LINUX)
if (base::FeatureList::IsEnabled(features::kFewerUpdateConfirmations)) {
chrome::AttemptRelaunch();
return;
}
#endif
base::RecordAction(UserMetricsAction("UpdateChrome")); base::RecordAction(UserMetricsAction("UpdateChrome"));
browser->window()->ShowUpdateChromeDialog(); browser->window()->ShowUpdateChromeDialog();
} }
@ -2064,6 +2093,19 @@ void CopyURL(content::WebContents* web_contents) {
scw.WriteText(base::UTF8ToUTF16(web_contents->GetVisibleURL().spec())); scw.WriteText(base::UTF8ToUTF16(web_contents->GetVisibleURL().spec()));
} }
bool CanCopyUrl(const Browser* browser) {
return IsWebAppOrCustomTab(browser) ||
!sharing_hub::SharingIsDisabledByPolicy(browser->profile());
}
bool IsWebAppOrCustomTab(const Browser* browser) {
return
#if BUILDFLAG(IS_CHROMEOS_ASH)
browser->is_type_custom_tab() ||
#endif
web_app::AppBrowserController::IsWebApp(browser);
}
Browser* OpenInChrome(Browser* hosted_app_browser) { Browser* OpenInChrome(Browser* hosted_app_browser) {
// Find a non-incognito browser. // Find a non-incognito browser.
Browser* target_browser = Browser* target_browser =
@ -2218,24 +2260,10 @@ void ProcessInterceptedChromeURLNavigationInIncognito(Browser* browser,
} else if (url == GURL(chrome::kChromeUIHistoryURL)) { } else if (url == GURL(chrome::kChromeUIHistoryURL)) {
ShowIncognitoHistoryDisclaimerDialog(browser); ShowIncognitoHistoryDisclaimerDialog(browser);
} else { } else {
NOTREACHED(); NOTREACHED_IN_MIGRATION();
} }
} }
#if BUILDFLAG(ENABLE_SCREEN_AI_SERVICE)
void RunScreenAILayoutExtraction(Browser* browser) {
content::WebContents* web_contents =
browser->tab_strip_model()->GetActiveWebContents();
if (!web_contents) {
return;
}
screen_ai::AXScreenAIAnnotatorFactory::GetForBrowserContext(
browser->profile())
->AnnotateScreenshot(web_contents);
}
#endif // BUILDFLAG(ENABLE_SCREEN_AI_SERVICE)
void ExecLensOverlay(Browser* browser) { void ExecLensOverlay(Browser* browser) {
content::WebContents* web_contents = content::WebContents* web_contents =
browser->tab_strip_model()->GetActiveWebContents(); browser->tab_strip_model()->GetActiveWebContents();
@ -2269,7 +2297,7 @@ void ExecLensRegionSearch(Browser* browser) {
std::make_unique<lens::LensRegionSearchController>(); std::make_unique<lens::LensRegionSearchController>();
lens_region_search_controller_data->lens_region_search_controller->Start( lens_region_search_controller_data->lens_region_search_controller->Start(
contents, lens::features::IsLensFullscreenSearchEnabled(), contents, lens::features::IsLensFullscreenSearchEnabled(),
is_google_dsp, entry_point); /*force_open_in_new_tab=*/false, is_google_dsp, entry_point);
browser->SetUserData(lens::LensRegionSearchControllerData::kDataKey, browser->SetUserData(lens::LensRegionSearchControllerData::kDataKey,
std::move(lens_region_search_controller_data)); std::move(lens_region_search_controller_data));
} }

View file

@ -32,8 +32,7 @@ const InstallConstants kInstallModes[] = {
.install_suffix = .install_suffix =
L"", // Empty install_suffix for the primary install mode. L"", // Empty install_suffix for the primary install mode.
.logo_suffix = L"", // No logo suffix for the primary install mode. .logo_suffix = L"", // No logo suffix for the primary install mode.
.app_guid = .app_guid = L"{7D2B3E1D-D096-4594-9D8F-A6667F12E0AC}",
L"", // Empty app_guid since no integration with Google Update.
.base_app_name = L"Thorium", // A distinct base_app_name. .base_app_name = L"Thorium", // A distinct base_app_name.
.base_app_id = L"Thorium", // A distinct base_app_id. .base_app_id = L"Thorium", // A distinct base_app_id.
.browser_prog_id_prefix = L"ThoriumHTM", // Browser ProgID prefix. .browser_prog_id_prefix = L"ThoriumHTM", // Browser ProgID prefix.

View file

@ -45,6 +45,7 @@
#include "chrome/install_static/install_details.h" #include "chrome/install_static/install_details.h"
#include "chrome/install_static/install_modes.h" #include "chrome/install_static/install_modes.h"
#include "chrome/install_static/install_util.h" #include "chrome/install_static/install_util.h"
#include "chrome/installer/setup/configure_app_container_sandbox.h"
#include "chrome/installer/setup/downgrade_cleanup.h" #include "chrome/installer/setup/downgrade_cleanup.h"
#include "chrome/installer/setup/install_params.h" #include "chrome/installer/setup/install_params.h"
#include "chrome/installer/setup/installer_state.h" #include "chrome/installer/setup/installer_state.h"
@ -79,13 +80,6 @@ namespace installer {
namespace { namespace {
constexpr wchar_t kChromeInstallFilesCapabilitySid[] =
L"S-1-15-3-1024-3424233489-972189580-2057154623-747635277-1604371224-"
L"316187997-3786583170-1043257646";
constexpr wchar_t kLpacChromeInstallFilesCapabilitySid[] =
L"S-1-15-3-1024-2302894289-466761758-1166120688-1039016420-2430351297-"
L"4240214049-4028510897-3317428798";
// Thorium Application dir files // Thorium Application dir files
const wchar_t kInitPref[] = L"initial_preferences"; const wchar_t kInitPref[] = L"initial_preferences";
const wchar_t kThorVer[] = L"thor_ver"; const wchar_t kThorVer[] = L"thor_ver";
@ -361,6 +355,7 @@ void AddChromeWorkItems(const InstallParams& install_params,
->set_best_effort(true); ->set_best_effort(true);
} }
#if BUILDFLAG(GOOGLE_CHROME_BRANDING)
// Adds work items to register the Elevation Service with Windows. Only for // Adds work items to register the Elevation Service with Windows. Only for
// system level installs. // system level installs.
void AddElevationServiceWorkItems(const base::FilePath& elevation_service_path, void AddElevationServiceWorkItems(const base::FilePath& elevation_service_path,
@ -382,6 +377,7 @@ void AddElevationServiceWorkItems(const base::FilePath& elevation_service_path,
install_service_work_item->set_best_effort(true); install_service_work_item->set_best_effort(true);
list->AddWorkItem(install_service_work_item); list->AddWorkItem(install_service_work_item);
} }
#endif // BUILDFLAG(GOOGLE_CHROME_BRANDING
#if BUILDFLAG(GOOGLE_CHROME_BRANDING) #if BUILDFLAG(GOOGLE_CHROME_BRANDING)
// Adds work items to add the "store-dmtoken" command to Chrome's version key. // Adds work items to add the "store-dmtoken" command to Chrome's version key.
@ -929,20 +925,8 @@ void AddInstallWorkItems(const InstallParams& install_params,
base::BindOnce( base::BindOnce(
[](const base::FilePath& target_path, const base::FilePath& temp_path, [](const base::FilePath& target_path, const base::FilePath& temp_path,
const CallbackWorkItem& work_item) { const CallbackWorkItem& work_item) {
auto sids = base::win::Sid::FromSddlStringVector( return ConfigureAppContainerSandbox(
{kChromeInstallFilesCapabilitySid, std::array<const base::FilePath*, 2>{&target_path, &temp_path});
kLpacChromeInstallFilesCapabilitySid});
bool success = false;
if (sids) {
bool success_target = base::win::GrantAccessToPath(
target_path, *sids, FILE_GENERIC_READ | FILE_GENERIC_EXECUTE,
CONTAINER_INHERIT_ACE | OBJECT_INHERIT_ACE);
bool success_temp = base::win::GrantAccessToPath(
temp_path, *sids, FILE_GENERIC_READ | FILE_GENERIC_EXECUTE,
CONTAINER_INHERIT_ACE | OBJECT_INHERIT_ACE);
success = success_target && success_temp;
}
return success;
}, },
target_path, temp_path), target_path, temp_path),
base::DoNothing()); base::DoNothing());
@ -1004,10 +988,12 @@ void AddInstallWorkItems(const InstallParams& install_params,
installer_state.root_key(), installer_state.root_key(),
GetNotificationHelperPath(target_path, new_version), install_list); GetNotificationHelperPath(target_path, new_version), install_list);
#if BUILDFLAG(GOOGLE_CHROME_BRANDING)
if (installer_state.system_install()) { if (installer_state.system_install()) {
AddElevationServiceWorkItems( AddElevationServiceWorkItems(
GetElevationServicePath(target_path, new_version), install_list); GetElevationServicePath(target_path, new_version), install_list);
} }
#endif // BUILDFLAG(GOOGLE_CHROME_BRANDING
AddUpdateDowngradeVersionItem(installer_state.root_key(), current_version, AddUpdateDowngradeVersionItem(installer_state.root_key(), current_version,
new_version, install_list); new_version, install_list);

View file

@ -34,14 +34,14 @@
#include "base/metrics/histogram_macros.h" #include "base/metrics/histogram_macros.h"
#include "base/numerics/safe_conversions.h" #include "base/numerics/safe_conversions.h"
#include "base/ranges/algorithm.h" #include "base/ranges/algorithm.h"
#include "base/strings/string_number_conversions.h"
#include "base/strings/string_split_win.h"
#include "base/strings/string_util.h" #include "base/strings/string_util.h"
#include "base/strings/utf_string_conversions.h" #include "base/strings/utf_string_conversions.h"
#include "base/version.h" #include "base/version.h"
#include "base/win/registry.h" #include "base/win/registry.h"
#include "base/win/win_util.h" #include "base/win/win_util.h"
#include "base/win/windows_version.h" #include "base/win/windows_version.h"
#include "build/branding_buildflags.h"
#include "build/build_config.h"
#include "chrome/install_static/install_details.h" #include "chrome/install_static/install_details.h"
#include "chrome/install_static/install_modes.h" #include "chrome/install_static/install_modes.h"
#include "chrome/install_static/install_util.h" #include "chrome/install_static/install_util.h"
@ -303,7 +303,7 @@ bool DeleteFileFromTempProcess(const base::FilePath& path,
PAPCFUNC exit_process = PAPCFUNC exit_process =
reinterpret_cast<PAPCFUNC>(::GetProcAddress(kernel32, "ExitProcess")); reinterpret_cast<PAPCFUNC>(::GetProcAddress(kernel32, "ExitProcess"));
if (!sleep || !delete_file || !exit_process) { if (!sleep || !delete_file || !exit_process) {
NOTREACHED(); NOTREACHED_IN_MIGRATION();
ok = FALSE; ok = FALSE;
} else { } else {
::QueueUserAPC(sleep, pi.hThread, delay_before_delete_ms); ::QueueUserAPC(sleep, pi.hThread, delay_before_delete_ms);
@ -838,4 +838,28 @@ void AddUpdateDowngradeVersionItem(HKEY root,
} }
} }
#if BUILDFLAG(GOOGLE_CHROME_BRANDING)
std::wstring UpdateLastWindowsVersion(base::wcstring_view os_version) {
constexpr wchar_t kLastWindowsVersion[] = L"LastWindowsVersion";
base::win::RegKey key;
std::wstring last_version;
if (key.Create(HKEY_CURRENT_USER, install_static::GetRegistryPath().c_str(),
KEY_QUERY_VALUE | KEY_SET_VALUE) == ERROR_SUCCESS) {
key.ReadValue(kLastWindowsVersion, &last_version);
if (last_version == os_version) {
return last_version;
}
base::Version version(base::WideToASCII(last_version));
// Verify that last_version has a valid Windows version format, and if not,
// return an empty string.
if (!version.IsValid() || version.components().size() != 4) {
last_version.clear();
}
key.WriteValue(kLastWindowsVersion, os_version.c_str());
}
return last_version;
}
#endif // BUILDFLAG(GOOGLE_CHROME_BRANDING)
} // namespace installer } // namespace installer

View file

@ -279,6 +279,8 @@ test("components_unittests") {
"//components/password_manager/core/common:unit_tests", "//components/password_manager/core/common:unit_tests",
"//components/payments/core:unit_tests", "//components/payments/core:unit_tests",
"//components/plus_addresses:unit_tests", "//components/plus_addresses:unit_tests",
"//components/plus_addresses/metrics:unit_tests",
"//components/plus_addresses/settings:unit_tests",
"//components/plus_addresses/webdata:unit_tests", "//components/plus_addresses/webdata:unit_tests",
"//components/policy/core/browser:unit_tests", "//components/policy/core/browser:unit_tests",
"//components/policy/core/common:unit_tests", "//components/policy/core/common:unit_tests",
@ -320,6 +322,7 @@ test("components_unittests") {
"//components/services/unzip:unit_tests", "//components/services/unzip:unit_tests",
"//components/sessions:unit_tests", "//components/sessions:unit_tests",
"//components/shared_highlighting/core/common:unit_tests", "//components/shared_highlighting/core/common:unit_tests",
"//components/sharing_message:unit_tests",
"//components/signin/core/browser:unit_tests", "//components/signin/core/browser:unit_tests",
"//components/signin/internal/identity_manager:unit_tests", "//components/signin/internal/identity_manager:unit_tests",
"//components/signin/public/base:unit_tests", "//components/signin/public/base:unit_tests",
@ -349,6 +352,7 @@ test("components_unittests") {
"//components/unexportable_keys:unit_tests", "//components/unexportable_keys:unit_tests",
"//components/unified_consent:unit_tests", "//components/unified_consent:unit_tests",
"//components/upload_list:unit_tests", "//components/upload_list:unit_tests",
"//components/url_deduplication:unit_tests",
"//components/url_formatter:unit_tests", "//components/url_formatter:unit_tests",
"//components/url_formatter/spoof_checks/common_words:unit_tests", "//components/url_formatter/spoof_checks/common_words:unit_tests",
"//components/url_formatter/spoof_checks/top_domains:unit_tests", "//components/url_formatter/spoof_checks/top_domains:unit_tests",
@ -415,7 +419,6 @@ test("components_unittests") {
if (use_blink) { if (use_blink) {
deps += [ deps += [
"//components/autofill/content/browser:unit_tests", "//components/autofill/content/browser:unit_tests",
"//components/autofill/content/renderer:unit_tests",
"//components/autofill/core/common/mojom:unit_tests", "//components/autofill/core/common/mojom:unit_tests",
"//components/browsing_data/content:unit_tests", "//components/browsing_data/content:unit_tests",
"//components/browsing_topics:unit_tests", "//components/browsing_topics:unit_tests",
@ -444,13 +447,15 @@ test("components_unittests") {
"//components/enterprise/content:unit_tests", "//components/enterprise/content:unit_tests",
"//components/favicon/content:unit_tests", "//components/favicon/content:unit_tests",
"//components/feed/core/v2:core_unit_tests", "//components/feed/core/v2:core_unit_tests",
"//components/feed/core/v2:ios_shared_unit_tests",
"//components/file_access:unit_tests", "//components/file_access:unit_tests",
"//components/fingerprinting_protection_filter/browser:unit_tests",
"//components/gcm_driver/instance_id:unit_tests", "//components/gcm_driver/instance_id:unit_tests",
"//components/heavy_ad_intervention:unit_tests", "//components/heavy_ad_intervention:unit_tests",
"//components/history/content/browser:unit_tests", "//components/history/content/browser:unit_tests",
"//components/history_clusters/core:unit_tests", "//components/history_clusters/core:unit_tests",
"//components/history_embeddings:unit_tests", "//components/history_embeddings:unit_tests",
"//components/input:unit_tests",
"//components/invalidation:unit_tests",
"//components/invalidation/impl:unit_tests", "//components/invalidation/impl:unit_tests",
"//components/javascript_dialogs:unit_tests", "//components/javascript_dialogs:unit_tests",
"//components/js_injection/common:unit_tests", "//components/js_injection/common:unit_tests",
@ -487,6 +492,7 @@ test("components_unittests") {
"//components/performance_manager:unit_tests", "//components/performance_manager:unit_tests",
"//components/policy/content:unit_tests", "//components/policy/content:unit_tests",
"//components/query_tiles:unit_tests", "//components/query_tiles:unit_tests",
"//components/reduce_accept_language/browser:unit_tests",
"//components/reporting/resources:unit_tests", "//components/reporting/resources:unit_tests",
"//components/services/heap_profiling:unit_tests", "//components/services/heap_profiling:unit_tests",
"//components/services/paint_preview_compositor:unit_tests", "//components/services/paint_preview_compositor:unit_tests",
@ -503,6 +509,7 @@ test("components_unittests") {
"//components/user_education/common:unit_tests", "//components/user_education/common:unit_tests",
"//components/value_store:unit_tests", "//components/value_store:unit_tests",
"//components/visited_url_ranking/internal:unit_tests", "//components/visited_url_ranking/internal:unit_tests",
"//components/visited_url_ranking/public:unit_tests",
"//components/visitedlink/test:unit_tests", "//components/visitedlink/test:unit_tests",
"//components/web_cache/browser:unit_tests", "//components/web_cache/browser:unit_tests",
"//components/web_package:unit_tests", "//components/web_package:unit_tests",
@ -523,6 +530,10 @@ test("components_unittests") {
deps += [ "//components/enterprise/idle:unit_tests" ] deps += [ "//components/enterprise/idle:unit_tests" ]
} }
if (is_linux || is_win || is_mac) {
deps += [ "//components/named_system_lock:unit_tests" ]
}
if (is_ios) { if (is_ios) {
bundle_deps = [ ":components_tests_pak_bundle_data" ] bundle_deps = [ ":components_tests_pak_bundle_data" ]
if (use_blink) { if (use_blink) {
@ -552,24 +563,21 @@ test("components_unittests") {
} }
} else { #!is_ios } else { #!is_ios
deps += [ deps += [
"//components/autofill/content/renderer:unit_tests",
"//components/background_sync:unit_tests", "//components/background_sync:unit_tests",
"//components/blocked_content:unit_tests", "//components/blocked_content:unit_tests",
"//components/content_settings/browser/ui:unit_tests", "//components/content_settings/browser/ui:unit_tests",
"//components/facilitated_payments/content/renderer:unit_tests", "//components/facilitated_payments/content/renderer:unit_tests",
"//components/fingerprinting_protection_filter/browser:unit_tests",
"//components/headless/test:unit_tests", "//components/headless/test:unit_tests",
"//components/media_router/browser:unit_tests", "//components/media_router/browser:unit_tests",
"//components/media_router/common:unit_tests", "//components/media_router/common:unit_tests",
"//components/media_router/common/providers/cast/channel:unit_tests", "//components/media_router/common/providers/cast/channel:unit_tests",
"//components/page_info:unit_tests",
"//components/permissions:unit_tests", "//components/permissions:unit_tests",
"//components/permissions/prediction_service:unit_tests", "//components/permissions/prediction_service:unit_tests",
"//components/privacy_sandbox:unit_tests", "//components/privacy_sandbox:unit_tests",
"//components/privacy_sandbox/privacy_sandbox_attestations:unit_tests", "//components/privacy_sandbox/privacy_sandbox_attestations:unit_tests",
# TODO(chromium: 1169835) components / reporting / storage / resources: unit_tests
# can't be run on iOS until they are updated.
"//components/safe_browsing/content/browser/password_protection:password_protection_unittest",
"//components/safe_browsing/content/browser/triggers:unit_tests",
"//components/safe_browsing/content/browser/web_ui:unit_tests",
"//components/safety_check:unit_tests", "//components/safety_check:unit_tests",
"//components/security_interstitials/content:unit_tests", "//components/security_interstitials/content:unit_tests",
"//components/services/quarantine:unit_tests", "//components/services/quarantine:unit_tests",
@ -611,9 +619,12 @@ test("components_unittests") {
"//components/cdm/browser:unit_tests", "//components/cdm/browser:unit_tests",
"//components/component_updater/android:embedded_component_loader_java", "//components/component_updater/android:embedded_component_loader_java",
"//components/component_updater/android:embedded_component_loader_unittests", "//components/component_updater/android:embedded_component_loader_unittests",
"//components/content_settings/android:native_java_unittests_java",
"//components/content_settings/android:unit_tests",
"//components/crash/android:java", "//components/crash/android:java",
"//components/crash/android:unit_tests", "//components/crash/android:unit_tests",
"//components/data_sharing/internal:internal_java", "//components/data_sharing/internal:internal_java",
"//components/data_sharing/internal:native_test_helper_java",
"//components/download/internal/common:internal_java", "//components/download/internal/common:internal_java",
"//components/embedder_support/android:native_java_unittests_java", "//components/embedder_support/android:native_java_unittests_java",
"//components/embedder_support/android/metrics:test_support_java", "//components/embedder_support/android/metrics:test_support_java",
@ -741,7 +752,10 @@ test("components_unittests") {
} }
if (is_win) { if (is_win) {
deps += [ "//components/winhttp:unit_tests" ] deps += [
"//components/services/font_data:unit_tests",
"//components/winhttp:unit_tests",
]
} }
if (enable_printing) { if (enable_printing) {
@ -757,27 +771,29 @@ test("components_unittests") {
if (safe_browsing_mode != 0) { if (safe_browsing_mode != 0) {
deps += [ deps += [
"//components/safe_browsing/content/browser:unit_tests",
"//components/safe_browsing/content/browser/download:unittests",
"//components/safe_browsing/content/common:file_type_policies_unittest",
"//components/safe_browsing/content/common:unit_tests", "//components/safe_browsing/content/common:unit_tests",
"//components/safe_browsing/core/browser:safe_browsing_url_checker_unittest", "//components/safe_browsing/core/browser:safe_browsing_url_checker_unittest",
] ]
} }
# TODO(crbug / 1056278): Enable this on Fuchsia and merge with the above if (safe_browsing_mode != 0 && !is_ios) {
# conditional.
if (safe_browsing_mode != 0 && !is_fuchsia) {
deps += [ deps += [
"//components/safe_browsing/content/browser/download:unittests", # TODO(chromium: 1169835) components / reporting / storage / resources: unit_tests
"//components/safe_browsing/content/common:file_type_policies_unittest", # can't be run on iOS until they are updated.
"//components/safe_browsing/content/browser/password_protection:password_protection_unittest",
"//components/safe_browsing/content/browser/triggers:unit_tests",
"//components/safe_browsing/content/browser/web_ui:unit_tests",
"//components/safe_browsing/content/common:file_type_policies_policy_util_unittest",
] ]
} }
if (safe_browsing_mode != 0 && !is_ios && !is_fuchsia) {
deps += [ "//components/safe_browsing/content/common:file_type_policies_policy_util_unittest" ]
}
if (safe_browsing_mode == 1) { if (safe_browsing_mode == 1) {
deps += [ deps += [
"//components/safe_browsing/content/renderer:throttles_unittest", "//components/safe_browsing/content/renderer:throttles_unittest",
"//components/safe_browsing/content/renderer/phishing_classifier:unit_tests",
"//components/safe_browsing/core/browser:ping_manager_unittest", "//components/safe_browsing/core/browser:ping_manager_unittest",
"//components/safe_browsing/core/browser:user_population_unittest", "//components/safe_browsing/core/browser:user_population_unittest",
"//components/safe_browsing/core/browser:verdict_cache_manager_unittest", "//components/safe_browsing/core/browser:verdict_cache_manager_unittest",
@ -794,15 +810,6 @@ test("components_unittests") {
] ]
} }
if (safe_browsing_mode == 1) {
deps += [
"//components/safe_browsing/content/browser:unit_tests",
"//components/safe_browsing/content/renderer/phishing_classifier:unit_tests",
]
} else if (safe_browsing_mode == 2) {
deps += [ "//components/safe_browsing/content/browser:unit_tests" ]
}
if (use_dbus) { if (use_dbus) {
deps += [ deps += [
"//components/dbus/menu:unit_tests", "//components/dbus/menu:unit_tests",
@ -836,7 +843,10 @@ test("components_unittests") {
} }
if (is_mac) { if (is_mac) {
deps += [ "//components/remote_cocoa/common:unit_tests" ] deps += [
"//components/remote_cocoa/app_shim:unit_tests",
"//components/remote_cocoa/common:unit_tests",
]
} }
# On LaCrOS, tests use ash - chrome as a window manager, thus the dependency. # On LaCrOS, tests use ash - chrome as a window manager, thus the dependency.
@ -1030,6 +1040,11 @@ if (use_blink) {
data += [ "$root_out_dir/Thorium Shell.app/" ] data += [ "$root_out_dir/Thorium Shell.app/" ]
} }
if (toolkit_views && !is_mac) {
# TODO(crbug.com/349781050): Enable test on Mac.
deps += [ "//components/constrained_window:browser_tests" ]
}
if (is_ios) { if (is_ios) {
entitlements_path = "//content/app/ios/appex/app.entitlements" entitlements_path = "//content/app/ios/appex/app.entitlements"
bundle_deps = [ bundle_deps = [
@ -1054,6 +1069,7 @@ if (use_blink) {
"//components/pdf/renderer", "//components/pdf/renderer",
"//pdf:accessibility", "//pdf:accessibility",
"//pdf:features", "//pdf:features",
"//ui/strings:auto_image_annotation_strings",
] ]
} }
@ -1208,7 +1224,7 @@ if (use_blink) {
] ]
} }
if (!is_android) { if (safe_browsing_mode == 1 || is_ios) {
sources += [ "safe_browsing/core/browser/db/v4_store_perftest.cc" ] sources += [ "safe_browsing/core/browser/db/v4_store_perftest.cc" ]
deps += [ deps += [
"//components/safe_browsing/core/browser/db:v4_protocol_manager_util", "//components/safe_browsing/core/browser/db:v4_protocol_manager_util",
@ -1252,7 +1268,6 @@ if (is_android) {
"//components/policy/android:components_policy_junit_tests", "//components/policy/android:components_policy_junit_tests",
"//components/prefs/android:junit", "//components/prefs/android:junit",
"//components/query_tiles:query_tiles_junit_tests", "//components/query_tiles:query_tiles_junit_tests",
"//components/saved_tab_groups:components_tab_group_sync_junit_tests",
"//components/signin/public/android:junit", "//components/signin/public/android:junit",
"//components/stylus_handwriting/android:stylus_handwriting_junit_tests", "//components/stylus_handwriting/android:stylus_handwriting_junit_tests",
"//components/subresource_filter/android:junit", "//components/subresource_filter/android:junit",

View file

@ -152,8 +152,9 @@ std::string TruncateUrl(const std::string& url) {
GURL GetUrlFromClipboard(bool notify_if_restricted) { GURL GetUrlFromClipboard(bool notify_if_restricted) {
std::u16string url_text; std::u16string url_text;
#if !BUILDFLAG(IS_IOS) #if !BUILDFLAG(IS_IOS)
ui::DataTransferEndpoint data_dst = ui::DataTransferEndpoint( ui::DataTransferEndpoint data_dst =
ui::EndpointType::kDefault, notify_if_restricted); ui::DataTransferEndpoint(ui::EndpointType::kDefault,
{.notify_if_restricted = notify_if_restricted});
ui::Clipboard::GetForCurrentThread()->ReadText( ui::Clipboard::GetForCurrentThread()->ReadText(
ui::ClipboardBuffer::kCopyPaste, &data_dst, &url_text); ui::ClipboardBuffer::kCopyPaste, &data_dst, &url_text);
#endif #endif
@ -244,7 +245,7 @@ void CloneBookmarkNode(BookmarkModel* model,
size_t index_to_add_at, size_t index_to_add_at,
bool reset_node_times) { bool reset_node_times) {
if (!parent->is_folder() || !model) { if (!parent->is_folder() || !model) {
NOTREACHED(); NOTREACHED_IN_MIGRATION();
return; return;
} }
for (size_t i = 0; i < elements.size(); ++i) { for (size_t i = 0; i < elements.size(); ++i) {
@ -310,7 +311,7 @@ void MakeTitleUnique(const BookmarkModel* model,
return; return;
} }
} }
NOTREACHED(); NOTREACHED_IN_MIGRATION();
} }
void PasteFromClipboard(BookmarkModel* model, void PasteFromClipboard(BookmarkModel* model,
@ -495,8 +496,7 @@ void RegisterProfilePrefs(user_prefs::PrefRegistrySyncable* registry) {
user_prefs::PrefRegistrySyncable::SYNCABLE_PREF); user_prefs::PrefRegistrySyncable::SYNCABLE_PREF);
registry->RegisterBooleanPref(prefs::kEditBookmarksEnabled, true); registry->RegisterBooleanPref(prefs::kEditBookmarksEnabled, true);
registry->RegisterBooleanPref( registry->RegisterBooleanPref(
// Alex313031 removed in Thorium M120 prefs::kShowAppsShortcutInBookmarkBar, true,
prefs::kShowAppsShortcutInBookmarkBar, false,
user_prefs::PrefRegistrySyncable::SYNCABLE_PREF); user_prefs::PrefRegistrySyncable::SYNCABLE_PREF);
registry->RegisterBooleanPref( registry->RegisterBooleanPref(
prefs::kShowTabGroupsInBookmarkBar, true, prefs::kShowTabGroupsInBookmarkBar, true,

View file

@ -18,7 +18,7 @@
#include "base/strings/string_util.h" #include "base/strings/string_util.h"
#include "base/strings/utf_string_conversions.h" #include "base/strings/utf_string_conversions.h"
#include "build/build_config.h" #include "build/build_config.h"
#include "components/bookmarks/browser/core_bookmark_model.h" #include "components/bookmarks/browser/bookmark_model.h"
#include "components/omnibox/browser/autocomplete_controller.h" #include "components/omnibox/browser/autocomplete_controller.h"
#include "components/omnibox/browser/autocomplete_input.h" #include "components/omnibox/browser/autocomplete_input.h"
#include "components/omnibox/browser/autocomplete_match.h" #include "components/omnibox/browser/autocomplete_match.h"
@ -195,7 +195,7 @@ ui::ImageModel OmniboxView::GetIcon(int dip_size,
bool dark_mode) const { bool dark_mode) const {
#if BUILDFLAG(IS_ANDROID) || BUILDFLAG(IS_IOS) #if BUILDFLAG(IS_ANDROID) || BUILDFLAG(IS_IOS)
// This is used on desktop only. // This is used on desktop only.
NOTREACHED(); NOTREACHED_IN_MIGRATION();
return ui::ImageModel(); return ui::ImageModel();
#else #else
@ -233,7 +233,7 @@ ui::ImageModel OmniboxView::GetIcon(int dip_size,
// If it's never called, the vector icon we provide below should remain. // If it's never called, the vector icon we provide below should remain.
// For bookmarked suggestions, display bookmark icon. // For bookmarked suggestions, display bookmark icon.
bookmarks::CoreBookmarkModel* bookmark_model = bookmarks::BookmarkModel* bookmark_model =
controller_->client()->GetBookmarkModel(); controller_->client()->GetBookmarkModel();
const bool is_bookmarked = const bool is_bookmarked =
bookmark_model && bookmark_model->IsBookmarked(match.destination_url); bookmark_model && bookmark_model->IsBookmarked(match.destination_url);

View file

@ -9,9 +9,9 @@
#include "build/build_config.h" #include "build/build_config.h"
#include "services/metrics/public/cpp/ukm_builders.h" #include "services/metrics/public/cpp/ukm_builders.h"
#include "services/metrics/public/cpp/ukm_recorder.h" #include "services/metrics/public/cpp/ukm_recorder.h"
#include "third_party/blink/public/common/browser_interface_broker_proxy.h"
#include "third_party/blink/public/common/features.h" #include "third_party/blink/public/common/features.h"
#include "third_party/blink/public/common/mediastream/media_devices.h" #include "third_party/blink/public/common/mediastream/media_devices.h"
#include "third_party/blink/public/platform/browser_interface_broker_proxy.h"
#include "third_party/blink/public/platform/modules/webrtc/webrtc_logging.h" #include "third_party/blink/public/platform/modules/webrtc/webrtc_logging.h"
#include "third_party/blink/public/platform/web_audio_latency_hint.h" #include "third_party/blink/public/platform/web_audio_latency_hint.h"
#include "third_party/blink/renderer/bindings/core/v8/script_promise_resolver.h" #include "third_party/blink/renderer/bindings/core/v8/script_promise_resolver.h"
@ -29,6 +29,7 @@
#include "third_party/blink/renderer/modules/peerconnection/peer_connection_dependency_factory.h" #include "third_party/blink/renderer/modules/peerconnection/peer_connection_dependency_factory.h"
#include "third_party/blink/renderer/modules/permissions/permission_utils.h" #include "third_party/blink/renderer/modules/permissions/permission_utils.h"
#include "third_party/blink/renderer/modules/webaudio/audio_listener.h" #include "third_party/blink/renderer/modules/webaudio/audio_listener.h"
#include "third_party/blink/renderer/modules/webaudio/audio_playout_stats.h"
#include "third_party/blink/renderer/modules/webaudio/audio_sink_info.h" #include "third_party/blink/renderer/modules/webaudio/audio_sink_info.h"
#include "third_party/blink/renderer/modules/webaudio/media_element_audio_source_node.h" #include "third_party/blink/renderer/modules/webaudio/media_element_audio_source_node.h"
#include "third_party/blink/renderer/modules/webaudio/media_stream_audio_destination_node.h" #include "third_party/blink/renderer/modules/webaudio/media_stream_audio_destination_node.h"
@ -41,6 +42,7 @@
#include "third_party/blink/renderer/platform/bindings/exception_state.h" #include "third_party/blink/renderer/platform/bindings/exception_state.h"
#include "third_party/blink/renderer/platform/heap/garbage_collected.h" #include "third_party/blink/renderer/platform/heap/garbage_collected.h"
#include "third_party/blink/renderer/platform/instrumentation/use_counter.h" #include "third_party/blink/renderer/platform/instrumentation/use_counter.h"
#include "third_party/blink/renderer/platform/runtime_enabled_features.h"
#include "third_party/blink/renderer/platform/scheduler/public/post_cross_thread_task.h" #include "third_party/blink/renderer/platform/scheduler/public/post_cross_thread_task.h"
#include "third_party/blink/renderer/platform/wtf/cross_thread_functional.h" #include "third_party/blink/renderer/platform/wtf/cross_thread_functional.h"
#include "third_party/blink/renderer/platform/wtf/text/string_builder.h" #include "third_party/blink/renderer/platform/wtf/text/string_builder.h"
@ -358,6 +360,7 @@ AudioContext::~AudioContext() {
void AudioContext::Trace(Visitor* visitor) const { void AudioContext::Trace(Visitor* visitor) const {
visitor->Trace(close_resolver_); visitor->Trace(close_resolver_);
visitor->Trace(audio_playout_stats_);
visitor->Trace(audio_context_manager_); visitor->Trace(audio_context_manager_);
visitor->Trace(permission_service_); visitor->Trace(permission_service_);
visitor->Trace(permission_receiver_); visitor->Trace(permission_receiver_);
@ -595,6 +598,17 @@ double AudioContext::outputLatency() const {
return std::round(output_position_.hardware_output_latency / factor) * factor; return std::round(output_position_.hardware_output_latency / factor) * factor;
} }
AudioPlayoutStats* AudioContext::playoutStats() {
DCHECK(IsMainThread());
if (!RuntimeEnabledFeatures::AudioContextPlayoutStatsEnabled()) {
return nullptr;
}
if (!audio_playout_stats_) {
audio_playout_stats_ = MakeGarbageCollected<AudioPlayoutStats>(this);
}
return audio_playout_stats_.Get();
}
ScriptPromise<IDLUndefined> AudioContext::setSinkId( ScriptPromise<IDLUndefined> AudioContext::setSinkId(
ScriptState* script_state, ScriptState* script_state,
const V8UnionAudioSinkOptionsOrString* v8_sink_id, const V8UnionAudioSinkOptionsOrString* v8_sink_id,
@ -714,7 +728,7 @@ bool AudioContext::AreAutoplayRequirementsFulfilled() const {
return AutoplayPolicy::IsDocumentAllowedToPlay(*GetWindow()->document()); return AutoplayPolicy::IsDocumentAllowedToPlay(*GetWindow()->document());
} }
NOTREACHED(); NOTREACHED_IN_MIGRATION();
return false; return false;
} }
@ -749,7 +763,7 @@ bool AudioContext::IsAllowedToStart() const {
switch (GetAutoplayPolicy()) { switch (GetAutoplayPolicy()) {
case AutoplayPolicy::Type::kNoUserGestureRequired: case AutoplayPolicy::Type::kNoUserGestureRequired:
NOTREACHED(); NOTREACHED_IN_MIGRATION();
break; break;
case AutoplayPolicy::Type::kUserGestureRequired: case AutoplayPolicy::Type::kUserGestureRequired:
DCHECK(window->GetFrame()); DCHECK(window->GetFrame());
@ -827,10 +841,17 @@ RealtimeAudioDestinationNode* AudioContext::GetRealtimeAudioDestinationNode()
return static_cast<RealtimeAudioDestinationNode*>(destination()); return static_cast<RealtimeAudioDestinationNode*>(destination());
} }
bool AudioContext::HandlePreRenderTasks(const AudioIOPosition* output_position, bool AudioContext::HandlePreRenderTasks(
const AudioCallbackMetric* metric) { uint32_t frames_to_process,
const AudioIOPosition* output_position,
const AudioCallbackMetric* metric,
base::TimeDelta playout_delay,
const media::AudioGlitchInfo& glitch_info) {
DCHECK(IsAudioThread()); DCHECK(IsAudioThread());
pending_audio_frame_stats_.Update(frames_to_process, sampleRate(),
playout_delay, glitch_info);
// At the beginning of every render quantum, try to update the internal // At the beginning of every render quantum, try to update the internal
// rendering graph state (from main thread changes). It's OK if the tryLock() // rendering graph state (from main thread changes). It's OK if the tryLock()
// fails, we'll just take slightly longer to pick up the changes. // fails, we'll just take slightly longer to pick up the changes.
@ -850,6 +871,8 @@ bool AudioContext::HandlePreRenderTasks(const AudioIOPosition* output_position,
output_position_ = *output_position; output_position_ = *output_position;
callback_metric_ = *metric; callback_metric_ = *metric;
audio_frame_stats_.Absorb(pending_audio_frame_stats_);
unlock(); unlock();
} }
@ -1178,18 +1201,18 @@ bool AudioContext::IsValidSinkDescriptor(
} }
void AudioContext::OnRenderError() { void AudioContext::OnRenderError() {
if (base::FeatureList::IsEnabled(features::kWebAudioHandleOnRenderError)) { DCHECK(IsMainThread());
DCHECK(IsMainThread());
CHECK(GetExecutionContext()); if (!RuntimeEnabledFeatures::AudioContextOnErrorEnabled()) {
LocalDOMWindow* window = To<LocalDOMWindow>(GetExecutionContext()); return;
if (window && window->GetFrame()) {
window->AddConsoleMessage(MakeGarbageCollected<ConsoleMessage>(
mojom::blink::ConsoleMessageSource::kOther,
mojom::blink::ConsoleMessageLevel::kError,
"The AudioContext encountered a render error."));
}
} }
CHECK(GetExecutionContext());
render_error_occurred_ = true;
GetExecutionContext()->GetTaskRunner(TaskType::kMediaElementEvent)
->PostTask(FROM_HERE,
WTF::BindOnce(&AudioContext::HandleRenderError,
WrapPersistent(this)));
} }
void AudioContext::ResumeOnPrerenderActivation() { void AudioContext::ResumeOnPrerenderActivation() {
@ -1206,4 +1229,42 @@ void AudioContext::ResumeOnPrerenderActivation() {
} }
} }
void AudioContext::TransferAudioFrameStatsTo(
AudioContext::AudioFrameStats& receiver) {
DeferredTaskHandler::GraphAutoLocker locker(this);
receiver.Absorb(audio_frame_stats_);
}
void AudioContext::HandleRenderError() {
DCHECK(IsMainThread());
LocalDOMWindow* window = To<LocalDOMWindow>(GetExecutionContext());
if (window && window->GetFrame()) {
window->AddConsoleMessage(MakeGarbageCollected<ConsoleMessage>(
mojom::blink::ConsoleMessageSource::kOther,
mojom::blink::ConsoleMessageLevel::kError,
"The AudioContext encountered an error from the audio device or the "
"WebAudio renderer."));
}
// Implements
// https://webaudio.github.io/web-audio-api/#error-handling-on-a-running-audio-context
if (ContextState() == kRunning) {
// TODO(https://crbug.com/353641602): starting or stopping the renderer
// should happen on the render thread, but this is the current convention.
destination()->GetAudioDestinationHandler().StopRendering();
DispatchEvent(*Event::Create(event_type_names::kError));
suspended_by_user_ = false;
SetContextState(kSuspended);
} else if (ContextState() == kSuspended) {
DispatchEvent(*Event::Create(event_type_names::kError));
}
}
void AudioContext::invoke_onrendererror_from_platform_for_testing() {
GetRealtimeAudioDestinationNode()->GetOwnHandler()
.invoke_onrendererror_from_platform_for_testing();
}
} // namespace blink } // namespace blink

File diff suppressed because it is too large Load diff

View file

@ -576,25 +576,24 @@ def DownloadDebianSysroot(platform_name, skip_download=False):
# work (clang can require 2.18; chromium currently doesn't) # work (clang can require 2.18; chromium currently doesn't)
# - libcrypt.so.1 reversioned so that crypt() is picked up from glibc # - libcrypt.so.1 reversioned so that crypt() is picked up from glibc
# The sysroot was built at # The sysroot was built at
# https://chromium-review.googlesource.com/c/chromium/src/+/3684954/1 # https://chromium-review.googlesource.com/c/chromium/src/+/5506275/1
# and the hashes here are from sysroots.json in that CL. # and the hashes here are from sysroots.json in that CL.
toolchain_bucket = 'https://commondatastorage.googleapis.com/chrome-linux-sysroot/toolchain/' toolchain_bucket = 'https://commondatastorage.googleapis.com/chrome-linux-sysroot/'
hashes = { hashes = {
# hash from https://chromium-review.googlesource.com/c/chromium/src/+/3684954/1/build/linux/sysroot_scripts/sysroots.json#3 # hash from https://chromium-review.googlesource.com/c/chromium/src/+/5506275/1/build/linux/sysroot_scripts/sysroots.json#3
'amd64': '2028cdaf24259d23adcff95393b8cc4f0eef714b', 'amd64': 'dec7a3a0fc5b83b909cba1b6d119077e0429a138eadef6bf5a0f2e03b1904631',
# hash from https://chromium-review.googlesource.com/c/chromium/src/+/3684954/1/build/linux/sysroot_scripts/sysroots.json#23 # hash from https://chromium-review.googlesource.com/c/chromium/src/+/5506275/1/build/linux/sysroot_scripts/sysroots.json#21
'i386': 'a033618b5e092c86e96d62d3c43f7363df6cebe7', 'i386': 'b53933120bb08ffc38140a817e3f0f99782254a6bf9622271574fa004e8783a4',
# hash from https://chromium-review.googlesource.com/c/chromium/src/+/3684954/1/build/linux/sysroot_scripts/sysroots.json#8 # hash from https://chromium-review.googlesource.com/c/chromium/src/+/5506275/1/build/linux/sysroot_scripts/sysroots.json#15
'arm': '0b9a3c54d2d5f6b1a428369aaa8d7ba7b227f701', 'arm': 'fe81e7114b97440262bce004caf02c1514732e2fa7f99693b2836932ad1c4626',
# hash from https://chromium-review.googlesource.com/c/chromium/src/+/3684954/1/build/linux/sysroot_scripts/sysroots.json#12 # hash from https://chromium-review.googlesource.com/c/chromium/src/+/5506275/1/build/linux/sysroot_scripts/sysroots.json#21
'arm64': '0e28d9832614729bb5b731161ff96cb4d516f345', 'arm64': '308e23faba3174bd01accfe358467b8a40fad4db4c49ef629da30219f65a275f',
} }
toolchain_name = f'debian_bullseye_{platform_name}_sysroot' toolchain_name = f'debian_bullseye_{platform_name}_sysroot'
output = os.path.join(LLVM_BUILD_TOOLS_DIR, toolchain_name) output = os.path.join(LLVM_BUILD_TOOLS_DIR, toolchain_name)
U = toolchain_bucket + hashes[platform_name] + '/' + toolchain_name + \ U = toolchain_bucket + hashes[platform_name]
'.tar.xz'
if not skip_download: if not skip_download:
DownloadAndUnpack(U, output) DownloadAndUnpack(U, output)
@ -948,6 +947,8 @@ def main():
# Fails with a recent ld, crbug.com/332589870 # Fails with a recent ld, crbug.com/332589870
'^.*ContinuousSyncMode/darwin-proof-of-concept.c$', '^.*ContinuousSyncMode/darwin-proof-of-concept.c$',
'^.*instrprof-darwin-exports.c$', '^.*instrprof-darwin-exports.c$',
# Fails on our mac builds, crbug.com/346289767
'^.*Interpreter/pretty-print.c$',
] ]
test_env = None test_env = None
if lit_excludes: if lit_excludes:
@ -1130,7 +1131,9 @@ def main():
chrome_tools = [] chrome_tools = []
if not args.no_tools: if not args.no_tools:
default_tools = ['plugins', 'blink_gc_plugin', 'translation_unit'] default_tools = [
'plugins', 'blink_gc_plugin', 'raw_ptr_plugin', 'translation_unit'
]
chrome_tools = list(set(default_tools + args.extra_tools)) chrome_tools = list(set(default_tools + args.extra_tools))
if cc is not None: base_cmake_args.append('-DCMAKE_C_COMPILER=' + cc) if cc is not None: base_cmake_args.append('-DCMAKE_C_COMPILER=' + cc)
if cxx is not None: base_cmake_args.append('-DCMAKE_CXX_COMPILER=' + cxx) if cxx is not None: base_cmake_args.append('-DCMAKE_CXX_COMPILER=' + cxx)
@ -1432,8 +1435,6 @@ def main():
cmake_args.append('-DLLVM_BUILTIN_TARGETS=' + all_triples) cmake_args.append('-DLLVM_BUILTIN_TARGETS=' + all_triples)
cmake_args.append('-DLLVM_RUNTIME_TARGETS=' + all_triples) cmake_args.append('-DLLVM_RUNTIME_TARGETS=' + all_triples)
# If we're bootstrapping, Goma doesn't know about the bootstrap compiler
# we're using as the host compiler.
if not args.bootstrap: if not args.bootstrap:
cmake_args.extend(ccache_cmake_args) cmake_args.extend(ccache_cmake_args)
@ -1519,7 +1520,7 @@ def main():
VerifyZStdSupport() VerifyZStdSupport()
# Run tests. # Run tests.
if (not args.build_mac_arm and if (chrome_tools and not args.build_mac_arm and
(args.run_tests or args.llvm_force_head_revision)): (args.run_tests or args.llvm_force_head_revision)):
RunCommand(['ninja', '-C', LLVM_BUILD_DIR, 'cr-check-all'], setenv=True) RunCommand(['ninja', '-C', LLVM_BUILD_DIR, 'cr-check-all'], setenv=True)

View file

@ -199,7 +199,8 @@ void ShowExamplesWindow(base::OnceClosure on_close,
} else { } else {
examples = GetExamplesToShow(std::move(examples)); examples = GetExamplesToShow(std::move(examples));
Widget* widget = new Widget; Widget* widget = new Widget;
Widget::InitParams params; Widget::InitParams params(Widget::InitParams::NATIVE_WIDGET_OWNS_WIDGET,
Widget::InitParams::TYPE_WINDOW);
params.delegate = params.delegate =
new ExamplesWindowContents(std::move(on_close), std::move(examples)); new ExamplesWindowContents(std::move(on_close), std::move(examples));
params.context = window_context; params.context = window_context;

View file

@ -55,8 +55,11 @@ generate_grd("build_grdp") {
"arrow_down.svg", "arrow_down.svg",
"arrow_right.svg", "arrow_right.svg",
"business.svg", "business.svg",
"colorize.svg",
"chevron_down.svg",
"chrome_logo_dark.svg", "chrome_logo_dark.svg",
"dark/arrow_down.svg", "dark/arrow_down.svg",
"dark/chevron_down.svg",
"icon_arrow_back.svg", "icon_arrow_back.svg",
"icon_arrow_drop_down_cr23.svg", "icon_arrow_drop_down_cr23.svg",
"icon_arrow_drop_up_cr23.svg", "icon_arrow_drop_up_cr23.svg",