M130 stage 2

This commit is contained in:
Alexander Frick 2024-11-19 19:33:35 -06:00
parent 15c1ca4ea9
commit b41032d110
34 changed files with 208 additions and 137 deletions

View file

@ -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/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_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/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/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/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/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.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: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> <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: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: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: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: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: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> <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>

View file

@ -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

View file

@ -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

View 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

View file

Before

Width:  |  Height:  |  Size: 399 B

After

Width:  |  Height:  |  Size: 399 B

View 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

View 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

View file

Before

Width:  |  Height:  |  Size: 845 B

After

Width:  |  Height:  |  Size: 845 B

View 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

View 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

View file

@ -126,6 +126,16 @@ patchAC3 () {
cd ~/thorium 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 && cd ~/thorium &&
printf "\n" && printf "\n" &&
@ -144,7 +154,6 @@ copyMacOS () {
printf "\n" && printf "\n" &&
printf "${YEL}Copying files for MacOS...${c0}\n" && printf "${YEL}Copying files for MacOS...${c0}\n" &&
cp -v arm/mac_arm.gni ${CR_SRC_DIR}/build/config/arm.gni && 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/ && cp -r -v arm/third_party/* ${CR_SRC_DIR}/third_party/ &&
cd ${CR_SRC_DIR} && cd ${CR_SRC_DIR} &&
python3 tools/update_pgo_profiles.py --target=mac update --gs-url-base=chromium-optimization-profiles/pgo_profiles && 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 && python3 tools/update_pgo_profiles.py --target=win32 update --gs-url-base=chromium-optimization-profiles/pgo_profiles &&
cd ~/thorium && cd ~/thorium &&
[ -f ${CR_SRC_DIR}/third_party/ffmpeg/ffmpeg_hevc_ac3.patch ] || patchAC3; [ -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" printf "\n"
} }
case $1 in case $1 in

Binary file not shown.

After

Width:  |  Height:  |  Size: 511 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 56 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 55 KiB

View file

@ -115,12 +115,12 @@ const char kAudioCapturerWithEchoCancellation[] =
"audio-capturer-with-echo-cancellation"; "audio-capturer-with-echo-cancellation";
#endif // BUILDFLAG(IS_FUCHSIA) #endif // BUILDFLAG(IS_FUCHSIA)
#if defined(USE_CRAS) #if BUILDFLAG(USE_CRAS)
// Use CRAS, the ChromeOS audio server. // Use CRAS, the ChromeOS audio server.
const char kUseCras[] = "use-cras"; const char kUseCras[] = "use-cras";
// Enforce system audio echo cancellation. // Enforce system audio echo cancellation.
const char kSystemAecEnabled[] = "system-aec-enabled"; const char kSystemAecEnabled[] = "system-aec-enabled";
#endif // defined(USE_CRAS) #endif // BUILDFLAG(USE_CRAS)
// For automated testing of protected content, this switch allows specific // For automated testing of protected content, this switch allows specific
// domains (e.g. example.com) to always allow the permission to share the // domains (e.g. example.com) to always allow the permission to share the
@ -367,6 +367,13 @@ BASE_FEATURE(kResumeBackgroundVideo,
BASE_FEATURE(kMacLoopbackAudioForScreenShare, BASE_FEATURE(kMacLoopbackAudioForScreenShare,
"MacLoopbackAudioForScreenShare", "MacLoopbackAudioForScreenShare",
base::FEATURE_DISABLED_BY_DEFAULT); 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) #endif // BUILDFLAG(IS_MAC)
#if BUILDFLAG(IS_LINUX) #if BUILDFLAG(IS_LINUX)
@ -474,7 +481,7 @@ BASE_FEATURE(kContextMenuSaveVideoFrameAs,
// Enables the "Search Video Frame with <Search Provider>" context menu item. // Enables the "Search Video Frame with <Search Provider>" context menu item.
BASE_FEATURE(kContextMenuSearchForVideoFrame, BASE_FEATURE(kContextMenuSearchForVideoFrame,
"ContextMenuSearchForVideoFrame", "ContextMenuSearchForVideoFrame",
base::FEATURE_ENABLED_BY_DEFAULT); base::FEATURE_DISABLED_BY_DEFAULT);
#if BUILDFLAG(CHROME_WIDE_ECHO_CANCELLATION) #if BUILDFLAG(CHROME_WIDE_ECHO_CANCELLATION)
// If echo cancellation for a mic signal is requested, mix and cancel all audio // If echo cancellation for a mic signal is requested, mix and cancel all audio
@ -568,12 +575,10 @@ BASE_FEATURE(kCrOSDspBasedAgcAllowed,
"CrOSDspBasedAgcAllowed", "CrOSDspBasedAgcAllowed",
base::FEATURE_ENABLED_BY_DEFAULT); base::FEATURE_ENABLED_BY_DEFAULT);
BASE_FEATURE(kIgnoreUiGains, BASE_FEATURE(kIgnoreUiGains, "IgnoreUiGains", base::FEATURE_ENABLED_BY_DEFAULT);
"IgnoreUiGains",
base::FEATURE_DISABLED_BY_DEFAULT);
BASE_FEATURE(kShowForceRespectUiGainsToggle, BASE_FEATURE(kShowForceRespectUiGainsToggle,
"ShowForceRespectUiGainsToggle", "ShowForceRespectUiGainsToggle",
base::FEATURE_DISABLED_BY_DEFAULT); base::FEATURE_ENABLED_BY_DEFAULT);
BASE_FEATURE(kCrOSSystemVoiceIsolationOption, BASE_FEATURE(kCrOSSystemVoiceIsolationOption,
"CrOSSystemVoiceIsolationOption", "CrOSSystemVoiceIsolationOption",
@ -591,12 +596,6 @@ BASE_FEATURE(kMemoryPressureBasedSourceBufferGC,
"MemoryPressureBasedSourceBufferGC", "MemoryPressureBasedSourceBufferGC",
base::FEATURE_DISABLED_BY_DEFAULT); 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 // Controls whether the Mirroring Service will fetch, analyze, and store
// information on the quality of the session using RTCP logs. // information on the quality of the session using RTCP logs.
BASE_FEATURE(kEnableRtcpReporting, BASE_FEATURE(kEnableRtcpReporting,
@ -673,6 +672,13 @@ BASE_FEATURE(kFeatureManagementLiveTranslateCrOS,
"FeatureManagementLiveTranslateCrOS", "FeatureManagementLiveTranslateCrOS",
base::FEATURE_DISABLED_BY_DEFAULT); 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. // Show toolbar button that opens dialog for controlling media sessions.
BASE_FEATURE(kGlobalMediaControls, BASE_FEATURE(kGlobalMediaControls,
"GlobalMediaControls", "GlobalMediaControls",
@ -688,17 +694,12 @@ BASE_FEATURE(kGlobalMediaControlsAutoDismiss,
"GlobalMediaControlsAutoDismiss", "GlobalMediaControlsAutoDismiss",
base::FEATURE_ENABLED_BY_DEFAULT); base::FEATURE_ENABLED_BY_DEFAULT);
#if BUILDFLAG(IS_CHROMEOS) #if !BUILDFLAG(IS_CHROMEOS)
// Updated global media controls UI for CrOS.
BASE_FEATURE(kGlobalMediaControlsCrOSUpdatedUI,
"GlobalMediaControlsCrOSUpdatedUI",
base::FEATURE_ENABLED_BY_DEFAULT);
#else // BUILDFLAG(IS_CHROMEOS)
// Updated global media controls UI for all the non-CrOS desktop platforms. // Updated global media controls UI for all the non-CrOS desktop platforms.
BASE_FEATURE(kGlobalMediaControlsUpdatedUI, BASE_FEATURE(kGlobalMediaControlsUpdatedUI,
"GlobalMediaControlsUpdatedUI", "GlobalMediaControlsUpdatedUI",
base::FEATURE_DISABLED_BY_DEFAULT); base::FEATURE_DISABLED_BY_DEFAULT);
#endif // BUILDFLAG(IS_CHROMEOS) #endif // !BUILDFLAG(IS_CHROMEOS)
#if !BUILDFLAG(IS_ANDROID) #if !BUILDFLAG(IS_ANDROID)
// If enabled, users can request Media Remoting without fullscreen-in-tab. // If enabled, users can request Media Remoting without fullscreen-in-tab.
@ -827,6 +828,11 @@ BASE_FEATURE(kGlobalVaapiLock,
BASE_FEATURE(kVaapiH264TemporalLayerHWEncoding, BASE_FEATURE(kVaapiH264TemporalLayerHWEncoding,
"VaapiH264TemporalLayerEncoding", "VaapiH264TemporalLayerEncoding",
base::FEATURE_ENABLED_BY_DEFAULT); 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. // Enable VP8 temporal layer encoding with HW encoder on ChromeOS.
BASE_FEATURE(kVaapiVp8TemporalLayerHWEncoding, BASE_FEATURE(kVaapiVp8TemporalLayerHWEncoding,
"VaapiVp8TemporalLayerEncoding", "VaapiVp8TemporalLayerEncoding",
@ -835,6 +841,10 @@ BASE_FEATURE(kVaapiVp8TemporalLayerHWEncoding,
BASE_FEATURE(kVaapiVp9SModeHWEncoding, BASE_FEATURE(kVaapiVp9SModeHWEncoding,
"VaapiVp9SModeHWEncoding", "VaapiVp9SModeHWEncoding",
base::FEATURE_ENABLED_BY_DEFAULT); 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) #endif // defined(ARCH_CPU_X86_FAMILY) && BUILDFLAG(IS_CHROMEOS)
#if BUILDFLAG(IS_CHROMEOS) || BUILDFLAG(IS_LINUX) #if BUILDFLAG(IS_CHROMEOS) || BUILDFLAG(IS_LINUX)
// Enables the new V4L2StatefulVideoDecoder instead of V4L2VideoDecoder. // Enables the new V4L2StatefulVideoDecoder instead of V4L2VideoDecoder.
@ -843,7 +853,11 @@ BASE_FEATURE(kVaapiVp9SModeHWEncoding,
// all platforms. // all platforms.
BASE_FEATURE(kV4L2FlatStatefulVideoDecoder, BASE_FEATURE(kV4L2FlatStatefulVideoDecoder,
"V4L2FlatStatefulVideoDecoder", "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 #endif
// Inform video blitter of video color space. // Inform video blitter of video color space.
@ -860,9 +874,9 @@ BASE_FEATURE(kVideoFrameUseClientSITextureTarget,
"VideoFrameUseClientSITextureTarget", "VideoFrameUseClientSITextureTarget",
base::FEATURE_ENABLED_BY_DEFAULT); base::FEATURE_ENABLED_BY_DEFAULT);
// Displays a minimize button on video picture-in-picture windows. // Displays new video picture-in-picture controls for the 2024 UI update.
BASE_FEATURE(kVideoPictureInPictureMinimizeButton, BASE_FEATURE(kVideoPictureInPictureControlsUpdate2024,
"VideoPictureInPictureMinimizeButton", "VideoPictureInPictureControlsUpdate2024",
base::FEATURE_DISABLED_BY_DEFAULT); base::FEATURE_DISABLED_BY_DEFAULT);
// A video encoder is allowed to drop a frame in cast mirroring. // 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. // A hardware video encoder is allowed to drop a frame in WebRTC.
BASE_FEATURE(kWebRTCHardwareVideoEncoderFrameDrop, BASE_FEATURE(kWebRTCHardwareVideoEncoderFrameDrop,
"WebRTCHardwareVideoEncoderFrameDrop", "WebRTCHardwareVideoEncoderFrameDrop",
base::FEATURE_DISABLED_BY_DEFAULT); base::FEATURE_ENABLED_BY_DEFAULT);
// Inform webrtc with correct video color space information whenever // Inform webrtc with correct video color space information whenever
// possible. // possible.
@ -897,6 +911,12 @@ BASE_FEATURE(kExternalClearKeyForTesting,
// Specifies the path to the MediaFoundation Clear Key CDM for testing. // Specifies the path to the MediaFoundation Clear Key CDM for testing.
const base::FeatureParam<std::string> kMediaFoundationClearKeyCdmPathForTesting{ const base::FeatureParam<std::string> kMediaFoundationClearKeyCdmPathForTesting{
&kExternalClearKeyForTesting, "media_foundation_cdm_path", ""}; &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) #endif // BUILDFLAG(IS_WIN)
// Enables the On-Device Web Speech feature on supported devices. // 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. // Live Caption can be used in multiple languages, as opposed to just English.
BASE_FEATURE(kLiveCaptionMultiLanguage, BASE_FEATURE(kLiveCaptionMultiLanguage,
"LiveCaptionMultiLanguage", "LiveCaptionMultiLanguage",
#if BUILDFLAG(IS_WIN) || BUILDFLAG(IS_MAC) || BUILDFLAG(IS_LINUX)
base::FEATURE_ENABLED_BY_DEFAULT base::FEATURE_ENABLED_BY_DEFAULT
#else
base::FEATURE_DISABLED_BY_DEFAULT
#endif
); );
// Enable experimental Live Caption languages. // Enable experimental Live Caption languages.
@ -993,11 +1009,7 @@ BASE_FEATURE(kLiveCaptionWebAudio,
// Live Translate translates captions generated by Live Caption. // Live Translate translates captions generated by Live Caption.
BASE_FEATURE(kLiveTranslate, BASE_FEATURE(kLiveTranslate,
"LiveTranslate", "LiveTranslate",
#if BUILDFLAG(IS_WIN) || BUILDFLAG(IS_MAC) || BUILDFLAG(IS_LINUX)
base::FEATURE_ENABLED_BY_DEFAULT base::FEATURE_ENABLED_BY_DEFAULT
#else
base::FEATURE_DISABLED_BY_DEFAULT
#endif
); );
// Prevents UrlProvisionFetcher from making a provisioning request. If // Prevents UrlProvisionFetcher from making a provisioning request. If
@ -1112,6 +1124,17 @@ BASE_FEATURE(kAVDColorSpaceChanges,
"AVDColorSpaceChanges", "AVDColorSpaceChanges",
base::FEATURE_ENABLED_BY_DEFAULT); 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) #if BUILDFLAG(IS_ANDROID)
// Should we allow video playback to use an overlay if it's not needed for // 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 // security? Normally, we'd always want to allow this, except as part of the
@ -1120,10 +1143,10 @@ BASE_FEATURE(kAllowNonSecureOverlays,
"AllowNonSecureOverlays", "AllowNonSecureOverlays",
base::FEATURE_ENABLED_BY_DEFAULT); base::FEATURE_ENABLED_BY_DEFAULT);
// Enables support for playback of encrypted AV1 content. // Enables block model (LinearBlock) on supported devices.
BASE_FEATURE(kEnableEncryptedAV1, BASE_FEATURE(kMediaCodecBlockModel,
"EnableEncryptedAV1", "MediaCodecBlockModel",
base::FEATURE_ENABLED_BY_DEFAULT); base::FEATURE_DISABLED_BY_DEFAULT);
// Allow FrameInfoHelper to guess coded size information for MediaCodec frames. // Allow FrameInfoHelper to guess coded size information for MediaCodec frames.
BASE_FEATURE(kMediaCodecCodedSizeGuessing, BASE_FEATURE(kMediaCodecCodedSizeGuessing,
@ -1164,11 +1187,6 @@ BASE_FEATURE(kMediaDrmGetStatusForPolicy,
"MediaDrmGetStatusForPolicy", "MediaDrmGetStatusForPolicy",
base::FEATURE_ENABLED_BY_DEFAULT); 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, // Enables the use of MediaPlayerRenderer for HLS playback. When disabled,
// HLS manifests will fail to load (triggering source fallback or load error). // HLS manifests will fail to load (triggering source fallback or load error).
BASE_FEATURE(kHlsPlayer, "HlsPlayer", base::FEATURE_ENABLED_BY_DEFAULT); BASE_FEATURE(kHlsPlayer, "HlsPlayer", base::FEATURE_ENABLED_BY_DEFAULT);
@ -1200,6 +1218,13 @@ BASE_FEATURE(kAllowMediaCodecSoftwareDecoder,
"AllowMediaCodecSoftwareDecoder", "AllowMediaCodecSoftwareDecoder",
base::FEATURE_DISABLED_BY_DEFAULT); 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) #endif // BUILDFLAG(IS_ANDROID)
#if BUILDFLAG(ENABLE_HLS_DEMUXER) #if BUILDFLAG(ENABLE_HLS_DEMUXER)
@ -1233,17 +1258,6 @@ BASE_FEATURE(kChromeOSHWVBREncoding,
#endif #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. // Limit the number of concurrent hardware decoder instances on ChromeOS.
BASE_FEATURE(kLimitConcurrentDecoderInstances, BASE_FEATURE(kLimitConcurrentDecoderInstances,
"LimitConcurrentDecoderInstances", "LimitConcurrentDecoderInstances",
@ -1296,21 +1310,13 @@ BASE_FEATURE(kEnableArmHwdrm10bitOverlays,
#if BUILDFLAG(USE_CHROMEOS_PROTECTED_MEDIA) #if BUILDFLAG(USE_CHROMEOS_PROTECTED_MEDIA)
// Enable use of HW based L1 Widevine DRM via the cdm-oemcrypto daemon on // Enable use of HW based L1 Widevine DRM via the cdm-oemcrypto daemon on
// ChromeOS. This flag is temporary while we finish development. // ChromeOS. This flag is temporary while we finish development.
// Expiry: M128 // Expiry: M133
// TODO(b/364969273): Remove this flag later.
BASE_FEATURE(kEnableArmHwdrm, BASE_FEATURE(kEnableArmHwdrm,
"EnableArmHwdrm", "EnableArmHwdrm",
base::FEATURE_DISABLED_BY_DEFAULT); base::FEATURE_ENABLED_BY_DEFAULT);
#endif // BUILDFLAG(USE_CHROMEOS_PROTECTED_MEDIA) #endif // BUILDFLAG(USE_CHROMEOS_PROTECTED_MEDIA)
#endif // defined(ARCH_CPU_ARM_FAMILY) #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) #endif // BUILDFLAG(USE_CHROMEOS_MEDIA_ACCELERATION)
#if BUILDFLAG(IS_WIN) #if BUILDFLAG(IS_WIN)
@ -1414,7 +1420,12 @@ const base::FeatureParam<int> kBatchReadCount{&kMediaFoundationBatchRead,
// ENABLE_PLATFORM_ENCRYPTED_DOLBY_VISION is disabled. // ENABLE_PLATFORM_ENCRYPTED_DOLBY_VISION is disabled.
BASE_FEATURE(kPlatformEncryptedDolbyVision, BASE_FEATURE(kPlatformEncryptedDolbyVision,
"PlatformEncryptedDolbyVision", "PlatformEncryptedDolbyVision",
#if BUILDFLAG(IS_WIN)
base::FEATURE_ENABLED_BY_DEFAULT
#else
base::FEATURE_ENABLED_BY_DEFAULT); base::FEATURE_ENABLED_BY_DEFAULT);
#endif
);
// When ENABLE_PLATFORM_ENCRYPTED_DOLBY_VISION is enabled at build time and // When ENABLE_PLATFORM_ENCRYPTED_DOLBY_VISION is enabled at build time and
// `kPlatformEncryptedDolbyVision` is enabled at run time, encrypted Dolby // `kPlatformEncryptedDolbyVision` is enabled at run time, encrypted Dolby
@ -1723,6 +1734,13 @@ BASE_FEATURE(kCastStreamingMacHardwareH264,
base::FEATURE_ENABLED_BY_DEFAULT); base::FEATURE_ENABLED_BY_DEFAULT);
#endif #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) #if BUILDFLAG(IS_FUCHSIA)
// Enables use of Fuchsia's Mediacodec service for encoding. // Enables use of Fuchsia's Mediacodec service for encoding.
BASE_FEATURE(kFuchsiaMediacodecVideoEncoder, BASE_FEATURE(kFuchsiaMediacodecVideoEncoder,
@ -1734,11 +1752,7 @@ BASE_FEATURE(kFuchsiaMediacodecVideoEncoder,
// smaller than maximum supported decodes as advertiszed by decoder. // smaller than maximum supported decodes as advertiszed by decoder.
BASE_FEATURE(kVideoDecodeBatching, BASE_FEATURE(kVideoDecodeBatching,
"VideoDecodeBatching", "VideoDecodeBatching",
#if BUILDFLAG(IS_CHROMEOS)
base::FEATURE_ENABLED_BY_DEFAULT
#else
base::FEATURE_DISABLED_BY_DEFAULT base::FEATURE_DISABLED_BY_DEFAULT
#endif
); );
// Safety switch to allow us to revert to the previous behavior of using the // Safety switch to allow us to revert to the previous behavior of using the
@ -1864,10 +1878,6 @@ bool IsVideoCaptureAcceleratedJpegDecodingEnabled() {
#endif #endif
} }
bool IsWritePixelsYUVEnabled() {
return base::FeatureList::IsEnabled(kUseWritePixelsYUV);
}
#if BUILDFLAG(IS_WIN) #if BUILDFLAG(IS_WIN)
bool IsMediaFoundationD3D11VideoCaptureEnabled() { bool IsMediaFoundationD3D11VideoCaptureEnabled() {
return base::FeatureList::IsEnabled(kMediaFoundationD3D11VideoCapture); return base::FeatureList::IsEnabled(kMediaFoundationD3D11VideoCapture);

View file

@ -2,6 +2,11 @@
// Use of this source code is governed by a BSD-style license that can be // Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file. // found in the LICENSE file.
#ifdef UNSAFE_BUFFERS_BUILD
// TODO(crbug.com/40285824): Remove this and convert code to safer constructs.
#pragma allow_unsafe_buffers
#endif
#include "media/ffmpeg/ffmpeg_common.h" #include "media/ffmpeg/ffmpeg_common.h"
#include "base/hash/sha1.h" #include "base/hash/sha1.h"

View file

@ -12,10 +12,20 @@
#include "base/types/cxx23_to_underlying.h" #include "base/types/cxx23_to_underlying.h"
#include "media/base/container_names.h" #include "media/base/container_names.h"
#include "media/base/media_switches.h" #include "media/base/media_switches.h"
#include "media/base/supported_types.h"
#include "media/ffmpeg/ffmpeg_common.h" #include "media/ffmpeg/ffmpeg_common.h"
namespace media { 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. // Internal buffer size used by AVIO for reading.
// TODO(dalecurtis): Experiment with this buffer size and measure impact on // TODO(dalecurtis): Experiment with this buffer size and measure impact on
// performance. Currently we want to use 32kb to preserve existing behavior // 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. // Enable fast, but inaccurate seeks for MP3.
format_context_->flags |= AVFMT_FLAG_FAST_SEEK; 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 // 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. // instances were real failures. Solves bugs like http://crbug.com/710791.
format_context_->error_recognition |= AV_EF_EXPLODE; 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 // deprecations and when an external ffmpeg is used this adds extra
// security. // security.
static const base::NoDestructor<std::string> kCombinedCodecList([]() { 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( return base::JoinString(
{GetAllowedAudioDecoders(), GetAllowedVideoDecoders()}, ","); {GetAllowedAudioDecoders(), GetAllowedVideoDecoders()}, ",");
}()); }());
@ -151,22 +174,15 @@ const char* FFmpegGlue::GetAllowedAudioDecoders() {
// static // static
const char* FFmpegGlue::GetAllowedVideoDecoders() { const char* FFmpegGlue::GetAllowedVideoDecoders() {
static const base::NoDestructor<std::string> kAllowedVideoCodecs([]() {
// This should match the configured lists in //third_party/ffmpeg. // This should match the configured lists in //third_party/ffmpeg.
#if BUILDFLAG(ENABLE_FFMPEG_VIDEO_DECODERS) #if BUILDFLAG(USE_PROPRIETARY_CODECS) && BUILDFLAG(ENABLE_FFMPEG_VIDEO_DECODERS)
std::vector<std::string> allowed_decoders;
#if BUILDFLAG(USE_PROPRIETARY_CODECS)
allowed_decoders.push_back("h264");
#if BUILDFLAG(ENABLE_PLATFORM_HEVC) #if BUILDFLAG(ENABLE_PLATFORM_HEVC)
allowed_decoders.push_back("hevc"); return IsBuiltInVideoCodec(VideoCodec::kH264) ? "h264,hevc" : "";
#endif // BUILDFLAG(ENABLE_PLATFORM_HEVC)
#endif // BUILDFLAG(USE_PROPRIETARY_CODECS)
return base::JoinString(allowed_decoders, ",");
#else #else
return std::string(); return IsBuiltInVideoCodec(VideoCodec::kH264) ? "h264" : "";
#endif // BUILDFLAG(ENABLE_FFMPEG_VIDEO_DECODERS) #else
}()); return "";
return kAllowedVideoCodecs->c_str(); #endif
} }
bool FFmpegGlue::OpenContext(bool is_local_file) { bool FFmpegGlue::OpenContext(bool is_local_file) {

View file

@ -2,6 +2,11 @@
// Use of this source code is governed by a BSD-style license that can be // Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file. // found in the LICENSE file.
#ifdef UNSAFE_BUFFERS_BUILD
// TODO(crbug.com/40285824): Remove this and convert code to safer constructs.
#pragma allow_unsafe_buffers
#endif
#include "media/filters/ffmpeg_video_decoder.h" #include "media/filters/ffmpeg_video_decoder.h"
#include <stddef.h> #include <stddef.h>
@ -21,6 +26,7 @@
#include "media/base/limits.h" #include "media/base/limits.h"
#include "media/base/media_log.h" #include "media/base/media_log.h"
#include "media/base/media_switches.h" #include "media/base/media_switches.h"
#include "media/base/supported_types.h"
#include "media/base/timestamp_constants.h" #include "media/base/timestamp_constants.h"
#include "media/base/video_aspect_ratio.h" #include "media/base/video_aspect_ratio.h"
#include "media/base/video_frame.h" #include "media/base/video_frame.h"
@ -120,7 +126,8 @@ static void ReleaseVideoBufferImpl(void* opaque, uint8_t* data) {
// static // static
bool FFmpegVideoDecoder::IsCodecSupported(VideoCodec codec) { 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) FFmpegVideoDecoder::FFmpegVideoDecoder(MediaLog* media_log)

View file

@ -95,15 +95,15 @@ LOAD_FLAG(SUPPORT_ASYNC_REVALIDATION, 1 << 14)
// Indicates that a prefetch request's cached response should be restricted in // 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 // in terms of reuse. The cached response can only be reused by requests with
// the LOAD_CAN_USE_RESTRICTED_PREFETCH load flag. // the LOAD_CAN_USE_RESTRICTED_PREFETCH_FOR_MAIN_FRAME load flag.
LOAD_FLAG(RESTRICTED_PREFETCH, 1 << 15) LOAD_FLAG(RESTRICTED_PREFETCH_FOR_MAIN_FRAME, 1 << 15)
// This flag must be set on requests that are allowed to reuse cache entries // 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 // that are marked as RESTRICTED_PREFETCH_FOR_MAIN_FRAME. Requests without this
// reuse restricted prefetch responses in the cache. Restricted response reuse // flag cannot reuse restricted prefetch responses in the cache. Restricted
// is considered privileged, and therefore this flag must only be set from a // response reuse is considered privileged, and therefore this flag must only be
// trusted process. // set from a trusted process.
LOAD_FLAG(CAN_USE_RESTRICTED_PREFETCH, 1 << 16) LOAD_FLAG(CAN_USE_RESTRICTED_PREFETCH_FOR_MAIN_FRAME, 1 << 16)
// Indicates that this load can use a shared dictionary. // Indicates that this load can use a shared dictionary.
LOAD_FLAG(CAN_USE_SHARED_DICTIONARY, 1 << 17) LOAD_FLAG(CAN_USE_SHARED_DICTIONARY, 1 << 17)

View file

@ -88,7 +88,8 @@ void UpdateConfigForDohUpgrade(DnsConfig* config) {
} }
class DnsClientImpl : public DnsClient { 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: public:
DnsClientImpl(NetLog* net_log, const RandIntCallback& rand_int_callback) DnsClientImpl(NetLog* net_log, const RandIntCallback& rand_int_callback)
: net_log_(net_log), rand_int_callback_(rand_int_callback) {} : net_log_(net_log), rand_int_callback_(rand_int_callback) {}
@ -251,14 +252,12 @@ class DnsClientImpl : public DnsClient {
private: private:
std::optional<DnsConfig> BuildEffectiveConfig() const { std::optional<DnsConfig> BuildEffectiveConfig() const {
DnsConfig config; 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) { if (config_overrides_.dns_over_https_config && config_overrides_.secure_dns_mode && !disable_thorium_dns_config) {
config = config_overrides_.ApplyOverrides(DnsConfig()); config = config_overrides_.ApplyOverrides(DnsConfig());
} else if (disable_thorium_dns_config && config_overrides_.OverridesEverything()) {
config = config_overrides_.ApplyOverrides(DnsConfig());
} else { } else {
if (!system_config_) { 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; return std::nullopt;
} }
@ -276,7 +275,7 @@ class DnsClientImpl : public DnsClient {
config.nameservers.clear(); config.nameservers.clear();
if (!config.IsValid()) { if (!config.IsValid()) {
LOG(WARNING) << "BuildEffectiveConfig(): invalid configuration"; LOG(WARNING) << "dns_client.cc->BuildEffectiveConfig(): Invalid configuration";
return std::nullopt; return std::nullopt;
} }

View file

@ -472,7 +472,7 @@ class DnsHTTPAttempt : public DnsAttempt, public URLRequest::Delegate {
request_->SetIdempotency(IDEMPOTENT); request_->SetIdempotency(IDEMPOTENT);
std::unique_ptr<UploadElementReader> reader = std::unique_ptr<UploadElementReader> reader =
std::make_unique<UploadBytesElementReader>( std::make_unique<UploadBytesElementReader>(
query_->io_buffer()->data(), query_->io_buffer()->size()); query_->io_buffer()->span());
request_->set_upload( request_->set_upload(
ElementsUploadDataStream::CreateWithReader(std::move(reader), 0)); ElementsUploadDataStream::CreateWithReader(std::move(reader), 0));
extra_request_headers.SetHeader(HttpRequestHeaders::kContentType, 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()); uint16_t query_size = static_cast<uint16_t>(query_->io_buffer()->size());
if (static_cast<int>(query_size) != query_->io_buffer()->size()) if (static_cast<int>(query_size) != query_->io_buffer()->size())
return ERR_FAILED; return ERR_FAILED;
base::as_writable_bytes(length_buffer_->span()) length_buffer_->span().copy_from(base::U16ToBigEndian(query_size));
.copy_from(base::U16ToBigEndian(query_size));
buffer_ = base::MakeRefCounted<DrainableIOBuffer>(length_buffer_, buffer_ = base::MakeRefCounted<DrainableIOBuffer>(length_buffer_,
length_buffer_->size()); length_buffer_->size());
next_state_ = STATE_SEND_LENGTH; next_state_ = STATE_SEND_LENGTH;
@ -879,8 +878,8 @@ class DnsTCPAttempt : public DnsAttempt {
return OK; return OK;
} }
response_length_ = base::U16FromBigEndian( response_length_ =
base::as_bytes(length_buffer_->span().first<2u>())); base::U16FromBigEndian(length_buffer_->span().first<2u>());
// Check if advertised response is too short. (Optimization only.) // Check if advertised response is too short. (Optimization only.)
if (response_length_ < query_->io_buffer()->size()) if (response_length_ < query_->io_buffer()->size())
return ERR_DNS_MALFORMED_RESPONSE; return ERR_DNS_MALFORMED_RESPONSE;

View file

@ -111,6 +111,7 @@
#if BUILDFLAG(ENABLE_DEVICE_BOUND_SESSIONS) #if BUILDFLAG(ENABLE_DEVICE_BOUND_SESSIONS)
#include "net/device_bound_sessions/registration_fetcher_param.h" #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" #include "net/device_bound_sessions/session_service.h"
#endif // BUILDFLAG(ENABLE_DEVICE_BOUND_SESSIONS) #endif // BUILDFLAG(ENABLE_DEVICE_BOUND_SESSIONS)
@ -306,7 +307,7 @@ HttpRequestSSLUpgradeDecision GetMetricForSSLUpgradeDecision(
return is_secure ? HttpRequestSSLUpgradeDecision::kSSLDynamicUpgrade return is_secure ? HttpRequestSSLUpgradeDecision::kSSLDynamicUpgrade
: HttpRequestSSLUpgradeDecision::kInsecureDynamicUpgrade; : HttpRequestSSLUpgradeDecision::kInsecureDynamicUpgrade;
} }
NOTREACHED_NORETURN(); NOTREACHED();
} }
void RecordSTSHistograms(net::SSLUpgradeDecision upgrade_decision, void RecordSTSHistograms(net::SSLUpgradeDecision upgrade_decision,
@ -445,6 +446,9 @@ void URLRequestHttpJob::Start() {
request_info_.is_subframe_document_resource = request_info_.is_subframe_document_resource =
request_->isolation_info().request_type() == request_->isolation_info().request_type() ==
net::IsolationInfo::RequestType::kSubFrame; 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_.load_flags = request_->load_flags();
request_info_.priority_incremental = request_->priority_incremental(); request_info_.priority_incremental = request_->priority_incremental();
request_info_.secure_dns_policy = request_->secure_dns_policy(); request_info_.secure_dns_policy = request_->secure_dns_policy();
@ -496,7 +500,9 @@ bool ShouldBlockAllCookies(PrivacyMode privacy_mode) {
} // namespace } // namespace
void URLRequestHttpJob::MaybeSetSecFetchStorageAccessHeader() { 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; return;
} }
// Avoid attaching the header in cases where the Cookie header is not included // 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; clear_site_data_prevents_cookies_from_being_stored = true;
} }
base::Time response_date; std::optional<base::Time> server_time = GetResponseHeaders()->GetDateValue();
std::optional<base::Time> server_time = std::nullopt;
if (GetResponseHeaders()->GetDateValue(&response_date))
server_time = std::make_optional(response_date);
bool force_ignore_site_for_cookies = bool force_ignore_site_for_cookies =
request_->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) #if BUILDFLAG(ENABLE_DEVICE_BOUND_SESSIONS)
void URLRequestHttpJob::ProcessDeviceBoundSessionsHeader() { 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 = std::vector<device_bound_sessions::RegistrationFetcherParam> params =
device_bound_sessions::RegistrationFetcherParam::CreateIfValid( device_bound_sessions::RegistrationFetcherParam::CreateIfValid(
request_->url(), GetResponseHeaders()); request_url, headers);
if (auto* service = request_->context()->device_bound_session_service()) { for (auto& param : params) {
for (auto& param : params) { service->RegisterBoundSession(std::move(param), request_->isolation_info());
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) #endif // BUILDFLAG(ENABLE_DEVICE_BOUND_SESSIONS)
@ -1585,7 +1600,9 @@ bool URLRequestHttpJob::NeedsAuth() {
} }
bool URLRequestHttpJob::NeedsRetryWithStorageAccess() { 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; return false;
} }
if (!ShouldAddCookieHeader() || if (!ShouldAddCookieHeader() ||
@ -1601,7 +1618,11 @@ bool URLRequestHttpJob::NeedsRetryWithStorageAccess() {
} }
HttpResponseHeaders* headers = request_->response_headers(); 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( void URLRequestHttpJob::SetSharedDictionaryGetter(

View file

@ -2,6 +2,11 @@
// Use of this source code is governed by a BSD-style license that can be // Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file. // found in the LICENSE file.
#ifdef UNSAFE_BUFFERS_BUILD
// TODO(crbug.com/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 // 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 // ported from XCB since we can't use XCB on Ubuntu while its 32-bit support
// remains woefully incomplete. // remains woefully incomplete.
@ -18,6 +23,7 @@
#include "base/command_line.h" #include "base/command_line.h"
#include "base/containers/contains.h" #include "base/containers/contains.h"
#include "base/containers/span.h"
#include "base/location.h" #include "base/location.h"
#include "base/logging.h" #include "base/logging.h"
#include "base/memory/ref_counted_memory.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) { for (int row = 0; row < height; row += rows_per_request) {
size_t n_rows = std::min<size_t>(rows_per_request, height - row); size_t n_rows = std::min<size_t>(rows_per_request, height - row);
auto data = base::MakeRefCounted<base::RefCountedStaticMemory>( 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({ connection->PutImage({
.format = x11::ImageFormat::ZPixmap, .format = x11::ImageFormat::ZPixmap,
.drawable = drawable, .drawable = drawable,
@ -365,14 +371,9 @@ bool GetCustomFramePrefDefault() {
return false; return false;
} }
ui::WindowManagerName wm = GuessWindowManager();
// Never default to using the custom title bar, unless the windows manager is a tiling WM. // 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. // Thorium should integrate, not be a special little snowflake.
if (IsWmTiling(wm)) { return false;
return true;
} else {
return false;
}
} }
bool IsWmTiling(WindowManagerName window_manager) { bool IsWmTiling(WindowManagerName window_manager) {
@ -548,8 +549,7 @@ UMALinuxWindowManager GetWindowManagerUMA() {
case WM_XMONAD: case WM_XMONAD:
return UMALinuxWindowManager::kXmonad; return UMALinuxWindowManager::kXmonad;
} }
NOTREACHED_IN_MIGRATION(); NOTREACHED();
return UMALinuxWindowManager::kOther;
} }
bool IsX11WindowFullScreen(x11::Window window) { bool IsX11WindowFullScreen(x11::Window window) {

View 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

View 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

View 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

View file

@ -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

View file

@ -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