M130 stage 2
|
@ -58,10 +58,7 @@
|
|||
<DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/130.0.6723.135:media/base/media_switches.cc;bpv=1" ADD_DATE="1661054752" ICON="">media_switches.cc - Chromium Code Search</A>
|
||||
<DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/130.0.6723.135:media/filters/ffmpeg_glue.cc;bpv=1" ADD_DATE="1661054752" ICON="">ffmpeg_glue.cc - Chromium Code Search</A>
|
||||
<DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/130.0.6723.135:media/filters/ffmpeg_video_decoder.cc;bpv=1" ADD_DATE="1661054752" ICON="">ffmpeg_video_decoder.cc - Chromium Code Search</A>
|
||||
<DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/130.0.6723.135:media/gpu/gpu_video_decode_accelerator_factory.cc;bpv=1" ADD_DATE="1661054752" ICON="">gpu_video_decode_accelerator_factory.cc - Chromium Code Search</A>
|
||||
<DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/130.0.6723.135:media/gpu/ipc/service/gpu_video_decode_accelerator.cc;bpv=1" ADD_DATE="1661054752" ICON="">gpu_video_decode_accelerator.cc - Chromium Code Search</A>
|
||||
<DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/130.0.6723.135:media/gpu/vaapi/vaapi_video_decode_accelerator.cc;bpv=1" ADD_DATE="1661054752" ICON="">vaapi_video_decode_accelerator.cc - Chromium Code Search</A>
|
||||
<DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/130.0.6723.135:media/gpu/vaapi/vaapi_video_decode_accelerator.h;bpv=1" ADD_DATE="1661054752" ICON="">vaapi_video_decode_accelerator.h - Chromium Code Search</A>
|
||||
<DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/130.0.6723.135:media/ffmpeg/ffmpeg_common.cc;bpv=1" ADD_DATE="1678753149" ICON="">ffmpeg_common.cc - Chromium Code Search</A>
|
||||
<DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/130.0.6723.135:media/gpu/vaapi/vaapi_wrapper.cc;bpv=1" ADD_DATE="1661054752" ICON="">vaapi_wrapper.cc - Chromium Code Search</A>
|
||||
<DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/130.0.6723.135:media/gpu/vaapi/vaapi_wrapper.h;bpv=1" ADD_DATE="1661054752" ICON="">vaapi_wrapper.h - Chromium Code Search</A>
|
||||
<DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/130.0.6723.135:net/base/load_flags_list.h;bpv=1" ADD_DATE="1661054752" ICON="">load_flags_list.h - Chromium Code Search</A>
|
||||
|
@ -198,7 +195,6 @@
|
|||
<DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/130.0.6723.135:components/version_ui/resources/about_version.html;bpv=1" ADD_DATE="1662210918" ICON="">about_version.html - Chromium Code Search</A>
|
||||
<DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/130.0.6723.135:media/base/supported_types.cc;l=1;bpv=1" ADD_DATE="1665805941" ICON="">supported_types.cc - Chromium Code Search</A>
|
||||
<DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/130.0.6723.135:components/variations/service/variations_service.cc;bpv=1" ADD_DATE="1674977695" ICON="">variations_service.cc - Chromium Code Search</A>
|
||||
<DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/130.0.6723.135:media/ffmpeg/ffmpeg_common.cc;bpv=1" ADD_DATE="1678753149" ICON="">ffmpeg_common.cc - Chromium Code Search</A>
|
||||
<DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/130.0.6723.135:build/config/android/BUILD.gn;bpv=1" ADD_DATE="1679174369" ICON="">BUILD.gn - Chromium Code Search</A>
|
||||
<DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/130.0.6723.135:media/media_options.gni;bpv=1" ADD_DATE="1679174990" ICON="">media_options.gni - Chromium Code Search</A>
|
||||
<DT><A HREF="https://source.chromium.org/chromium/chromium/src/+/refs/tags/130.0.6723.135:tools/cfi/ignores.txt;bpv=1" ADD_DATE="1682694796" ICON="">ignores.txt - Chromium Code Search</A>
|
||||
|
|
|
@ -1 +1 @@
|
|||
<svg xmlns="http://www.w3.org/2000/svg" width="48" height="48" fill-rule="evenodd" class="vector-svg"><path fill="#3367d6" stroke="#3367d6" stroke-width="3px" stroke-linecap="round" shape-rendering="geometricPrecision" d="M 31.81 42 h 4.72 c 0.27 0 0.5 -0.23 0.5 -0.5 V 31.82 a 1.5 1.5 0 0 1 1.5 -1.5 a 4.99 4.99 0 0 0 4.99 -4.99 a 4.99 4.99 0 0 0 -4.99 -4.99 a 1.5 1.5 0 0 1 -1.5 -1.5 v -7.08 c 0 -0.27 -0.23 -0.5 -0.5 -0.5 h -7.38 a 1.5 1.5 0 0 1 -1.5 -1.5 a 4.99 4.99 0 0 0 -4.99 -4.99 a 4.99 4.99 0 0 0 -4.99 4.99 a 1.5 1.5 0 0 1 -1.5 1.5 H 6.5 c -0.27 0 -0.5 0.23 -0.5 0.5 v 8.32 c 3.69 0.7 6.49 3.96 6.49 7.85 S 9.69 35.07 6 35.77 v 5.72 c 0 0.27 0.23 0.5 0.5 0.5 h 9.62 c 0.7 -3.69 3.95 -6.49 7.85 -6.49 c 3.89 0 7.14 2.8 7.85 6.49 m 4.72 3 h -6.08 a 1.5 1.5 0 0 1 -1.5 -1.5 a 4.99 4.99 0 0 0 -4.99 -4.99 a 4.99 4.99 0 0 0 -4.99 4.99 a 1.5 1.5 0 0 1 -1.5 1.5 H 6.5 c -1.93 0 -3.5 -1.57 -3.5 -3.5 v -7.08 a 1.5 1.5 0 0 1 1.5 -1.5 a 4.99 4.99 0 0 0 4.99 -4.99 A 4.99 4.99 0 0 0 4.5 22.94 a 1.5 1.5 0 0 1 -1.5 -1.5 v -9.68 c 0 -1.93 1.57 -3.5 3.5 -3.5 h 8.32 c 0.7 -3.69 3.95 -6.49 7.84 -6.49 c 3.89 0 7.14 2.8 7.85 6.49 h 6.02 c 1.93 0 3.5 1.57 3.5 3.5 v 5.72 c 3.69 0.7 6.49 3.95 6.49 7.85 c 0 3.89 -2.8 7.14 -6.49 7.85 v 8.32 c 0 1.93 -1.57 3.5 -3.5 3.5 Z" style="fill: rgb(51, 103, 214); stroke: rgb(51, 103, 214);"/></svg>
|
||||
<svg xmlns="http://www.w3.org/2000/svg" width="48" height="48" fill-rule="evenodd" class="vector-svg"><path fill="#1A73E8" stroke="#1A73E8" stroke-width="3px" stroke-linecap="round" shape-rendering="geometricPrecision" d="M 31.81 42 h 4.72 c 0.27 0 0.5 -0.23 0.5 -0.5 V 31.82 a 1.5 1.5 0 0 1 1.5 -1.5 a 4.99 4.99 0 0 0 4.99 -4.99 a 4.99 4.99 0 0 0 -4.99 -4.99 a 1.5 1.5 0 0 1 -1.5 -1.5 v -7.08 c 0 -0.27 -0.23 -0.5 -0.5 -0.5 h -7.38 a 1.5 1.5 0 0 1 -1.5 -1.5 a 4.99 4.99 0 0 0 -4.99 -4.99 a 4.99 4.99 0 0 0 -4.99 4.99 a 1.5 1.5 0 0 1 -1.5 1.5 H 6.5 c -0.27 0 -0.5 0.23 -0.5 0.5 v 8.32 c 3.69 0.7 6.49 3.96 6.49 7.85 S 9.69 35.07 6 35.77 v 5.72 c 0 0.27 0.23 0.5 0.5 0.5 h 9.62 c 0.7 -3.69 3.95 -6.49 7.85 -6.49 c 3.89 0 7.14 2.8 7.85 6.49 m 4.72 3 h -6.08 a 1.5 1.5 0 0 1 -1.5 -1.5 a 4.99 4.99 0 0 0 -4.99 -4.99 a 4.99 4.99 0 0 0 -4.99 4.99 a 1.5 1.5 0 0 1 -1.5 1.5 H 6.5 c -1.93 0 -3.5 -1.57 -3.5 -3.5 v -7.08 a 1.5 1.5 0 0 1 1.5 -1.5 a 4.99 4.99 0 0 0 4.99 -4.99 A 4.99 4.99 0 0 0 4.5 22.94 a 1.5 1.5 0 0 1 -1.5 -1.5 v -9.68 c 0 -1.93 1.57 -3.5 3.5 -3.5 h 8.32 c 0.7 -3.69 3.95 -6.49 7.84 -6.49 c 3.89 0 7.14 2.8 7.85 6.49 h 6.02 c 1.93 0 3.5 1.57 3.5 3.5 v 5.72 c 3.69 0.7 6.49 3.95 6.49 7.85 c 0 3.89 -2.8 7.14 -6.49 7.85 v 8.32 c 0 1.93 -1.57 3.5 -3.5 3.5 Z" style="fill: rgb(51, 103, 214); stroke: rgb(51, 103, 214);"/></svg>
|
||||
|
|
Before Width: | Height: | Size: 1.3 KiB After Width: | Height: | Size: 1.3 KiB |
|
@ -1 +1 @@
|
|||
<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24"><path d="M0 0h24v24H0z" fill="none"/><path fill="#3367d6" d="M20.5 11H19V7c0-1.1-.9-2-2-2h-4V3.5a2.5 2.5 0 0 0-5 0V5H4c-1.1 0-1.99.9-1.99 2v3.8H3.5c1.49 0 2.7 1.21 2.7 2.7s-1.21 2.7-2.7 2.7H2V20c0 1.1.9 2 2 2h3.8v-1.5c0-1.49 1.21-2.7 2.7-2.7 1.49 0 2.7 1.21 2.7 2.7V22H17c1.1 0 2-.9 2-2v-4h1.5a2.5 2.5 0 0 0 0-5z"/></svg>
|
||||
<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24"><path d="M0 0h24v24H0z" fill="none"/><path fill="#1A73E8" d="M20.5 11H19V7c0-1.1-.9-2-2-2h-4V3.5a2.5 2.5 0 0 0-5 0V5H4c-1.1 0-1.99.9-1.99 2v3.8H3.5c1.49 0 2.7 1.21 2.7 2.7s-1.21 2.7-2.7 2.7H2V20c0 1.1.9 2 2 2h3.8v-1.5c0-1.49 1.21-2.7 2.7-2.7 1.49 0 2.7 1.21 2.7 2.7V22H17c1.1 0 2-.9 2-2v-4h1.5a2.5 2.5 0 0 0 0-5z"/></svg>
|
||||
|
|
Before Width: | Height: | Size: 385 B After Width: | Height: | Size: 385 B |
1
logos/NEW/webui/searchbox/bookmark_cr23.svg
Normal file
|
@ -0,0 +1 @@
|
|||
<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24"><path fill="#62757E" d="M20.62 19.96h-.59a7.6 7.6 0 0 1 0-3.08h.59a.77.77 0 1 0 0-1.54V3.89c0-.77-.63-1.39-1.4-1.39H5.953C4.552 2.5 3.39 3.57 3.39 4.92v13.5c0 1.7 1.402 3.08 3.123 3.08H20.62a.77.77 0 1 0 0-1.54ZM9.714 4.04h4.625v5.3l-1.822-1.49a.784.784 0 0 0-.98 0L9.713 9.34v-5.3Zm8.744 15.92H6.514c-.88 0-1.581-.69-1.581-1.54 0-.85.7-1.54 1.581-1.54h11.944a9.353 9.353 0 0 0 0 3.08Zm.621-4.62H6.514c-.58 0-1.12.17-1.581.44V4.92c0-.48.45-.89 1.03-.89h2.22v6.92c0 .65.76 1.01 1.261.59l2.593-2.12 2.592 2.12c.5.41 1.261.05 1.261-.59V4.04h3.21v11.31l-.02-.01Z"/></svg>
|
After Width: | Height: | Size: 639 B |
Before Width: | Height: | Size: 399 B After Width: | Height: | Size: 399 B |
1
logos/NEW/webui/searchbox/dino_cr23.svg
Normal file
|
@ -0,0 +1 @@
|
|||
<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" fill="#23E2DB" viewBox="0 -960 960 960"><path d="M288-48v-153.333h-38.333v-38.334h-38.334V-278H173v-38.5h-39V-355H96v-230h38.333v76.667h38.334V-470H211v38h77v-38h38.4v-38H384v-38.5h58V-585h38v-249.6h38V-873h307.556v38H864v172.636H672V-624h115v39H634v77h76v76.444h-38v-38.222h-38V-336h-39v58h-38.333v38.333h-38.334v153.334h38.334V-48H480v-114.75h-38V-201h-38.667v38.333h-38.666v38.334H326V-86h39v38h-77Zm269-729h38v-39h-38v39ZM58-163h153v-19H58v19Zm537 0h307v-19H595v19ZM173-86h77v-19h-77v19ZM58-28h76v-20H58v20Zm787-20h19v-19h-19v19Z"/></svg>
|
After Width: | Height: | Size: 606 B |
1
logos/NEW/webui/searchbox/extension_app.svg
Normal file
|
@ -0,0 +1 @@
|
|||
<svg width="32" height="32" viewBox="0 0 32 32" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"><defs><path d="M24.5 15H23v-4c0-1.1-.9-2-2-2h-4V7.5a2.5 2.5 0 0 0-5 0V9H8c-1.1 0-1.99.9-1.99 2v3.8H7.5c1.49 0 2.7 1.21 2.7 2.7 0 1.49-1.21 2.7-2.7 2.7H6V24c0 1.1.9 2 2 2h3.8v-1.5c0-1.49 1.21-2.7 2.7-2.7 1.49 0 2.7 1.21 2.7 2.7V26H21c1.1 0 2-.9 2-2v-4h1.5a2.5 2.5 0 0 0 0-5z" id="a"/></defs><use xlink:href="#a" fill-rule="evenodd" fill="#1A73E8" stroke="#1A73E8"/></svg>
|
After Width: | Height: | Size: 497 B |
Before Width: | Height: | Size: 845 B After Width: | Height: | Size: 845 B |
1
logos/NEW/webui/searchbox/incognito_cr23.svg
Normal file
|
@ -0,0 +1 @@
|
|||
<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="none" viewBox="0 0 16 16"><g fill="#E51C23" clip-path="url(#a)"><path d="M10.75 9c-.83 0-1.55.46-1.94 1.13-.26-.08-.53-.13-.81-.13s-.55.05-.81.13A2.249 2.249 0 0 0 5.25 9C4.01 9 3 10.01 3 11.25s1.01 2.25 2.25 2.25c1.12 0 2.04-.82 2.21-1.89.17-.07.35-.11.54-.11.19 0 .37.05.54.11.17 1.07 1.1 1.89 2.21 1.89 1.24 0 2.25-1.01 2.25-2.25S11.99 9 10.75 9Zm-5.5 3c-.41 0-.75-.34-.75-.75s.34-.75.75-.75.75.34.75.75-.34.75-.75.75Zm5.5 0c-.41 0-.75-.34-.75-.75s.34-.75.75-.75.75.34.75.75-.34.75-.75.75Zm.87-5.5-1.41-4a.763.763 0 0 0-.43-.45.787.787 0 0 0-.62.02L8 2.65l-1.16-.58a.764.764 0 0 0-1.05.43l-1.41 4H2V8h12V6.5h-2.38Zm-5.65 0 .95-2.7.74.37c.21.11.46.11.67 0l.74-.37.95 2.7H5.97Z"/></g><defs><clipPath id="a"><path fill="#fff" d="M0 0h16v16H0z"/></clipPath></defs></svg>
|
After Width: | Height: | Size: 839 B |
1
logos/NEW/webui/searchbox/star_active.svg
Normal file
|
@ -0,0 +1 @@
|
|||
<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24"><path fill="#62757E" fill-rule="evenodd" d="M7.5 2.05a2.8 2.8 0 0 0-2.8 2.8v15.233c0 1.457 1.64 2.31 2.834 1.473l4.351-3.052a.2.2 0 0 1 .23 0l4.351 3.052c1.193.837 2.834-.016 2.834-1.473V4.85a2.8 2.8 0 0 0-2.8-2.8h-9Z" clip-rule="evenodd"/></svg>
|
After Width: | Height: | Size: 318 B |
12
setup.sh
|
@ -126,6 +126,16 @@ patchAC3 () {
|
|||
cd ~/thorium
|
||||
}
|
||||
|
||||
patchSSE2 () {
|
||||
cp -v other/SSE2/angle-lockfree.patch ${CR_SRC_DIR}/third_party/angle/src/ &&
|
||||
|
||||
printf "\n" &&
|
||||
printf "${YEL}Patching ANGLE for SSE2...${c0}\n" &&
|
||||
cd ${CR_SRC_DIR}/third_party/angle/src &&
|
||||
git apply --reject ./angle-lockfree.patch &&
|
||||
cd ~/thorium
|
||||
}
|
||||
|
||||
cd ~/thorium &&
|
||||
|
||||
printf "\n" &&
|
||||
|
@ -144,7 +154,6 @@ copyMacOS () {
|
|||
printf "\n" &&
|
||||
printf "${YEL}Copying files for MacOS...${c0}\n" &&
|
||||
cp -v arm/mac_arm.gni ${CR_SRC_DIR}/build/config/arm.gni &&
|
||||
cp -v other/AVX2/build/config/compiler/BUILD.gn ${CR_SRC_DIR}/build/config/compiler/ &&
|
||||
cp -r -v arm/third_party/* ${CR_SRC_DIR}/third_party/ &&
|
||||
cd ${CR_SRC_DIR} &&
|
||||
python3 tools/update_pgo_profiles.py --target=mac update --gs-url-base=chromium-optimization-profiles/pgo_profiles &&
|
||||
|
@ -263,6 +272,7 @@ copySSE2 () {
|
|||
python3 tools/update_pgo_profiles.py --target=win32 update --gs-url-base=chromium-optimization-profiles/pgo_profiles &&
|
||||
cd ~/thorium &&
|
||||
[ -f ${CR_SRC_DIR}/third_party/ffmpeg/ffmpeg_hevc_ac3.patch ] || patchAC3;
|
||||
[ -f ${CR_SRC_DIR}/third_party/angle/src/angle-lockfree.patch ] || patchSSE2;
|
||||
printf "\n"
|
||||
}
|
||||
case $1 in
|
||||
|
|
BIN
src/chrome/app/theme/chromium/product_logo_16.png
Normal file
After Width: | Height: | Size: 511 B |
BIN
src/chrome/app/theme/chromium/product_logo_32.png
Normal file
After Width: | Height: | Size: 1.1 KiB |
BIN
src/chrome/app/theme/chromium/win/chromium_doc.ico
Normal file
After Width: | Height: | Size: 56 KiB |
BIN
src/chrome/app/theme/chromium/win/chromium_pdf.ico
Normal file
After Width: | Height: | Size: 55 KiB |
|
@ -115,12 +115,12 @@ const char kAudioCapturerWithEchoCancellation[] =
|
|||
"audio-capturer-with-echo-cancellation";
|
||||
#endif // BUILDFLAG(IS_FUCHSIA)
|
||||
|
||||
#if defined(USE_CRAS)
|
||||
#if BUILDFLAG(USE_CRAS)
|
||||
// Use CRAS, the ChromeOS audio server.
|
||||
const char kUseCras[] = "use-cras";
|
||||
// Enforce system audio echo cancellation.
|
||||
const char kSystemAecEnabled[] = "system-aec-enabled";
|
||||
#endif // defined(USE_CRAS)
|
||||
#endif // BUILDFLAG(USE_CRAS)
|
||||
|
||||
// For automated testing of protected content, this switch allows specific
|
||||
// domains (e.g. example.com) to always allow the permission to share the
|
||||
|
@ -367,6 +367,13 @@ BASE_FEATURE(kResumeBackgroundVideo,
|
|||
BASE_FEATURE(kMacLoopbackAudioForScreenShare,
|
||||
"MacLoopbackAudioForScreenShare",
|
||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||
|
||||
// Use the built-in MacOS screen-sharing picker (SCContentSharingPicker). This
|
||||
// flag will only use the built-in picker on MacOS 15 Sequoia and later where it
|
||||
// is required to avoid recurring permission dialogs.
|
||||
BASE_FEATURE(kUseSCContentSharingPicker,
|
||||
"UseSCContentSharingPicker",
|
||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||
#endif // BUILDFLAG(IS_MAC)
|
||||
|
||||
#if BUILDFLAG(IS_LINUX)
|
||||
|
@ -474,7 +481,7 @@ BASE_FEATURE(kContextMenuSaveVideoFrameAs,
|
|||
// Enables the "Search Video Frame with <Search Provider>" context menu item.
|
||||
BASE_FEATURE(kContextMenuSearchForVideoFrame,
|
||||
"ContextMenuSearchForVideoFrame",
|
||||
base::FEATURE_ENABLED_BY_DEFAULT);
|
||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||
|
||||
#if BUILDFLAG(CHROME_WIDE_ECHO_CANCELLATION)
|
||||
// If echo cancellation for a mic signal is requested, mix and cancel all audio
|
||||
|
@ -568,12 +575,10 @@ BASE_FEATURE(kCrOSDspBasedAgcAllowed,
|
|||
"CrOSDspBasedAgcAllowed",
|
||||
base::FEATURE_ENABLED_BY_DEFAULT);
|
||||
|
||||
BASE_FEATURE(kIgnoreUiGains,
|
||||
"IgnoreUiGains",
|
||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||
BASE_FEATURE(kIgnoreUiGains, "IgnoreUiGains", base::FEATURE_ENABLED_BY_DEFAULT);
|
||||
BASE_FEATURE(kShowForceRespectUiGainsToggle,
|
||||
"ShowForceRespectUiGainsToggle",
|
||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||
base::FEATURE_ENABLED_BY_DEFAULT);
|
||||
|
||||
BASE_FEATURE(kCrOSSystemVoiceIsolationOption,
|
||||
"CrOSSystemVoiceIsolationOption",
|
||||
|
@ -591,12 +596,6 @@ BASE_FEATURE(kMemoryPressureBasedSourceBufferGC,
|
|||
"MemoryPressureBasedSourceBufferGC",
|
||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||
|
||||
// Enables writing pixels together for all planes to a multi-planar shared
|
||||
// image.
|
||||
BASE_FEATURE(kUseWritePixelsYUV,
|
||||
"UseWritePixelsYUV",
|
||||
base::FEATURE_ENABLED_BY_DEFAULT);
|
||||
|
||||
// Controls whether the Mirroring Service will fetch, analyze, and store
|
||||
// information on the quality of the session using RTCP logs.
|
||||
BASE_FEATURE(kEnableRtcpReporting,
|
||||
|
@ -673,6 +672,13 @@ BASE_FEATURE(kFeatureManagementLiveTranslateCrOS,
|
|||
"FeatureManagementLiveTranslateCrOS",
|
||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||
|
||||
#if !BUILDFLAG(IS_ANDROID)
|
||||
// Blocks picture-in-picture windows while file dialogs are open.
|
||||
BASE_FEATURE(kFileDialogsBlockPictureInPicture,
|
||||
"FileDialogsBlockPictureInPicture",
|
||||
base::FEATURE_ENABLED_BY_DEFAULT);
|
||||
#endif // !BUILDFLAG(IS_ANDROID)
|
||||
|
||||
// Show toolbar button that opens dialog for controlling media sessions.
|
||||
BASE_FEATURE(kGlobalMediaControls,
|
||||
"GlobalMediaControls",
|
||||
|
@ -688,17 +694,12 @@ BASE_FEATURE(kGlobalMediaControlsAutoDismiss,
|
|||
"GlobalMediaControlsAutoDismiss",
|
||||
base::FEATURE_ENABLED_BY_DEFAULT);
|
||||
|
||||
#if BUILDFLAG(IS_CHROMEOS)
|
||||
// Updated global media controls UI for CrOS.
|
||||
BASE_FEATURE(kGlobalMediaControlsCrOSUpdatedUI,
|
||||
"GlobalMediaControlsCrOSUpdatedUI",
|
||||
base::FEATURE_ENABLED_BY_DEFAULT);
|
||||
#else // BUILDFLAG(IS_CHROMEOS)
|
||||
#if !BUILDFLAG(IS_CHROMEOS)
|
||||
// Updated global media controls UI for all the non-CrOS desktop platforms.
|
||||
BASE_FEATURE(kGlobalMediaControlsUpdatedUI,
|
||||
"GlobalMediaControlsUpdatedUI",
|
||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||
#endif // BUILDFLAG(IS_CHROMEOS)
|
||||
#endif // !BUILDFLAG(IS_CHROMEOS)
|
||||
|
||||
#if !BUILDFLAG(IS_ANDROID)
|
||||
// If enabled, users can request Media Remoting without fullscreen-in-tab.
|
||||
|
@ -827,6 +828,11 @@ BASE_FEATURE(kGlobalVaapiLock,
|
|||
BASE_FEATURE(kVaapiH264TemporalLayerHWEncoding,
|
||||
"VaapiH264TemporalLayerEncoding",
|
||||
base::FEATURE_ENABLED_BY_DEFAULT);
|
||||
// Enable software bitrate controller for H264 temporal layer encoding with HW
|
||||
// encoder on ChromeOS.
|
||||
BASE_FEATURE(kVaapiH264SWBitrateController,
|
||||
"VaapiH264SWBitrateController",
|
||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||
// Enable VP8 temporal layer encoding with HW encoder on ChromeOS.
|
||||
BASE_FEATURE(kVaapiVp8TemporalLayerHWEncoding,
|
||||
"VaapiVp8TemporalLayerEncoding",
|
||||
|
@ -835,6 +841,10 @@ BASE_FEATURE(kVaapiVp8TemporalLayerHWEncoding,
|
|||
BASE_FEATURE(kVaapiVp9SModeHWEncoding,
|
||||
"VaapiVp9SModeHWEncoding",
|
||||
base::FEATURE_ENABLED_BY_DEFAULT);
|
||||
// Enables VSync aligned MJPEG decoding.
|
||||
BASE_FEATURE(kVSyncMjpegDecoding,
|
||||
"VSyncMjpegDecoding",
|
||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||
#endif // defined(ARCH_CPU_X86_FAMILY) && BUILDFLAG(IS_CHROMEOS)
|
||||
#if BUILDFLAG(IS_CHROMEOS) || BUILDFLAG(IS_LINUX)
|
||||
// Enables the new V4L2StatefulVideoDecoder instead of V4L2VideoDecoder.
|
||||
|
@ -843,7 +853,11 @@ BASE_FEATURE(kVaapiVp9SModeHWEncoding,
|
|||
// all platforms.
|
||||
BASE_FEATURE(kV4L2FlatStatefulVideoDecoder,
|
||||
"V4L2FlatStatefulVideoDecoder",
|
||||
base::FEATURE_ENABLED_BY_DEFAULT);
|
||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||
// Enable H264 temporal layer encoding with V4L2 HW encoder on ChromeOS.
|
||||
BASE_FEATURE(kV4L2H264TemporalLayerHWEncoding,
|
||||
"V4L2H264TemporalLayerHWEncoding",
|
||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||
#endif
|
||||
|
||||
// Inform video blitter of video color space.
|
||||
|
@ -860,9 +874,9 @@ BASE_FEATURE(kVideoFrameUseClientSITextureTarget,
|
|||
"VideoFrameUseClientSITextureTarget",
|
||||
base::FEATURE_ENABLED_BY_DEFAULT);
|
||||
|
||||
// Displays a minimize button on video picture-in-picture windows.
|
||||
BASE_FEATURE(kVideoPictureInPictureMinimizeButton,
|
||||
"VideoPictureInPictureMinimizeButton",
|
||||
// Displays new video picture-in-picture controls for the 2024 UI update.
|
||||
BASE_FEATURE(kVideoPictureInPictureControlsUpdate2024,
|
||||
"VideoPictureInPictureControlsUpdate2024",
|
||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||
|
||||
// A video encoder is allowed to drop a frame in cast mirroring.
|
||||
|
@ -878,7 +892,7 @@ BASE_FEATURE(kWebCodecsVideoEncoderFrameDrop,
|
|||
// A hardware video encoder is allowed to drop a frame in WebRTC.
|
||||
BASE_FEATURE(kWebRTCHardwareVideoEncoderFrameDrop,
|
||||
"WebRTCHardwareVideoEncoderFrameDrop",
|
||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||
base::FEATURE_ENABLED_BY_DEFAULT);
|
||||
|
||||
// Inform webrtc with correct video color space information whenever
|
||||
// possible.
|
||||
|
@ -897,6 +911,12 @@ BASE_FEATURE(kExternalClearKeyForTesting,
|
|||
// Specifies the path to the MediaFoundation Clear Key CDM for testing.
|
||||
const base::FeatureParam<std::string> kMediaFoundationClearKeyCdmPathForTesting{
|
||||
&kExternalClearKeyForTesting, "media_foundation_cdm_path", ""};
|
||||
|
||||
// Enables the use of a faulty GPU for MediaFoundation. This is used for testing
|
||||
// purposes only.
|
||||
BASE_FEATURE(kEnableFaultyGPUForMediaFoundation,
|
||||
"EnableFaultyGPUForMediaFoundation",
|
||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||
#endif // BUILDFLAG(IS_WIN)
|
||||
|
||||
// Enables the On-Device Web Speech feature on supported devices.
|
||||
|
@ -963,11 +983,7 @@ BASE_FEATURE(kLiveCaptionUseWaitK,
|
|||
// Live Caption can be used in multiple languages, as opposed to just English.
|
||||
BASE_FEATURE(kLiveCaptionMultiLanguage,
|
||||
"LiveCaptionMultiLanguage",
|
||||
#if BUILDFLAG(IS_WIN) || BUILDFLAG(IS_MAC) || BUILDFLAG(IS_LINUX)
|
||||
base::FEATURE_ENABLED_BY_DEFAULT
|
||||
#else
|
||||
base::FEATURE_DISABLED_BY_DEFAULT
|
||||
#endif
|
||||
);
|
||||
|
||||
// Enable experimental Live Caption languages.
|
||||
|
@ -993,11 +1009,7 @@ BASE_FEATURE(kLiveCaptionWebAudio,
|
|||
// Live Translate translates captions generated by Live Caption.
|
||||
BASE_FEATURE(kLiveTranslate,
|
||||
"LiveTranslate",
|
||||
#if BUILDFLAG(IS_WIN) || BUILDFLAG(IS_MAC) || BUILDFLAG(IS_LINUX)
|
||||
base::FEATURE_ENABLED_BY_DEFAULT
|
||||
#else
|
||||
base::FEATURE_DISABLED_BY_DEFAULT
|
||||
#endif
|
||||
);
|
||||
|
||||
// Prevents UrlProvisionFetcher from making a provisioning request. If
|
||||
|
@ -1112,6 +1124,17 @@ BASE_FEATURE(kAVDColorSpaceChanges,
|
|||
"AVDColorSpaceChanges",
|
||||
base::FEATURE_ENABLED_BY_DEFAULT);
|
||||
|
||||
// Whether FFmpeg supports decoding H.264 video in software. Has no effect if
|
||||
// BUILDFLAG(ENABLE_FFMPEG_VIDEO_DECODERS) is false.
|
||||
BASE_FEATURE(kBuiltInH264Decoder,
|
||||
"BuiltInH264Decoder",
|
||||
#if BUILDFLAG(IS_ANDROID) || !BUILDFLAG(ENABLE_FFMPEG_VIDEO_DECODERS)
|
||||
base::FEATURE_DISABLED_BY_DEFAULT
|
||||
#else
|
||||
base::FEATURE_ENABLED_BY_DEFAULT
|
||||
#endif
|
||||
);
|
||||
|
||||
#if BUILDFLAG(IS_ANDROID)
|
||||
// Should we allow video playback to use an overlay if it's not needed for
|
||||
// security? Normally, we'd always want to allow this, except as part of the
|
||||
|
@ -1120,10 +1143,10 @@ BASE_FEATURE(kAllowNonSecureOverlays,
|
|||
"AllowNonSecureOverlays",
|
||||
base::FEATURE_ENABLED_BY_DEFAULT);
|
||||
|
||||
// Enables support for playback of encrypted AV1 content.
|
||||
BASE_FEATURE(kEnableEncryptedAV1,
|
||||
"EnableEncryptedAV1",
|
||||
base::FEATURE_ENABLED_BY_DEFAULT);
|
||||
// Enables block model (LinearBlock) on supported devices.
|
||||
BASE_FEATURE(kMediaCodecBlockModel,
|
||||
"MediaCodecBlockModel",
|
||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||
|
||||
// Allow FrameInfoHelper to guess coded size information for MediaCodec frames.
|
||||
BASE_FEATURE(kMediaCodecCodedSizeGuessing,
|
||||
|
@ -1164,11 +1187,6 @@ BASE_FEATURE(kMediaDrmGetStatusForPolicy,
|
|||
"MediaDrmGetStatusForPolicy",
|
||||
base::FEATURE_ENABLED_BY_DEFAULT);
|
||||
|
||||
// Enables CanPlayType() (and other queries) for HLS MIME types. Note that
|
||||
// disabling this also causes navigation to .m3u8 files to trigger downloading
|
||||
// instead of playback.
|
||||
BASE_FEATURE(kCanPlayHls, "CanPlayHls", base::FEATURE_ENABLED_BY_DEFAULT);
|
||||
|
||||
// Enables the use of MediaPlayerRenderer for HLS playback. When disabled,
|
||||
// HLS manifests will fail to load (triggering source fallback or load error).
|
||||
BASE_FEATURE(kHlsPlayer, "HlsPlayer", base::FEATURE_ENABLED_BY_DEFAULT);
|
||||
|
@ -1200,6 +1218,13 @@ BASE_FEATURE(kAllowMediaCodecSoftwareDecoder,
|
|||
"AllowMediaCodecSoftwareDecoder",
|
||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||
|
||||
// This feature allows for some MediaDrm functions to be executed in a separate
|
||||
// process so that crashes do not bring down the browser. Flag is available so
|
||||
// that it can be disabled for WebView as separate processes are not allowed.
|
||||
BASE_FEATURE(kAllowMediaCodecCallsInSeparateProcess,
|
||||
"AllowMediaCodecCallsInSeparateProcess",
|
||||
base::FEATURE_ENABLED_BY_DEFAULT);
|
||||
|
||||
#endif // BUILDFLAG(IS_ANDROID)
|
||||
|
||||
#if BUILDFLAG(ENABLE_HLS_DEMUXER)
|
||||
|
@ -1233,17 +1258,6 @@ BASE_FEATURE(kChromeOSHWVBREncoding,
|
|||
#endif
|
||||
);
|
||||
|
||||
#if !BUILDFLAG(USE_VAAPI)
|
||||
// Enable the hardware-accelerated direct video decoder instead of the one
|
||||
// needing the VdaVideoDecoder adapter. This flag is used mainly as a
|
||||
// chrome:flag for developers debugging issues as well as to be able to
|
||||
// experiment with direct VideoDecoder path on Linux Desktop.
|
||||
// TODO(b/159825227): remove when the direct video decoder is fully launched.
|
||||
BASE_FEATURE(kUseChromeOSDirectVideoDecoder,
|
||||
"UseChromeOSDirectVideoDecoder",
|
||||
base::FEATURE_ENABLED_BY_DEFAULT);
|
||||
#endif // !BUILDFLAG(USE_VAAPI)
|
||||
|
||||
// Limit the number of concurrent hardware decoder instances on ChromeOS.
|
||||
BASE_FEATURE(kLimitConcurrentDecoderInstances,
|
||||
"LimitConcurrentDecoderInstances",
|
||||
|
@ -1296,21 +1310,13 @@ BASE_FEATURE(kEnableArmHwdrm10bitOverlays,
|
|||
#if BUILDFLAG(USE_CHROMEOS_PROTECTED_MEDIA)
|
||||
// Enable use of HW based L1 Widevine DRM via the cdm-oemcrypto daemon on
|
||||
// ChromeOS. This flag is temporary while we finish development.
|
||||
// Expiry: M128
|
||||
// Expiry: M133
|
||||
// TODO(b/364969273): Remove this flag later.
|
||||
BASE_FEATURE(kEnableArmHwdrm,
|
||||
"EnableArmHwdrm",
|
||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||
base::FEATURE_ENABLED_BY_DEFAULT);
|
||||
#endif // BUILDFLAG(USE_CHROMEOS_PROTECTED_MEDIA)
|
||||
#endif // defined(ARCH_CPU_ARM_FAMILY)
|
||||
#if BUILDFLAG(IS_CHROMEOS) && !BUILDFLAG(USE_VAAPI)
|
||||
// ChromeOS has one of two VideoDecoder implementations active based on
|
||||
// SoC/board specific configurations that are sent via command line flags. This
|
||||
// switch allows using the non default implementation for testing.
|
||||
// TODO(b/159825227): remove when the "old" video decoder is fully launched.
|
||||
BASE_FEATURE(kUseAlternateVideoDecoderImplementation,
|
||||
"UseAlternateVideoDecoderImplementation",
|
||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||
#endif // BUILDFLAG(IS_CHROMEOS) && !BUILDFLAG(USE_VAAPI)
|
||||
#endif // BUILDFLAG(USE_CHROMEOS_MEDIA_ACCELERATION)
|
||||
|
||||
#if BUILDFLAG(IS_WIN)
|
||||
|
@ -1414,7 +1420,12 @@ const base::FeatureParam<int> kBatchReadCount{&kMediaFoundationBatchRead,
|
|||
// ENABLE_PLATFORM_ENCRYPTED_DOLBY_VISION is disabled.
|
||||
BASE_FEATURE(kPlatformEncryptedDolbyVision,
|
||||
"PlatformEncryptedDolbyVision",
|
||||
#if BUILDFLAG(IS_WIN)
|
||||
base::FEATURE_ENABLED_BY_DEFAULT
|
||||
#else
|
||||
base::FEATURE_ENABLED_BY_DEFAULT);
|
||||
#endif
|
||||
);
|
||||
|
||||
// When ENABLE_PLATFORM_ENCRYPTED_DOLBY_VISION is enabled at build time and
|
||||
// `kPlatformEncryptedDolbyVision` is enabled at run time, encrypted Dolby
|
||||
|
@ -1723,6 +1734,13 @@ BASE_FEATURE(kCastStreamingMacHardwareH264,
|
|||
base::FEATURE_ENABLED_BY_DEFAULT);
|
||||
#endif
|
||||
|
||||
#if BUILDFLAG(IS_WIN)
|
||||
// Controls whether hardware H264 is default enabled on Windows.
|
||||
BASE_FEATURE(kCastStreamingWinHardwareH264,
|
||||
"CastStreamingWinHardwareH264",
|
||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||
#endif
|
||||
|
||||
#if BUILDFLAG(IS_FUCHSIA)
|
||||
// Enables use of Fuchsia's Mediacodec service for encoding.
|
||||
BASE_FEATURE(kFuchsiaMediacodecVideoEncoder,
|
||||
|
@ -1734,11 +1752,7 @@ BASE_FEATURE(kFuchsiaMediacodecVideoEncoder,
|
|||
// smaller than maximum supported decodes as advertiszed by decoder.
|
||||
BASE_FEATURE(kVideoDecodeBatching,
|
||||
"VideoDecodeBatching",
|
||||
#if BUILDFLAG(IS_CHROMEOS)
|
||||
base::FEATURE_ENABLED_BY_DEFAULT
|
||||
#else
|
||||
base::FEATURE_DISABLED_BY_DEFAULT
|
||||
#endif
|
||||
);
|
||||
|
||||
// Safety switch to allow us to revert to the previous behavior of using the
|
||||
|
@ -1864,10 +1878,6 @@ bool IsVideoCaptureAcceleratedJpegDecodingEnabled() {
|
|||
#endif
|
||||
}
|
||||
|
||||
bool IsWritePixelsYUVEnabled() {
|
||||
return base::FeatureList::IsEnabled(kUseWritePixelsYUV);
|
||||
}
|
||||
|
||||
#if BUILDFLAG(IS_WIN)
|
||||
bool IsMediaFoundationD3D11VideoCaptureEnabled() {
|
||||
return base::FeatureList::IsEnabled(kMediaFoundationD3D11VideoCapture);
|
||||
|
|
|
@ -2,6 +2,11 @@
|
|||
// Use of this source code is governed by a BSD-style license that can be
|
||||
// found in the LICENSE file.
|
||||
|
||||
#ifdef UNSAFE_BUFFERS_BUILD
|
||||
// TODO(crbug.com/40285824): Remove this and convert code to safer constructs.
|
||||
#pragma allow_unsafe_buffers
|
||||
#endif
|
||||
|
||||
#include "media/ffmpeg/ffmpeg_common.h"
|
||||
|
||||
#include "base/hash/sha1.h"
|
||||
|
|
|
@ -12,10 +12,20 @@
|
|||
#include "base/types/cxx23_to_underlying.h"
|
||||
#include "media/base/container_names.h"
|
||||
#include "media/base/media_switches.h"
|
||||
#include "media/base/supported_types.h"
|
||||
#include "media/ffmpeg/ffmpeg_common.h"
|
||||
|
||||
namespace media {
|
||||
|
||||
// Kill switches in case things explode. Remove after M132.
|
||||
// TODO(crbug.com/355485812): Re-enable this flag.
|
||||
BASE_FEATURE(kAllowOnlyAudioCodecsDuringDemuxing,
|
||||
"AllowOnlyAudioCodecsDuringDemuxing",
|
||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||
BASE_FEATURE(kForbidH264ParsingDuringDemuxing,
|
||||
"ForbidH264ParsingDuringDemuxing",
|
||||
base::FEATURE_DISABLED_BY_DEFAULT);
|
||||
|
||||
// Internal buffer size used by AVIO for reading.
|
||||
// TODO(dalecurtis): Experiment with this buffer size and measure impact on
|
||||
// performance. Currently we want to use 32kb to preserve existing behavior
|
||||
|
@ -108,6 +118,12 @@ FFmpegGlue::FFmpegGlue(FFmpegURLProtocol* protocol) {
|
|||
// Enable fast, but inaccurate seeks for MP3.
|
||||
format_context_->flags |= AVFMT_FLAG_FAST_SEEK;
|
||||
|
||||
// We don't allow H.264 parsing during demuxing since we have our own parser
|
||||
// and the ffmpeg one increases memory usage unnecessarily.
|
||||
if (base::FeatureList::IsEnabled(kForbidH264ParsingDuringDemuxing)) {
|
||||
format_context_->flags |= AVFMT_FLAG_NOH264PARSE;
|
||||
}
|
||||
|
||||
// Ensures format parsing errors will bail out. From an audit on 11/2017, all
|
||||
// instances were real failures. Solves bugs like http://crbug.com/710791.
|
||||
format_context_->error_recognition |= AV_EF_EXPLODE;
|
||||
|
@ -122,6 +138,13 @@ FFmpegGlue::FFmpegGlue(FFmpegURLProtocol* protocol) {
|
|||
// deprecations and when an external ffmpeg is used this adds extra
|
||||
// security.
|
||||
static const base::NoDestructor<std::string> kCombinedCodecList([]() {
|
||||
if (base::FeatureList::IsEnabled(kAllowOnlyAudioCodecsDuringDemuxing)) {
|
||||
// We also don't allow ffmpeg to use any video decoders during demuxing
|
||||
// since it's unnecessary for the codecs we use and just increases
|
||||
// memory usage.
|
||||
return std::string(GetAllowedAudioDecoders());
|
||||
}
|
||||
|
||||
return base::JoinString(
|
||||
{GetAllowedAudioDecoders(), GetAllowedVideoDecoders()}, ",");
|
||||
}());
|
||||
|
@ -151,22 +174,15 @@ const char* FFmpegGlue::GetAllowedAudioDecoders() {
|
|||
|
||||
// static
|
||||
const char* FFmpegGlue::GetAllowedVideoDecoders() {
|
||||
static const base::NoDestructor<std::string> kAllowedVideoCodecs([]() {
|
||||
// This should match the configured lists in //third_party/ffmpeg.
|
||||
#if BUILDFLAG(ENABLE_FFMPEG_VIDEO_DECODERS)
|
||||
std::vector<std::string> allowed_decoders;
|
||||
#if BUILDFLAG(USE_PROPRIETARY_CODECS)
|
||||
allowed_decoders.push_back("h264");
|
||||
#if BUILDFLAG(USE_PROPRIETARY_CODECS) && BUILDFLAG(ENABLE_FFMPEG_VIDEO_DECODERS)
|
||||
#if BUILDFLAG(ENABLE_PLATFORM_HEVC)
|
||||
allowed_decoders.push_back("hevc");
|
||||
#endif // BUILDFLAG(ENABLE_PLATFORM_HEVC)
|
||||
#endif // BUILDFLAG(USE_PROPRIETARY_CODECS)
|
||||
return base::JoinString(allowed_decoders, ",");
|
||||
return IsBuiltInVideoCodec(VideoCodec::kH264) ? "h264,hevc" : "";
|
||||
#else
|
||||
return std::string();
|
||||
#endif // BUILDFLAG(ENABLE_FFMPEG_VIDEO_DECODERS)
|
||||
}());
|
||||
return kAllowedVideoCodecs->c_str();
|
||||
return IsBuiltInVideoCodec(VideoCodec::kH264) ? "h264" : "";
|
||||
#else
|
||||
return "";
|
||||
#endif
|
||||
}
|
||||
|
||||
bool FFmpegGlue::OpenContext(bool is_local_file) {
|
||||
|
|
|
@ -2,6 +2,11 @@
|
|||
// Use of this source code is governed by a BSD-style license that can be
|
||||
// found in the LICENSE file.
|
||||
|
||||
#ifdef UNSAFE_BUFFERS_BUILD
|
||||
// TODO(crbug.com/40285824): Remove this and convert code to safer constructs.
|
||||
#pragma allow_unsafe_buffers
|
||||
#endif
|
||||
|
||||
#include "media/filters/ffmpeg_video_decoder.h"
|
||||
|
||||
#include <stddef.h>
|
||||
|
@ -21,6 +26,7 @@
|
|||
#include "media/base/limits.h"
|
||||
#include "media/base/media_log.h"
|
||||
#include "media/base/media_switches.h"
|
||||
#include "media/base/supported_types.h"
|
||||
#include "media/base/timestamp_constants.h"
|
||||
#include "media/base/video_aspect_ratio.h"
|
||||
#include "media/base/video_frame.h"
|
||||
|
@ -120,7 +126,8 @@ static void ReleaseVideoBufferImpl(void* opaque, uint8_t* data) {
|
|||
|
||||
// static
|
||||
bool FFmpegVideoDecoder::IsCodecSupported(VideoCodec codec) {
|
||||
return avcodec_find_decoder(VideoCodecToCodecID(codec)) != nullptr;
|
||||
// We only build support for H.264 and HEVC.
|
||||
return codec == VideoCodec::kH264 && IsBuiltInVideoCodec(codec);
|
||||
}
|
||||
|
||||
FFmpegVideoDecoder::FFmpegVideoDecoder(MediaLog* media_log)
|
||||
|
|
|
@ -95,15 +95,15 @@ LOAD_FLAG(SUPPORT_ASYNC_REVALIDATION, 1 << 14)
|
|||
|
||||
// Indicates that a prefetch request's cached response should be restricted in
|
||||
// in terms of reuse. The cached response can only be reused by requests with
|
||||
// the LOAD_CAN_USE_RESTRICTED_PREFETCH load flag.
|
||||
LOAD_FLAG(RESTRICTED_PREFETCH, 1 << 15)
|
||||
// the LOAD_CAN_USE_RESTRICTED_PREFETCH_FOR_MAIN_FRAME load flag.
|
||||
LOAD_FLAG(RESTRICTED_PREFETCH_FOR_MAIN_FRAME, 1 << 15)
|
||||
|
||||
// This flag must be set on requests that are allowed to reuse cache entries
|
||||
// that are marked as RESTRICTED_PREFETCH. Requests without this flag cannot
|
||||
// reuse restricted prefetch responses in the cache. Restricted response reuse
|
||||
// is considered privileged, and therefore this flag must only be set from a
|
||||
// trusted process.
|
||||
LOAD_FLAG(CAN_USE_RESTRICTED_PREFETCH, 1 << 16)
|
||||
// that are marked as RESTRICTED_PREFETCH_FOR_MAIN_FRAME. Requests without this
|
||||
// flag cannot reuse restricted prefetch responses in the cache. Restricted
|
||||
// response reuse is considered privileged, and therefore this flag must only be
|
||||
// set from a trusted process.
|
||||
LOAD_FLAG(CAN_USE_RESTRICTED_PREFETCH_FOR_MAIN_FRAME, 1 << 16)
|
||||
|
||||
// Indicates that this load can use a shared dictionary.
|
||||
LOAD_FLAG(CAN_USE_SHARED_DICTIONARY, 1 << 17)
|
||||
|
|
|
@ -88,7 +88,8 @@ void UpdateConfigForDohUpgrade(DnsConfig* config) {
|
|||
}
|
||||
|
||||
class DnsClientImpl : public DnsClient {
|
||||
const bool disable_thorium_dns_config = base::CommandLine::ForCurrentProcess()->HasSwitch("disable-thorium-dns-config");
|
||||
const bool disable_thorium_dns_config =
|
||||
base::CommandLine::ForCurrentProcess()->HasSwitch("disable-thorium-dns-config");
|
||||
public:
|
||||
DnsClientImpl(NetLog* net_log, const RandIntCallback& rand_int_callback)
|
||||
: net_log_(net_log), rand_int_callback_(rand_int_callback) {}
|
||||
|
@ -251,14 +252,12 @@ class DnsClientImpl : public DnsClient {
|
|||
private:
|
||||
std::optional<DnsConfig> BuildEffectiveConfig() const {
|
||||
DnsConfig config;
|
||||
// in Bromite it is sufficient to have secure DoH enabled to give the overrides priority
|
||||
// In Thorium it is sufficient to have secure DoH enabled to give the overrides priority
|
||||
if (config_overrides_.dns_over_https_config && config_overrides_.secure_dns_mode && !disable_thorium_dns_config) {
|
||||
config = config_overrides_.ApplyOverrides(DnsConfig());
|
||||
} else if (disable_thorium_dns_config && config_overrides_.OverridesEverything()) {
|
||||
config = config_overrides_.ApplyOverrides(DnsConfig());
|
||||
} else {
|
||||
if (!system_config_) {
|
||||
LOG(WARNING) << "BuildEffectiveConfig(): System configuration not set: No system_config_ ";
|
||||
LOG(WARNING) << "dns_client.cc->BuildEffectiveConfig(): System configuration not set: No system_config_ ";
|
||||
return std::nullopt;
|
||||
}
|
||||
|
||||
|
@ -276,7 +275,7 @@ class DnsClientImpl : public DnsClient {
|
|||
config.nameservers.clear();
|
||||
|
||||
if (!config.IsValid()) {
|
||||
LOG(WARNING) << "BuildEffectiveConfig(): invalid configuration";
|
||||
LOG(WARNING) << "dns_client.cc->BuildEffectiveConfig(): Invalid configuration";
|
||||
return std::nullopt;
|
||||
}
|
||||
|
||||
|
|
|
@ -472,7 +472,7 @@ class DnsHTTPAttempt : public DnsAttempt, public URLRequest::Delegate {
|
|||
request_->SetIdempotency(IDEMPOTENT);
|
||||
std::unique_ptr<UploadElementReader> reader =
|
||||
std::make_unique<UploadBytesElementReader>(
|
||||
query_->io_buffer()->data(), query_->io_buffer()->size());
|
||||
query_->io_buffer()->span());
|
||||
request_->set_upload(
|
||||
ElementsUploadDataStream::CreateWithReader(std::move(reader), 0));
|
||||
extra_request_headers.SetHeader(HttpRequestHeaders::kContentType,
|
||||
|
@ -813,8 +813,7 @@ class DnsTCPAttempt : public DnsAttempt {
|
|||
uint16_t query_size = static_cast<uint16_t>(query_->io_buffer()->size());
|
||||
if (static_cast<int>(query_size) != query_->io_buffer()->size())
|
||||
return ERR_FAILED;
|
||||
base::as_writable_bytes(length_buffer_->span())
|
||||
.copy_from(base::U16ToBigEndian(query_size));
|
||||
length_buffer_->span().copy_from(base::U16ToBigEndian(query_size));
|
||||
buffer_ = base::MakeRefCounted<DrainableIOBuffer>(length_buffer_,
|
||||
length_buffer_->size());
|
||||
next_state_ = STATE_SEND_LENGTH;
|
||||
|
@ -879,8 +878,8 @@ class DnsTCPAttempt : public DnsAttempt {
|
|||
return OK;
|
||||
}
|
||||
|
||||
response_length_ = base::U16FromBigEndian(
|
||||
base::as_bytes(length_buffer_->span().first<2u>()));
|
||||
response_length_ =
|
||||
base::U16FromBigEndian(length_buffer_->span().first<2u>());
|
||||
// Check if advertised response is too short. (Optimization only.)
|
||||
if (response_length_ < query_->io_buffer()->size())
|
||||
return ERR_DNS_MALFORMED_RESPONSE;
|
||||
|
|
|
@ -111,6 +111,7 @@
|
|||
|
||||
#if BUILDFLAG(ENABLE_DEVICE_BOUND_SESSIONS)
|
||||
#include "net/device_bound_sessions/registration_fetcher_param.h"
|
||||
#include "net/device_bound_sessions/session_challenge_param.h"
|
||||
#include "net/device_bound_sessions/session_service.h"
|
||||
#endif // BUILDFLAG(ENABLE_DEVICE_BOUND_SESSIONS)
|
||||
|
||||
|
@ -306,7 +307,7 @@ HttpRequestSSLUpgradeDecision GetMetricForSSLUpgradeDecision(
|
|||
return is_secure ? HttpRequestSSLUpgradeDecision::kSSLDynamicUpgrade
|
||||
: HttpRequestSSLUpgradeDecision::kInsecureDynamicUpgrade;
|
||||
}
|
||||
NOTREACHED_NORETURN();
|
||||
NOTREACHED();
|
||||
}
|
||||
|
||||
void RecordSTSHistograms(net::SSLUpgradeDecision upgrade_decision,
|
||||
|
@ -445,6 +446,9 @@ void URLRequestHttpJob::Start() {
|
|||
request_info_.is_subframe_document_resource =
|
||||
request_->isolation_info().request_type() ==
|
||||
net::IsolationInfo::RequestType::kSubFrame;
|
||||
request_info_.is_main_frame_navigation =
|
||||
request_->isolation_info().IsMainFrameRequest();
|
||||
request_info_.initiator = request_->initiator();
|
||||
request_info_.load_flags = request_->load_flags();
|
||||
request_info_.priority_incremental = request_->priority_incremental();
|
||||
request_info_.secure_dns_policy = request_->secure_dns_policy();
|
||||
|
@ -496,7 +500,9 @@ bool ShouldBlockAllCookies(PrivacyMode privacy_mode) {
|
|||
} // namespace
|
||||
|
||||
void URLRequestHttpJob::MaybeSetSecFetchStorageAccessHeader() {
|
||||
if (!base::FeatureList::IsEnabled(features::kStorageAccessHeaders)) {
|
||||
if (!request_->network_delegate()->IsStorageAccessHeaderEnabled(
|
||||
base::OptionalToPtr(request_->isolation_info().top_frame_origin()),
|
||||
request_->url())) {
|
||||
return;
|
||||
}
|
||||
// Avoid attaching the header in cases where the Cookie header is not included
|
||||
|
@ -1044,10 +1050,7 @@ void URLRequestHttpJob::SaveCookiesAndNotifyHeadersComplete(int result) {
|
|||
clear_site_data_prevents_cookies_from_being_stored = true;
|
||||
}
|
||||
|
||||
base::Time response_date;
|
||||
std::optional<base::Time> server_time = std::nullopt;
|
||||
if (GetResponseHeaders()->GetDateValue(&response_date))
|
||||
server_time = std::make_optional(response_date);
|
||||
std::optional<base::Time> server_time = GetResponseHeaders()->GetDateValue();
|
||||
|
||||
bool force_ignore_site_for_cookies =
|
||||
request_->force_ignore_site_for_cookies();
|
||||
|
@ -1167,14 +1170,26 @@ void URLRequestHttpJob::OnSetCookieResult(const CookieOptions& options,
|
|||
|
||||
#if BUILDFLAG(ENABLE_DEVICE_BOUND_SESSIONS)
|
||||
void URLRequestHttpJob::ProcessDeviceBoundSessionsHeader() {
|
||||
device_bound_sessions::SessionService* service =
|
||||
request_->context()->device_bound_session_service();
|
||||
if (!service) {
|
||||
return;
|
||||
}
|
||||
|
||||
const auto& request_url = request_->url();
|
||||
auto* headers = GetResponseHeaders();
|
||||
std::vector<device_bound_sessions::RegistrationFetcherParam> params =
|
||||
device_bound_sessions::RegistrationFetcherParam::CreateIfValid(
|
||||
request_->url(), GetResponseHeaders());
|
||||
if (auto* service = request_->context()->device_bound_session_service()) {
|
||||
for (auto& param : params) {
|
||||
service->RegisterBoundSession(std::move(param),
|
||||
request_->isolation_info());
|
||||
}
|
||||
request_url, headers);
|
||||
for (auto& param : params) {
|
||||
service->RegisterBoundSession(std::move(param), request_->isolation_info());
|
||||
}
|
||||
|
||||
std::vector<device_bound_sessions::SessionChallengeParam> challenge_params =
|
||||
device_bound_sessions::SessionChallengeParam::CreateIfValid(request_url,
|
||||
headers);
|
||||
for (auto& param : challenge_params) {
|
||||
service->SetChallengeForBoundSession(request_url, std::move(param));
|
||||
}
|
||||
}
|
||||
#endif // BUILDFLAG(ENABLE_DEVICE_BOUND_SESSIONS)
|
||||
|
@ -1585,7 +1600,9 @@ bool URLRequestHttpJob::NeedsAuth() {
|
|||
}
|
||||
|
||||
bool URLRequestHttpJob::NeedsRetryWithStorageAccess() {
|
||||
if (!base::FeatureList::IsEnabled(features::kStorageAccessHeaders)) {
|
||||
if (!request_->network_delegate()->IsStorageAccessHeaderEnabled(
|
||||
base::OptionalToPtr(request_->isolation_info().top_frame_origin()),
|
||||
request_->url())) {
|
||||
return false;
|
||||
}
|
||||
if (!ShouldAddCookieHeader() ||
|
||||
|
@ -1601,7 +1618,11 @@ bool URLRequestHttpJob::NeedsRetryWithStorageAccess() {
|
|||
}
|
||||
|
||||
HttpResponseHeaders* headers = request_->response_headers();
|
||||
return headers && headers->HasStorageAccessRetryHeader();
|
||||
// We use the Origin header's value directly, rather than
|
||||
// `request_.initiator()`, because the header may be "null" in some cases.
|
||||
return headers && headers->HasStorageAccessRetryHeader(base::OptionalToPtr(
|
||||
request_info_.extra_headers.GetHeader(
|
||||
HttpRequestHeaders::kOrigin)));
|
||||
}
|
||||
|
||||
void URLRequestHttpJob::SetSharedDictionaryGetter(
|
||||
|
|
|
@ -2,6 +2,11 @@
|
|||
// Use of this source code is governed by a BSD-style license that can be
|
||||
// found in the LICENSE file.
|
||||
|
||||
#ifdef UNSAFE_BUFFERS_BUILD
|
||||
// TODO(crbug.com/351564777): Remove this and convert code to safer constructs.
|
||||
#pragma allow_unsafe_buffers
|
||||
#endif
|
||||
|
||||
// This file defines utility functions for X11 (Linux only). This code has been
|
||||
// ported from XCB since we can't use XCB on Ubuntu while its 32-bit support
|
||||
// remains woefully incomplete.
|
||||
|
@ -18,6 +23,7 @@
|
|||
|
||||
#include "base/command_line.h"
|
||||
#include "base/containers/contains.h"
|
||||
#include "base/containers/span.h"
|
||||
#include "base/location.h"
|
||||
#include "base/logging.h"
|
||||
#include "base/memory/ref_counted_memory.h"
|
||||
|
@ -133,7 +139,7 @@ void DrawPixmap(x11::Connection* connection,
|
|||
for (int row = 0; row < height; row += rows_per_request) {
|
||||
size_t n_rows = std::min<size_t>(rows_per_request, height - row);
|
||||
auto data = base::MakeRefCounted<base::RefCountedStaticMemory>(
|
||||
vec.data() + row * row_bytes, n_rows * row_bytes);
|
||||
base::span(vec).subspan(row * row_bytes, n_rows * row_bytes));
|
||||
connection->PutImage({
|
||||
.format = x11::ImageFormat::ZPixmap,
|
||||
.drawable = drawable,
|
||||
|
@ -365,14 +371,9 @@ bool GetCustomFramePrefDefault() {
|
|||
return false;
|
||||
}
|
||||
|
||||
ui::WindowManagerName wm = GuessWindowManager();
|
||||
// Never default to using the custom title bar, unless the windows manager is a tiling WM.
|
||||
// Thorium should integrate, not be a special little snowflake.
|
||||
if (IsWmTiling(wm)) {
|
||||
return true;
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
bool IsWmTiling(WindowManagerName window_manager) {
|
||||
|
@ -548,8 +549,7 @@ UMALinuxWindowManager GetWindowManagerUMA() {
|
|||
case WM_XMONAD:
|
||||
return UMALinuxWindowManager::kXmonad;
|
||||
}
|
||||
NOTREACHED_IN_MIGRATION();
|
||||
return UMALinuxWindowManager::kOther;
|
||||
NOTREACHED();
|
||||
}
|
||||
|
||||
bool IsX11WindowFullScreen(x11::Window window) {
|
||||
|
|
|
@ -0,0 +1 @@
|
|||
<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24"><path fill="#62757E" d="M20.62 19.96h-.59a7.6 7.6 0 0 1 0-3.08h.59a.77.77 0 1 0 0-1.54V3.89c0-.77-.63-1.39-1.4-1.39H5.953C4.552 2.5 3.39 3.57 3.39 4.92v13.5c0 1.7 1.402 3.08 3.123 3.08H20.62a.77.77 0 1 0 0-1.54ZM9.714 4.04h4.625v5.3l-1.822-1.49a.784.784 0 0 0-.98 0L9.713 9.34v-5.3Zm8.744 15.92H6.514c-.88 0-1.581-.69-1.581-1.54 0-.85.7-1.54 1.581-1.54h11.944a9.353 9.353 0 0 0 0 3.08Zm.621-4.62H6.514c-.58 0-1.12.17-1.581.44V4.92c0-.48.45-.89 1.03-.89h2.22v6.92c0 .65.76 1.01 1.261.59l2.593-2.12 2.592 2.12c.5.41 1.261.05 1.261-.59V4.04h3.21v11.31l-.02-.01Z"/></svg>
|
After Width: | Height: | Size: 639 B |
|
@ -0,0 +1 @@
|
|||
<svg width="32" height="32" viewBox="0 0 32 32" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"><defs><path d="M24.5 15H23v-4c0-1.1-.9-2-2-2h-4V7.5a2.5 2.5 0 0 0-5 0V9H8c-1.1 0-1.99.9-1.99 2v3.8H7.5c1.49 0 2.7 1.21 2.7 2.7 0 1.49-1.21 2.7-2.7 2.7H6V24c0 1.1.9 2 2 2h3.8v-1.5c0-1.49 1.21-2.7 2.7-2.7 1.49 0 2.7 1.21 2.7 2.7V26H21c1.1 0 2-.9 2-2v-4h1.5a2.5 2.5 0 0 0 0-5z" id="a"/></defs><use xlink:href="#a" fill-rule="evenodd" fill="#1A73E8" stroke="#1A73E8"/></svg>
|
After Width: | Height: | Size: 497 B |
|
@ -0,0 +1 @@
|
|||
<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24"><path fill="#62757E" fill-rule="evenodd" d="M7.5 2.05a2.8 2.8 0 0 0-2.8 2.8v15.233c0 1.457 1.64 2.31 2.834 1.473l4.351-3.052a.2.2 0 0 1 .23 0l4.351 3.052c1.193.837 2.834-.016 2.834-1.473V4.85a2.8 2.8 0 0 0-2.8-2.8h-9Z" clip-rule="evenodd"/></svg>
|
After Width: | Height: | Size: 318 B |
|
@ -1 +1 @@
|
|||
<svg xmlns="http://www.w3.org/2000/svg" width="48" height="48" fill-rule="evenodd" class="vector-svg"><path fill="#3367d6" stroke="#3367d6" stroke-width="3px" stroke-linecap="round" shape-rendering="geometricPrecision" d="M 31.81 42 h 4.72 c 0.27 0 0.5 -0.23 0.5 -0.5 V 31.82 a 1.5 1.5 0 0 1 1.5 -1.5 a 4.99 4.99 0 0 0 4.99 -4.99 a 4.99 4.99 0 0 0 -4.99 -4.99 a 1.5 1.5 0 0 1 -1.5 -1.5 v -7.08 c 0 -0.27 -0.23 -0.5 -0.5 -0.5 h -7.38 a 1.5 1.5 0 0 1 -1.5 -1.5 a 4.99 4.99 0 0 0 -4.99 -4.99 a 4.99 4.99 0 0 0 -4.99 4.99 a 1.5 1.5 0 0 1 -1.5 1.5 H 6.5 c -0.27 0 -0.5 0.23 -0.5 0.5 v 8.32 c 3.69 0.7 6.49 3.96 6.49 7.85 S 9.69 35.07 6 35.77 v 5.72 c 0 0.27 0.23 0.5 0.5 0.5 h 9.62 c 0.7 -3.69 3.95 -6.49 7.85 -6.49 c 3.89 0 7.14 2.8 7.85 6.49 m 4.72 3 h -6.08 a 1.5 1.5 0 0 1 -1.5 -1.5 a 4.99 4.99 0 0 0 -4.99 -4.99 a 4.99 4.99 0 0 0 -4.99 4.99 a 1.5 1.5 0 0 1 -1.5 1.5 H 6.5 c -1.93 0 -3.5 -1.57 -3.5 -3.5 v -7.08 a 1.5 1.5 0 0 1 1.5 -1.5 a 4.99 4.99 0 0 0 4.99 -4.99 A 4.99 4.99 0 0 0 4.5 22.94 a 1.5 1.5 0 0 1 -1.5 -1.5 v -9.68 c 0 -1.93 1.57 -3.5 3.5 -3.5 h 8.32 c 0.7 -3.69 3.95 -6.49 7.84 -6.49 c 3.89 0 7.14 2.8 7.85 6.49 h 6.02 c 1.93 0 3.5 1.57 3.5 3.5 v 5.72 c 3.69 0.7 6.49 3.95 6.49 7.85 c 0 3.89 -2.8 7.14 -6.49 7.85 v 8.32 c 0 1.93 -1.57 3.5 -3.5 3.5 Z" style="fill: rgb(51, 103, 214); stroke: rgb(51, 103, 214);"/></svg>
|
||||
<svg xmlns="http://www.w3.org/2000/svg" width="48" height="48" fill-rule="evenodd" class="vector-svg"><path fill="#1A73E8" stroke="#1A73E8" stroke-width="3px" stroke-linecap="round" shape-rendering="geometricPrecision" d="M 31.81 42 h 4.72 c 0.27 0 0.5 -0.23 0.5 -0.5 V 31.82 a 1.5 1.5 0 0 1 1.5 -1.5 a 4.99 4.99 0 0 0 4.99 -4.99 a 4.99 4.99 0 0 0 -4.99 -4.99 a 1.5 1.5 0 0 1 -1.5 -1.5 v -7.08 c 0 -0.27 -0.23 -0.5 -0.5 -0.5 h -7.38 a 1.5 1.5 0 0 1 -1.5 -1.5 a 4.99 4.99 0 0 0 -4.99 -4.99 a 4.99 4.99 0 0 0 -4.99 4.99 a 1.5 1.5 0 0 1 -1.5 1.5 H 6.5 c -0.27 0 -0.5 0.23 -0.5 0.5 v 8.32 c 3.69 0.7 6.49 3.96 6.49 7.85 S 9.69 35.07 6 35.77 v 5.72 c 0 0.27 0.23 0.5 0.5 0.5 h 9.62 c 0.7 -3.69 3.95 -6.49 7.85 -6.49 c 3.89 0 7.14 2.8 7.85 6.49 m 4.72 3 h -6.08 a 1.5 1.5 0 0 1 -1.5 -1.5 a 4.99 4.99 0 0 0 -4.99 -4.99 a 4.99 4.99 0 0 0 -4.99 4.99 a 1.5 1.5 0 0 1 -1.5 1.5 H 6.5 c -1.93 0 -3.5 -1.57 -3.5 -3.5 v -7.08 a 1.5 1.5 0 0 1 1.5 -1.5 a 4.99 4.99 0 0 0 4.99 -4.99 A 4.99 4.99 0 0 0 4.5 22.94 a 1.5 1.5 0 0 1 -1.5 -1.5 v -9.68 c 0 -1.93 1.57 -3.5 3.5 -3.5 h 8.32 c 0.7 -3.69 3.95 -6.49 7.84 -6.49 c 3.89 0 7.14 2.8 7.85 6.49 h 6.02 c 1.93 0 3.5 1.57 3.5 3.5 v 5.72 c 3.69 0.7 6.49 3.95 6.49 7.85 c 0 3.89 -2.8 7.14 -6.49 7.85 v 8.32 c 0 1.93 -1.57 3.5 -3.5 3.5 Z" style="fill: rgb(51, 103, 214); stroke: rgb(51, 103, 214);"/></svg>
|
||||
|
|
Before Width: | Height: | Size: 1.3 KiB After Width: | Height: | Size: 1.3 KiB |
|
@ -1 +1 @@
|
|||
<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24"><path d="M0 0h24v24H0z" fill="none"/><path fill="#3367d6" d="M20.5 11H19V7c0-1.1-.9-2-2-2h-4V3.5a2.5 2.5 0 0 0-5 0V5H4c-1.1 0-1.99.9-1.99 2v3.8H3.5c1.49 0 2.7 1.21 2.7 2.7s-1.21 2.7-2.7 2.7H2V20c0 1.1.9 2 2 2h3.8v-1.5c0-1.49 1.21-2.7 2.7-2.7 1.49 0 2.7 1.21 2.7 2.7V22H17c1.1 0 2-.9 2-2v-4h1.5a2.5 2.5 0 0 0 0-5z"/></svg>
|
||||
<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24"><path d="M0 0h24v24H0z" fill="none"/><path fill="#1A73E8" d="M20.5 11H19V7c0-1.1-.9-2-2-2h-4V3.5a2.5 2.5 0 0 0-5 0V5H4c-1.1 0-1.99.9-1.99 2v3.8H3.5c1.49 0 2.7 1.21 2.7 2.7s-1.21 2.7-2.7 2.7H2V20c0 1.1.9 2 2 2h3.8v-1.5c0-1.49 1.21-2.7 2.7-2.7 1.49 0 2.7 1.21 2.7 2.7V22H17c1.1 0 2-.9 2-2v-4h1.5a2.5 2.5 0 0 0 0-5z"/></svg>
|
||||
|
|
Before Width: | Height: | Size: 385 B After Width: | Height: | Size: 385 B |