tbb-commits
Threads by month
- ----- 2025 -----
- July
- June
- May
- April
- March
- February
- January
- ----- 2024 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2023 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2022 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2021 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2020 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2019 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2018 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2017 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2016 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2015 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- January
- ----- 2014 -----
- December
- November
- October
- September
- August
- July
- June
- May
- April
- March
- February
- 18606 discussions

[Git][tpo/applications/tor-browser][tor-browser-130.0a1-15.0-1] 199 commits: Bug 1840385 - Do not spoof the OS in HTTP User Agent. r=tjr
by Pier Angelo Vendrame (@pierov) 25 Feb '25
by Pier Angelo Vendrame (@pierov) 25 Feb '25
25 Feb '25
Pier Angelo Vendrame pushed to branch tor-browser-130.0a1-15.0-1 at The Tor Project / Applications / Tor Browser
Commits:
fa918a4f by Pier Angelo Vendrame at 2025-02-24T16:57:24+01:00
Bug 1840385 - Do not spoof the OS in HTTP User Agent. r=tjr
Differential Revision: https://phabricator.services.mozilla.com/D234835
- - - - -
cf31af61 by Filipe Laíns at 2025-02-24T16:57:24+01:00
Bug 1935621 - Fix virtual environment sysconfig path calculation r=firefox-build-system-reviewers,ahochheiden
Signed-off-by: Filipe Laíns <lains(a)riseup.net>
Signed-off-by: Filipe Laíns <lains(a)riseup.net>
Signed-off-by: Filipe Laíns <lains(a)riseup.net>
Differential Revision: https://phabricator.services.mozilla.com/D231480
- - - - -
303dcffb by Henry Wilkes at 2025-02-24T16:57:25+01:00
BB 41454: Move focus after calling openPreferences for a sub-category.
Temporary fix until mozilla bug 1799153 gets a patch upstream.
- - - - -
fdda304d by Henry Wilkes at 2025-02-24T16:57:25+01:00
BB 43072: Add aria label and description to moz-message-bar.
Ensures that moz-message-bar, including notifications, are announced on
Orca.
This addresses upstream bugzilla bug 1895857 and should likely be
replaced when it is fixed.
- - - - -
16d87465 by Henry Wilkes at 2025-02-24T16:57:25+01:00
BB 42739: Use the brand name for profile error messages.
Some messages in profileSelection.properties use gAppData->name as
variable inputs. However, gAppData->name is still "Firefox" for our
base-browser builds, rather than the user-facing browser name. We swap
these instances with the displayed brand name instead.
- - - - -
adef3fbb by hackademix at 2025-02-24T16:57:26+01:00
BB 42194: Fix blank net error page on failed DNS resolution with active proxy.
- - - - -
80dd2e4a by Henry Wilkes at 2025-02-24T16:57:26+01:00
BB 41483: Remove the firefox override for appstrings.properties
Remove this patch after upstream bugzilla bug 1790187
- - - - -
a85c5a9a by hackademix at 2025-02-24T16:57:26+01:00
BB 43101: Deep link to the startup security warning explanation.
- - - - -
d6068ed8 by Marco Simonelli at 2025-02-25T14:49:20+01:00
BB 41459: WebRTC fails to build under mingw (Part 1)
- properly define NOMINMAX for just MSVC builds
- - - - -
3ddc9354 by Marco Simonelli at 2025-02-25T14:49:23+01:00
BB 41459: WebRTC fails to build under mingw (Part 2)
- fixes required to build third_party/libwebrtc
- - - - -
c11a7d4e by Marco Simonelli at 2025-02-25T14:49:23+01:00
BB 41459: WebRTC fails to build under mingw (Part 3)
- fixes required to build third_party/sipcc
- - - - -
ae6b2c65 by Marco Simonelli at 2025-02-25T14:49:24+01:00
BB 41459: WebRTC fails to build under mingw (Part 4)
- fixes requried to build netwerk/sctp
- - - - -
c19ff99e by Marco Simonelli at 2025-02-25T14:49:24+01:00
BB 41459: WebRTC fails to build under mingw (Part 5)
- fixes required to build dom/media/webrtc
- - - - -
c8b90df4 by Marco Simonelli at 2025-02-25T14:49:24+01:00
BB 41459: WebRTC fails to build under mingw (Part 6)
- fixes required to build dom/media/systemservices
- - - - -
65569d4f by june wilde at 2025-02-25T14:49:25+01:00
BB 42758: Fix WebRTC build errors.
- - - - -
0195781e by hackademix at 2025-02-25T14:49:25+01:00
BB 41854: Allow overriding download spam protection.
- - - - -
0bb1f4c3 by hackademix at 2025-02-25T14:49:26+01:00
BB 42832: Download spam prevention exemption for browser extensions.
- - - - -
a3412e91 by Pier Angelo Vendrame at 2025-02-25T14:49:26+01:00
BB 42220: Allow for more file types to be forced-inline.
Firefox allows to open some files in the browser without any
confirmation, but this will result in a disk leak, because the file will
be downloaded to the temporary directory first (and not deleted, in some
cases).
A preference allows PDFs to be opened without being downloaded to disk.
So, we introduce a similar one to do the same for all the files that are
set to be opened automatically in the browser.
- - - - -
e8ad5caf by hackademix at 2025-02-25T14:49:26+01:00
BB 42835: Create an actor to filter file data transfers
- - - - -
98dac41a by Beatriz Rizental at 2025-02-25T14:49:27+01:00
BB 42728: Modify ./mach lint to skip unused linters
- - - - -
0602741d by Gaba at 2025-02-25T14:49:27+01:00
Adding issue and merge request templates
- - - - -
5d94c137 by Richard Pospesel at 2025-02-25T14:49:27+01:00
BB 42683: Create script to generate issue triage csv file from bugzilla query and git logs
- - - - -
1773f588 by Henry Wilkes at 2025-02-25T14:49:28+01:00
BB 42305: Add script to combine translation files across versions.
- - - - -
34809995 by Beatriz Rizental at 2025-02-25T14:49:28+01:00
Add CI for Base Browser
- - - - -
f877ed10 by Pier Angelo Vendrame at 2025-02-25T14:49:28+01:00
Base Browser's .mozconfigs.
Bug 17858: Cannot create incremental MARs for hardened builds.
Define HOST_CFLAGS, etc. to avoid compiling programs such as mbsdiff
(which is part of mar-tools and is not distributed to end-users) with
ASan.
Bug 21849: Don't allow SSL key logging.
Bug 25741 - TBA: Disable features at compile-time
Define MOZ_ANDROID_NETWORK_STATE and MOZ_ANDROID_LOCATION
Bug 27623 - Export MOZILLA_OFFICIAL during desktop builds
This fixes a problem where some preferences had the wrong default value.
Also see bug 27472 where we made a similar fix for Android.
Bug 29859: Disable HLS support for now
Bug 30463: Explicitly disable MOZ_TELEMETRY_REPORTING
Bug 32493: Disable MOZ_SERVICES_HEALTHREPORT
Bug 33734: Set MOZ_NORMANDY to False
Bug 33851: Omit Parental Controls.
Bug 40252: Add --enable-rust-simd to our tor-browser mozconfig files
Bug 41584: Move some configuration options to base-browser level
- - - - -
11504ff8 by Pier Angelo Vendrame at 2025-02-25T14:49:29+01:00
Tweaks to the build system
Bug 40857: Modified the fat .aar creation file
This is a workaround to build fat .aars with the compiling enviornment
disabled.
Mozilla does not use a similar configuration, but either runs a Firefox
build and discards its output, or uses artifacts build.
We might switch to artifact builds too, and drop this patch, or write a
better one to upstream. But until then we need this patch.
See also https://bugzilla.mozilla.org/show_bug.cgi?id=1763770.
Bug 41458: Prevent `mach package-multi-locale` from actually creating a package
macOS builds need some files to be moved around with
./mach package-multi-locale to create multi-locale packages.
The required command isn't exposed through any other mach command.
So, we patch package-multi-locale both to prevent it from failing when
doing official builds and to detect any future changes on it.
- - - - -
9401b693 by Pier Angelo Vendrame at 2025-02-25T14:49:29+01:00
BB 29320: Replace the gnu target with gnullvm for Rust.
- - - - -
3d6b9408 by Pier Angelo Vendrame at 2025-02-25T14:49:29+01:00
BB 42616: Remove VideoCaptureTest.kt.
This is a workaround to fix the GeckoView build with WebRTC disabled.
We should replace this workaround with a proper solution, that
excludes this test when MOZ_WEBRTC is undefined/False.
- - - - -
21872ded by Pier Angelo Vendrame at 2025-02-25T14:49:30+01:00
BB 41108: Remove privileged macOS installation from 102
- - - - -
c7e5f855 by Dan Ballard at 2025-02-25T14:49:30+01:00
BB 41149: Re-enable DLL injection protection in all builds not just nightlies
- - - - -
2a77daf3 by Henry Wilkes at 2025-02-25T14:49:30+01:00
BB 43092: Disable wayland by default in Base Browser.
- - - - -
2c57451b by Matthew Finkel at 2025-02-25T14:49:31+01:00
BB 24796: Comment out excess permissions from GeckoView
The GeckoView AndroidManifest.xml is not preprocessed unlike Fennec's
manifest, so we can't use the ifdef preprocessor guards around the
permissions we do not want. Commenting the permissions is the
next-best-thing.
- - - - -
eb5b6af5 by Matthew Finkel at 2025-02-25T14:49:31+01:00
BB 28125: Prevent non-Necko network connections
- - - - -
1f14a767 by Mike Perry at 2025-02-25T14:49:31+01:00
BB 12974: Disable NTLM and Negotiate HTTP Auth
The Mozilla bugs: https://bugzilla.mozilla.org/show_bug.cgi?id=1046421,
https://bugzilla.mozilla.org/show_bug.cgi?id=1261591, tor-browser#27602
- - - - -
01811991 by cypherpunks1 at 2025-02-25T14:49:32+01:00
BB 40717: Hide Windows SSO in settings
- - - - -
161ab02b by Georg Koppen at 2025-02-25T14:49:32+01:00
BB 16285: Exclude ClearKey system for now
In the past the ClearKey system had not been compiled when specifying
--disable-eme. But that changed and it is even bundled nowadays (see:
Mozilla's bug 1300654). We don't want to ship it right now as the use
case for it is not really visible while the code had security
vulnerabilities in the past.
- - - - -
f3c351a1 by Kathy Brade at 2025-02-25T14:49:32+01:00
BB 21431: Clean-up system extensions shipped in Firefox
Only ship the pdfjs extension.
- - - - -
6e5dacc8 by Henry Wilkes at 2025-02-25T14:49:33+01:00
BB 42831: Remove the shopping components.
- - - - -
44e59e11 by Kathy Brade at 2025-02-25T14:49:33+01:00
BB 33852: Clean up about:logins (LockWise) to avoid mentioning sync, etc.
Hide elements on about:logins that mention sync, "Firefox LockWise", and
Mozilla's LockWise mobile apps.
Disable the "Create New Login" button when security.nocertdb is true.
- - - - -
d8ad8fc9 by Alex Catarineu at 2025-02-25T14:49:33+01:00
BB 41457: Remove Mozilla permissions
Bug 40025: Remove Mozilla add-on install permissions
- - - - -
9c3eecc8 by Kathy Brade at 2025-02-25T14:49:34+01:00
BB 40002: Remove about:ion
Firefox Ion (previously Firefox Pioneer) is an opt-in program in which people
volunteer to participate in studies that collect detailed, sensitive data about
how they use their browser.
Bug 41662: Disable about:sync-logs
Even though we disable sync by default with
`identity.fxaccounts.enabled`, this about: page is still avilable.
We could throw an exception on the constructor of the related
component, but it would result only in an error in the console, without
a visible "this address does not look right" error page.
If we fix the issues with MOZ_SERVICES_SYNC, we can restore the
component.
- - - - -
0e152674 by Morgan at 2025-02-25T14:49:34+01:00
BB 42716: Disable unwanted about: pages
- - - - -
7a480d2e by Arthur Edelstein at 2025-02-25T14:49:34+01:00
BB 26353: Prevent speculative connect that violated FPI.
Connections were observed in the catch-all circuit when
the user entered an https or http URL in the URL bar, or
typed a search term.
- - - - -
0d1265c9 by Alex Catarineu at 2025-02-25T14:49:35+01:00
BB 31740: Remove some unnecessary RemoteSettings instances
More concretely, SearchService.jsm 'hijack-blocklists' and
url-classifier-skip-urls.
Avoid creating instance for 'anti-tracking-url-decoration'.
If prefs are disabling their usage, avoid creating instances for
'cert-revocations' and 'intermediates'.
Do not ship JSON dumps for collections we do not expect to need. For
the ones in the 'main' bucket, this prevents them from being synced
unnecessarily (the code in remote-settings does so for collections
in the main bucket for which a dump or local data exists). For the
collections in the other buckets, we just save some size by not
shipping their dumps.
We also clear the collections database on the v2 -> v3 migration.
- - - - -
7d9e22b6 by cypherpunks1 at 2025-02-25T14:49:35+01:00
BB 41092: Add a RemoteSettings JSON dump for query-stripping
- - - - -
8f00cd24 by cypherpunks1 at 2025-02-25T14:49:35+01:00
BB 42730: Patch RemoteSettings to use only local dumps as a data source
- - - - -
e7ec4fe7 by Pier Angelo Vendrame at 2025-02-25T14:49:36+01:00
BB 41635: Disable the Normandy component
Do not include Normandy at all whenever MOZ_NORMANDY is False.
- - - - -
a9e91c95 by Georg Koppen at 2025-02-25T14:49:36+01:00
BB 30541: Disable WebGL readPixel() for web content
Related Bugzilla: https://bugzilla.mozilla.org/show_bug.cgi?id=1428034
- - - - -
64c033bf by Alex Catarineu at 2025-02-25T14:49:37+01:00
BB 28369: Stop shipping pingsender executable
- - - - -
41709ab6 by Henry Wilkes at 2025-02-25T14:49:37+01:00
BB 42630: Disable LaterRun module.
- - - - -
ad26fc59 by Pier Angelo Vendrame at 2025-02-25T14:49:37+01:00
BB 41599: Always return an empty string as network ID
Firefox computes an internal network ID used to detect network changes
and act consequently (e.g., to improve WebSocket UX).
However, there are a few ways to get this internal network ID, so we
patch them out, to be sure any new code will not be able to use them and
possibly link users.
We also sent a patch to Mozilla to seed the internal network ID, to
prevent any accidental leak in the future.
Upstream: https://bugzilla.mozilla.org/show_bug.cgi?id=1817756
- - - - -
45d3c43d by Pier Angelo Vendrame at 2025-02-25T14:49:38+01:00
BB 43386: Use Firefox in the UA in RFP-exempt request.
XHR requests initiated by extensions are exempt from RFP.
Therefore, they report the actual app name, instead of Firefox, and the
actual Firefox minor version.
This happens whenever the app name has been customized and does not
match a hardcoded "Firefox".
- - - - -
c7310a30 by Richard Pospesel at 2025-02-25T14:49:38+01:00
BB 41327: Disable UrlbarProviderInterventions
- - - - -
d63225f8 by Richard Pospesel at 2025-02-25T14:49:38+01:00
BB 42037: Disable about:firefoxview page
- - - - -
81d6dcd8 by Mike Perry at 2025-02-25T14:49:39+01:00
Firefox preference overrides.
- - - - -
2e718126 by Pier Angelo Vendrame at 2025-02-25T14:49:39+01:00
BB 43140: Tighten up fonts on Linux.
We ship a fontconfig configuration to esnure all Linux users have the
same defaults and reduce the chances of fingerprinting.
We used to add this file in tor-browser-build, but some users might
skip it by using the browser executable without the wrapper script.
Therefore, we decided to activate the file with the FontConfig API
instead of the environment variables.
Bug 41043: Hardcode the UI font on Linux
The mechanism to choose the UI font does not play well with our
fontconfig configuration. As a result, the final criterion to choose
the font for the UI was its version.
Since we hardcode Arimo as a default sans-serif on preferences, we use
it also for the UI. FontConfig will fall back to some other font for
scripts Arimo does not cover as expected (we tested with Japanese).
Bug 43141: Hardcode system-ui to Arimo.
- - - - -
e4939ebc by Pier Angelo Vendrame at 2025-02-25T14:49:39+01:00
BB 41901: Hardcode normalized FontSubstitutes.
Windows has a system to set font aliases through the registry.
This allows some customization that could be used as a fingerprinting
vector.
Moreover, this mechanism is used by Windows itself, and different SKUs
might have different default FontSubstitutes.
- - - - -
cdf96e28 by Pier Angelo Vendrame at 2025-02-25T14:49:40+01:00
BB 43322: Customize the font visibility lists.
Customize the lists of fonts to assign base visibility to in
base browser and derivatives.
Also, rename the files with the upstream lists, to make sure we do not
use them by mistake.
- - - - -
7e8ceb8e by Alex Catarineu at 2025-02-25T14:49:40+01:00
BB 30605: Honor privacy.spoof_english in Android
This checks `privacy.spoof_english` whenever `setLocales` is
called from Fenix side and sets `intl.accept_languages`
accordingly.
Bug 40198: Expose privacy.spoof_english pref in GeckoView
- - - - -
9c6e487e by Pier Angelo Vendrame at 2025-02-25T14:49:40+01:00
BB 42562: Normalized the Accepted Languages on Android.
The OS language might be outside the list of actually supported
languages and it might leak the user's region.
Therefore, we force the locale reported in Accept-Language to match one
we support with translations, even when it means using a not exact
region tag.
- - - - -
1842aac6 by Alex Catarineu at 2025-02-25T14:49:41+01:00
BB 40171: Make WebRequest and GeckoWebExecutor First-Party aware
- - - - -
bc3f9c2c by Alex Catarineu at 2025-02-25T14:49:41+01:00
BB 26345: Hide tracking protection UI
- - - - -
d3e130df by Henry Wilkes at 2025-02-25T14:49:41+01:00
BB 43109: Hide Firefox Relay from settings.
This should remain disabled, see tor-browser#42814.
- - - - -
11ebb0ab by Henry Wilkes at 2025-02-25T14:49:42+01:00
BB 42777: Hide Website Privacy Preferences.
We hide the Website Privacy Preferences section, which controls the
"global privacy control" (GPC) and "do not track" (DNT) settings.
- - - - -
518302c6 by Morgan at 2025-02-25T14:49:42+01:00
BB 42070: Hide "Use smooth scrolling" from settings
- - - - -
d044837e by Arthur Edelstein at 2025-02-25T14:49:42+01:00
BB 18905: Hide unwanted items from help menu
Bug 25660: Remove the "New Private Window" option
- - - - -
37301fd7 by Pier Angelo Vendrame at 2025-02-25T14:49:43+01:00
BB 41739: Remove "Website appearance" from about:preferences.
It is ignored because of RFP and it is confusing for users.
- - - - -
8bcdf151 by Henry Wilkes at 2025-02-25T14:49:43+01:00
BB 43117: Hide "Always underline links" from settings.
- - - - -
f47d3c27 by Pier Angelo Vendrame at 2025-02-25T14:49:43+01:00
BB 42774: Always hide the third-pary certs UI.
- - - - -
f847b89a by Henry Wilkes at 2025-02-25T14:49:44+01:00
BB 43118: Hide feature recommendation (CFR) settings.
- - - - -
45d83061 by Pier Angelo Vendrame at 2025-02-25T14:49:44+01:00
BB 9173: Change the default Firefox profile directory to be relative.
This commit makes Firefox look for the default profile directory in a
directory relative to the binary path.
The directory can be specified through the --with-relative-data-dir.
This is relative to the same directory as the firefox main binary for
Linux and Windows.
On macOS, we remove Contents/MacOS from it.
Or, in other words, the directory is relative to the application
bundle.
This behavior can be overriden at runtime, by placing a file called
system-install adjacent to the firefox main binary (also on macOS).
- - - - -
f50ae4ce by Pier Angelo Vendrame at 2025-02-25T14:49:44+01:00
BB 42773: Replace ~ with the original home.
In Bug 93141, Mozilla started sending users to their home when they type
~ in the URL bar.
On Linux, we change $HOME for various reason, therefore you would be
redirected to the spoofed home directory when typing ~.
So, we check if the original home directory is known, and use that,
instead.
- - - - -
66e1c9d3 by Alex Catarineu at 2025-02-25T14:49:45+01:00
BB 27604: Fix addon issues when moving the profile directory
Bugzilla: https://bugzilla.mozilla.org/show_bug.cgi?id=1429838
- - - - -
e25db85f by Mike Perry at 2025-02-25T14:49:45+01:00
BB 13028: Prevent potential proxy bypass cases.
It looks like these cases should only be invoked in the NSS command line
tools, and not the browser, but I decided to patch them anyway because there
literally is a maze of network function pointers being passed around, and it's
very hard to tell if some random code might not pass in the proper proxied
versions of the networking code here by accident.
Bugzilla: https://bugzilla.mozilla.org/show_bug.cgi?id=1433509
- - - - -
1a47ed0d by Pier Angelo Vendrame at 2025-02-25T14:49:45+01:00
BB 40309: Avoid using regional OS locales
Avoid regional OS locales if the pref
`intl.regional_prefs.use_os_locales` is false but RFP is enabled.
- - - - -
9d7b06aa by Matthew Finkel at 2025-02-25T14:49:46+01:00
BB 40432: Prevent probing installed applications
Bugzilla: https://bugzilla.mozilla.org/show_bug.cgi?id=1711084
- - - - -
4045b051 by cypherpunks1 at 2025-02-25T14:49:46+01:00
BB 33955: When copying an image only copy the image contents to the clipboard
- - - - -
36a213d7 by cypherpunks1 at 2025-02-25T14:49:46+01:00
BB 41791: Omit the source URL when copying page contents to the clipboard
- - - - -
a1eb3fd0 by hackademix at 2025-02-25T14:49:47+01:00
BB 42288: Allow language spoofing in status messages.
- - - - -
921a1d0a by Pier Angelo Vendrame at 2025-02-25T14:49:47+01:00
BB 43196: Remove the vendor name from media notifications on Linux.
Firefox shows "vendor remoteName" as a title of the "... is playing
media" notification on Linux.
However, for our browser the remote name is enough, and prepending the
vendor to it creates a string users usually never see.
- - - - -
aeec6455 by Pier Angelo Vendrame at 2025-02-25T14:49:48+01:00
Base Browser strings
This commit adds all the strings needed by following Base Browser
patches.
- - - - -
0e558592 by Henry Wilkes at 2025-02-25T14:49:48+01:00
BB 42583: Modify moz-support-link for Base Browser.
- - - - -
3a999bf9 by Pier Angelo Vendrame at 2025-02-25T14:49:48+01:00
BB 41369: Improve Firefox language settings for multi-lingual packages
Change the language selector to be sorted by language code, rather than
name, and to display the language code to the user.
Bug 41372: Handle Japanese as a special case in preferences on macOS
Japanese is treated in a special way on macOS. However, seeing the
Japanese language tag could be confusing for users, and moreover the
language name is not localized correctly like other langs.
Bug 41378: Tell users that they can change their language at the first start
With multi-lingual builds, Tor Browser matches the user's system
language, but some users might want to change it.
So, we tell them that it is possible, but only once.
- - - - -
6ade343d by p13dz at 2025-02-25T14:49:49+01:00
BB 40283: Workaround for the file upload bug
- - - - -
2227d03e by hackademix at 2025-02-25T14:49:49+01:00
BB 42019: Empty browser's clipboard on browser shutdown
- - - - -
c4aacdf0 by hackademix at 2025-02-25T14:49:49+01:00
BB 42084: Ensure English spoofing works even if preferences are set out of order.
- - - - -
dc13ae15 by Pier Angelo Vendrame at 2025-02-25T14:49:50+01:00
BB 41930: Remove the UI to customize accept_languages.
- - - - -
fe7c0c0c by hackademix at 2025-02-25T14:49:50+01:00
BB 41434: Letterboxing, improve logging.
- - - - -
47e3259e by hackademix at 2025-02-25T14:49:50+01:00
BB 41434: Letterboxing, preemptively apply margins in a global CSS rule to mitigate race conditions on newly created windows and tabs.
- - - - -
9973f668 by hackademix at 2025-02-25T14:49:51+01:00
BB 31064: Letterboxing, exempt browser extensions.
- - - - -
5d339f09 by hackademix at 2025-02-25T14:49:51+01:00
BB 32411: Letterboxing, exempt view-source: URIs.
- - - - -
d8319739 by hackademix at 2025-02-25T14:49:51+01:00
BB 42574: Letterboxing, exempt pdf.js.
- - - - -
53222df5 by hackademix at 2025-02-25T14:49:52+01:00
BB 32308: Use direct browser sizing for letterboxing.
Bug 30556: align letterboxing with 200x100 new win width stepping
- - - - -
d33e3384 by hackademix at 2025-02-25T14:49:52+01:00
BB 41631: Prevent weird initial window dimensions caused by subpixel computations
- - - - -
5e9f0cd3 by hackademix at 2025-02-25T14:49:52+01:00
BB 41918: Option to reuse last window size when letterboxing is enabled.
- - - - -
f56d4942 by hackademix at 2025-02-25T14:49:53+01:00
BB 41916: Letterboxing preferences UI
- - - - -
9795ed66 by hackademix at 2025-02-25T14:49:53+01:00
BB 41695: Warn on window maximization without letterboxing in RFPHelper module
- - - - -
1d17c457 by hackademix at 2025-02-25T14:49:53+01:00
BB 42443: Shrink window to match letterboxing size when the emtpy area is clicked.
- - - - -
ff47213e by Henry Wilkes at 2025-02-25T14:49:54+01:00
BB 42528: Don't leak system scrollbar size on windows.
- - - - -
4fc8b2be by Henry Wilkes at 2025-02-25T14:49:54+01:00
BB 31575: Disable Firefox Home (Activity Stream)
Treat about:blank as the default home page and new tab page.
Avoid loading AboutNewTab in BrowserGlue.sys.mjs in order
to avoid several network requests that we do not need.
Bug 41624: Disable about:pocket-* pages.
Bug 40144: Redirect about:privatebrowsing to the user's home
- - - - -
c8751aca by Kathy Brade at 2025-02-25T14:49:55+01:00
BB 4234: Use the Firefox Update Process for Base Browser.
Windows: disable "runas" code path in updater (15201).
Windows: avoid writing to the registry (16236).
Also includes fixes for tickets 13047, 13301, 13356, 13594, 15406,
16014, 16909, 24476, and 25909.
Also fix bug 27221: purge the startup cache if the Base Browser
version changed (even if the Firefox version and build ID did
not change), e.g., after a minor Base Browser update.
Also fix 32616: Disable GetSecureOutputDirectoryPath() functionality.
Bug 26048: potentially confusing "restart to update" message
Within the update doorhanger, remove the misleading message that mentions
that windows will be restored after an update is applied, and replace the
"Restart and Restore" button label with an existing
"Restart to update Tor Browser" string.
Bug 28885: notify users that update is downloading
Add a "Downloading Base Browser update" item which appears in the
hamburger (app) menu while the update service is downloading a MAR
file. Before this change, the browser did not indicate to the user
that an update was in progress, which is especially confusing in
Tor Browser because downloads often take some time. If the user
clicks on the new menu item, the about dialog is opened to allow
the user to see download progress.
As part of this fix, the update service was changed to always show
update-related messages in the hamburger menu, even if the update
was started in the foreground via the about dialog or via the
"Check for Tor Browser Update" toolbar menu item. This change is
consistent with the Tor Browser goal of making sure users are
informed about the update process.
Removed #28885 parts of this patch which have been uplifted to Firefox.
- - - - -
c2fa8b3f by Pier Angelo Vendrame at 2025-02-25T14:49:55+01:00
BB 42061: Create an alpha update channel.
- - - - -
dcac0cbe by Nicolas Vigier at 2025-02-25T14:49:55+01:00
BB 41682: Add base-browser nightly mar signing key
- - - - -
dc112f6f by Pier Angelo Vendrame at 2025-02-25T14:49:56+01:00
BB 41603: Customize the creation of MOZ_SOURCE_URL
MOZ_SOURCE_URL is created by combining MOZ_SOURCE_REPO and
MOZ_SOURCE_CHANGESET.
But the code takes for granted that it refers to a Hg instance, so it
combines them as `$MOZ_SOURCE_REPO/rev/$MOZ_SOURCE_CHANGESET`.
With this commit, we change this logic to combine them to create a URL
that is valid for GitLab.
$MOZ_SOURCE_CHANGESET needs to be a commit hash, not a branch or a tag.
If that is needed, we could use /-/tree/, instead of /-/commit/.
- - - - -
0d9a9275 by Pier Angelo Vendrame at 2025-02-25T14:49:56+01:00
BB 41698: Reword the recommendation badges in about:addons
Firefox strings use { -brand-product-name }.
As a result, it seems that the fork is recommending extensions, whereas
AMO curators are doing that.
So, we replace the strings with custom ones that clarify that Mozilla is
recommending them.
We assign the strings with JS because our translation backend does not
support Fluent attributes, yet, but once it does, we should switch to
them, instead.
Upstream bug: https://bugzilla.mozilla.org/show_bug.cgi?id=1825033
- - - - -
c1556f56 by Pier Angelo Vendrame at 2025-02-25T14:49:56+01:00
BB 42438: Tweaks to the migration wizard.
Remove the items not compatible with our features (such as history) from
the migration wizard.
On Linux, allow to specify an alternative home directory, since we
usually change $HOME in our startup script.
- - - - -
41964b3c by Alex Catarineu at 2025-02-25T14:49:57+01:00
BB 40069: Add helpers for message passing with extensions
- - - - -
3c42032c by Matthew Finkel at 2025-02-25T14:49:57+01:00
BB 41598: Prevent NoScript from being removed/disabled.
Bug 40253: Explicitly allow NoScript in Private Browsing mode.
- - - - -
1a7336ea by Henry Wilkes at 2025-02-25T14:49:57+01:00
BB 41581: Hide NoScript extension's toolbar button by default.
This hides it from both the toolbar and the unified extensions panel.
We also hide the unified-extension-button if the panel would be empty:
not including the NoScript button when it is hidden. As a result, this
will be hidden by default until a user installs another extension (or
shows the NoScript button and unpins it).
- - - - -
8acbe7f6 by hackademix at 2025-02-25T14:49:58+01:00
BB 41834: Hide "Can't Be Removed - learn more" menu line for uninstallable add-ons
- - - - -
c5147e23 by Pier Angelo Vendrame at 2025-02-25T14:49:58+01:00
BB 40925: Implemented the Security Level component
This component adds a new Security Level toolbar button which visually
indicates the current global security level via icon (as defined by the
extensions.torbutton.security_slider pref), a drop-down hanger with a
short description of the current security level, and a new section in
the about:preferences#privacy page where users can change their current
security level. In addition, the hanger and the preferences page will
show a visual warning when the user has modified prefs associated with
the security level and provide a one-click 'Restore Defaults' button to
get the user back on recommended settings.
Bug 40125: Expose Security Level pref in GeckoView
- - - - -
a79bfca0 by Pier Angelo Vendrame at 2025-02-25T14:49:58+01:00
BB 40926: Implemented the New Identity feature
- - - - -
0c8cf88c by Henry Wilkes at 2025-02-25T14:49:59+01:00
BB 41736: Customize toolbar for base-browser.
- - - - -
6977534e by Pier Angelo Vendrame at 2025-02-25T14:49:59+01:00
BB 42027: Base Browser migration procedures.
This commit implmenents the the Base Browser's version of _migrateUI.
- - - - -
aabd2a31 by Henry Wilkes at 2025-02-25T14:49:59+01:00
TB 42308: Create README for tor-browser.
We drop the README.txt that comes from Mozilla Firefox and add README.md
for tor-browser.
- - - - -
aba06760 by Richard Pospesel at 2025-02-25T14:50:00+01:00
TB 41649: Create rebase and security backport gitlab issue templates
- - - - -
16916a72 by Beatriz Rizental at 2025-02-25T14:50:00+01:00
Add CI for Tor Browser
- - - - -
cfc05127 by Richard Pospesel at 2025-02-25T14:50:01+01:00
TB 41089: Add tor-browser build scripts + Makefile to tor-browser
- - - - -
40eb9c75 by Henry Wilkes at 2025-02-25T14:50:01+01:00
TB 41803: Add some developer tools for working on tor-browser.
- - - - -
bd3674b1 by Kathy Brade at 2025-02-25T14:50:01+01:00
TB 11641: Disable remoting by default.
Unless the -osint command line flag is used, the browser now defaults
to the equivalent of -no-remote. There is a new -allow-remote flag that
may be used to restore the original (Firefox-like) default behavior.
- - - - -
876a342c by Alex Catarineu at 2025-02-25T14:50:02+01:00
Add TorStrings module for localization
- - - - -
16243a58 by Henry Wilkes at 2025-02-25T14:50:02+01:00
Tor Browser strings
This commit adds all the strings needed for Tor Browser patches.
- - - - -
bb462dcb by Henry Wilkes at 2025-02-25T14:50:02+01:00
Tor Browser localization migration scripts.
- - - - -
1a8f2c29 by Mike Perry at 2025-02-25T14:50:03+01:00
TB 2176: Rebrand Firefox to TorBrowser
See also Bugs #5194, #7187, #8115, #8219.
This patch does some basic renaming of Firefox to TorBrowser. The rest of the
branding is done by images and icons.
Also fix bug 27905.
Bug 25702: Update Tor Browser icon to follow design guidelines
- Updated all of the branding in /browser/branding/official with new 'stable'
icon series.
- Updated /extensions/onboarding/content/img/tor-watermark.png with new icon and
add the source svg in the same directory
- Copied /browser/branding/official over /browser/branding/nightly and the new
/browser/branding/alpha directories. Replaced content with 'nightly' and
'alpha' icon series.
Updated VisualElements_70.png and VisualElements_150.png with updated icons in
each branding directory (fixes #22654)
- Updated firefox.VisualElementsManfiest.xml with updated colors in each
branding directory
- Added firefox.svg to each branding directory from which all the other icons
are derived (apart from document.icns and document.ico)
- Added default256.png and default512.png icons
- Updated aboutTBUpdate.css to point to branding-aware icon128.png and removed
original icon
- Use the Tor Browser icon within devtools/client/themes/images/.
Bug 30631: Blurry Tor Browser icon on macOS app switcher
It would seem the png2icns tool does not generate correct icns files and
so on macOS the larger icons were missing resulting in blurry icons in
the OS chrome. Regenerated the padded icons in a macOS VM using
iconutil.
Bug 28196: preparations for using torbutton tor-browser-brand.ftl
A small change to Fluent FileSource class is required so that we
can register a new source without its supported locales being
counted as available locales for the browser.
Bug 31803: Replaced about:debugging logo with flat version
Bug 21724: Make Firefox and Tor Browser distinct macOS apps
When macOS opens a document or selects a default browser, it sometimes
uses the CFBundleSignature. Changing from the Firefox MOZB signature to
a different signature TORB allows macOS to distinguish between Firefox
and Tor Browser.
Bug 32092: Fix Tor Browser Support link in preferences
For bug 40562, we moved onionPattern* from bug 27476 to here, as
about:tor needs these files but it is included earlier.
Bug 41278: Create Tor Browser styled pdf logo similar to the vanilla Firefox one
Bug 42088: New application icons (used in-app and on linux).
Bug 42087: New application icons (windows).
- - - - -
d585bd39 by Henry Wilkes at 2025-02-25T14:50:03+01:00
Customize moz-toggle for tor-browser.
- - - - -
c6c8663a by Henry Wilkes at 2025-02-25T14:50:03+01:00
TB 43087: Add onion-pattern to be used on Tor pages.
- - - - -
7e7ac2d8 by hackademix at 2025-02-25T14:50:04+01:00
TB 41917: Tor brand-specific styles.
- - - - -
578a112c by Henry Wilkes at 2025-02-25T14:50:04+01:00
TB 41817: tor-browser semantic colors.
- - - - -
c30fb1f5 by Henry Wilkes at 2025-02-25T14:50:04+01:00
TB 42110: Add TorUIUtils module for common tor component methods.
- - - - -
f335397d by Henry Wilkes at 2025-02-25T14:50:05+01:00
Add purple tor version of the loading APNG.
- - - - -
881cd85b by Henry Wilkes at 2025-02-25T14:50:05+01:00
TB 42583: Modify moz-support-link for Tor Browser.
- - - - -
6401a140 by sanketh at 2025-02-25T14:50:05+01:00
TB 40209: Implement Basic Crypto Safety
Adds a CryptoSafety actor which detects when you've copied a crypto
address from a HTTP webpage and shows a warning.
Closes #40209.
Bug 40428: Fix string attribute names
- - - - -
4f73a29a by Mike Perry at 2025-02-25T14:50:06+01:00
TB3: Tor Browser's official .mozconfigs.
Also:
Add an --enable-tor-browser-data-outside-app-dir configure option
Add --with-tor-browser-version configure option
Bug 31457: disable per-installation profiles
The dedicated profiles (per-installation) feature does not interact
well with our bundled profiles on Linux and Windows, and it also causes
multiple profiles to be created on macOS under TorBrowser-Data.
Bug 31935: Disable profile downgrade protection.
Since Tor Browser does not support more than one profile, disable
the prompt and associated code that offers to create one when a
version downgrade situation is detected.
Add --enable-tor-browser-update build option
Bug 40793: moved Tor configuration options from old-configure.in to moz.configure
Bug 41584: Move some configuration options to base-browser level
- - - - -
93693f93 by Henry Wilkes at 2025-02-25T14:50:06+01:00
TB 41340: Enable TOR_BROWSER_NIGHTLY_BUILD features for dev and nightly builds
tor-browser#41285: Enable fluent warnings.
- - - - -
e042a3f9 by Pier Angelo Vendrame at 2025-02-25T14:50:06+01:00
TB 40562: Added Tor Browser preferences to 000-tor-browser.js
Before reordering patches, we used to keep the Tor-related patches
(torbutton and tor-launcher) at the beginning.
After that issue, we decided to move them towards the end.
In addition to that, we have decided to move Tor Browser-only
preferences there, too, to make Base Browser-only fixups easier to
apply.
- - - - -
e421d06f by Pier Angelo Vendrame at 2025-02-25T14:50:07+01:00
TB 13252: Customize profile management on macOS
On macOS we allow both portable mode and system installation.
However, in the latter case, we customize Firefox's directories to
match the hierarchy we use for the portable mode.
Also, display an informative error message if the TorBrowser-Data
directory cannot be created due to an "access denied" or a
"read only volume" error.
- - - - -
3cffae8c by Pier Angelo Vendrame at 2025-02-25T14:50:07+01:00
TB 40933: Add tor-launcher functionality
Bug 41926: Reimplement the control port
- - - - -
9b3dce99 by Cecylia Bocovich at 2025-02-25T14:50:08+01:00
Lox integration
- - - - -
0d98fab6 by Richard Pospesel at 2025-02-25T14:50:08+01:00
TB 40597: Implement TorSettings module
- migrated in-page settings read/write implementation from about:preferences#tor
to the TorSettings module
- TorSettings initially loads settings from the tor daemon, and saves them to
firefox prefs
- TorSettings notifies observers when a setting has changed; currently only
QuickStart notification is implemented for parity with previous preference
notify logic in about:torconnect and about:preferences#tor
- about:preferences#tor, and about:torconnect now read and write settings
thorugh the TorSettings module
- all tor settings live in the torbrowser.settings.* preference branch
- removed unused pref modify permission for about:torconnect content page from
AsyncPrefs.jsm
Bug 40645: Migrate Moat APIs to Moat.jsm module
- - - - -
b2629d0d by Arthur Edelstein at 2025-02-25T14:50:08+01:00
TB 3455: Add DomainIsolator, for isolating circuit by domain.
Add an XPCOM component that registers a ProtocolProxyChannelFilter
which sets the username/password for each web request according to
url bar domain.
Bug 9442: Add New Circuit button
Bug 13766: Set a 10 minute circuit dirty timeout for the catch-all circ.
Bug 19206: Include a 128 bit random tag as part of the domain isolator nonce.
Bug 19206: Clear out the domain isolator state on `New Identity`.
Bug 21201.2: Isolate by firstPartyDomain from OriginAttributes
Bug 21745: Fix handling of catch-all circuit
Bug 41741: Refactor the domain isolator and new circuit
- - - - -
6054836b by Henry Wilkes at 2025-02-25T14:50:09+01:00
TB 41600: Add a tor circuit display panel.
- - - - -
c088c8d4 by Pier Angelo Vendrame at 2025-02-25T14:50:09+01:00
TB 42247: Android helpers for the TorProvider
GeckoView is missing some API we use on desktop for the integration
with the tor daemon, such as subprocess.
Therefore, we need to implement them in Java and plumb the data
back and forth between JS and Java.
- - - - -
fe23600a by hackademix at 2025-02-25T14:50:10+01:00
TB 8324: Prevent DNS proxy bypasses caused by Drag&Drop
Bug 41613: Skip Drang & Drop filtering for DNS-safe URLs
- - - - -
f73495a6 by Matthew Finkel at 2025-02-25T14:50:10+01:00
TB 25741: TBA: Disable GeckoNetworkManager
The browser should not need information related to the network
interface or network state, tor should take care of that.
- - - - -
4220c609 by Pier Angelo Vendrame at 2025-02-25T14:50:10+01:00
TB 40807: Added QRCode.js to toolkit/modules
- - - - -
1b9515a6 by Richard Pospesel at 2025-02-25T14:50:11+01:00
TB 31286: Implementation of bridge, proxy, and firewall settings in about:preferences#connection
This patch adds a new about:preferences#connection page which allows
modifying bridge, proxy, and firewall settings from within Tor Browser.
All of the functionality present in tor-launcher's Network
Configuration panel is present:
- Setting built-in bridges
- Requesting bridges from BridgeDB via moat
- Using user-provided bridges
- Configuring SOCKS4, SOCKS5, and HTTP/HTTPS proxies
- Setting firewall ports
- Viewing and Copying Tor's logs
- The Networking Settings in General preferences has been removed
Bug 40774: Update about:preferences page to match new UI designs
- - - - -
a94dbd74 by Richard Pospesel at 2025-02-25T14:50:11+01:00
TB 27476: Implement about:torconnect captive portal within Tor Browser
- implements new about:torconnect page as tor-launcher replacement
- adds new torconnect component to browser
- tor process management functionality remains implemented in tor-launcher through the TorProtocolService module
- adds warning/error box to about:preferences#tor when not connected to tor
Bug 40773: Update the about:torconnect frontend page to match additional UI flows.
Bug 41608: Add a toolbar status button and a urlbar "Connect" button.
- - - - -
57bbf762 by Pier Angelo Vendrame at 2025-02-25T14:50:12+01:00
Temporary changes to about:torconnect for Android.
We are planning of tempoorarily using about:torconnect on Android, until
the native UX is ready.
- - - - -
29489cad by Henry Wilkes at 2025-02-25T14:50:12+01:00
TB 7494: Create local home page for TBB.
Bug 41333: Update about:tor to new design. Including:
+ make the favicon match the branding icon.
+ make the location bar show a search icon.
- - - - -
f7778278 by Pier Angelo Vendrame at 2025-02-25T14:50:12+01:00
TB 41668: Tweaks to the Base Browser updater for Tor Browser
This commit was once part of "Bug 4234: Use the Firefox Update Process
for Tor Browser.".
However, some parts of it were not needed for Base Browser and some
derivative browsers.
Therefore, we extracted from that commit the parts for Tor Browser
legacy, and we add them back to the patch set with this commit.
- - - - -
f781c045 by Kathy Brade at 2025-02-25T14:50:13+01:00
TB 12647: Support symlinks in the updater.
- - - - -
f5e495fd by Georg Koppen at 2025-02-25T14:50:13+01:00
TB 32658: Create a new MAR signing key
It's time for our rotation again: Move the backup key in the front
position and add a new backup key.
Bug 33803: Move our primary nightly MAR signing key to tor-browser
Bug 33803: Add a secondary nightly MAR signing key
- - - - -
5613de84 by Pier Angelo Vendrame at 2025-02-25T14:50:13+01:00
TB 42891: Set the bundled search engine for Tor Browser.
After upstream changes between Firefox 115 and 128, we had to
completely rework the way in which we define our search engines.
This commit replaces the old "Omnibox: Add DDG, Startpage, Disconnect,
Youtube, Twitter; remove Amazon, eBay, bing".
With that commit, we customized a list of addons IDs to ship as
built-in search engines, but then upsteam moved to using only
RemoteSettings.
The configuration has many more fields, and it would be quite long to
include it in the source code. Therefore, we use some local JSON files
and load the settings from them.
- - - - -
055770a5 by Alex Catarineu at 2025-02-25T14:50:14+01:00
TB 40073: Disable remote Public Suffix List fetching
In https://bugzilla.mozilla.org/show_bug.cgi?id=1563246 Firefox implemented
fetching the Public Suffix List via RemoteSettings and replacing the default
one at runtime, which we do not want.
- - - - -
f46d780e by Henry Wilkes at 2025-02-25T14:50:14+01:00
TB 41906: Hide DNS over HTTPS preferences.
- - - - -
4326c45c by Richard Pospesel at 2025-02-25T14:50:15+01:00
TB 23247: Communicating security expectations for .onion
Encrypting pages hosted on Onion Services with SSL/TLS is redundant
(in terms of hiding content) as all traffic within the Tor network is
already fully encrypted. Therefore, serving HTTP pages from an Onion
Service is more or less fine.
Prior to this patch, Tor Browser would mostly treat pages delivered
via Onion Services as well as pages delivered in the ordinary fashion
over the internet in the same way. This created some inconsistencies
in behaviour and misinformation presented to the user relating to the
security of pages delivered via Onion Services:
- HTTP Onion Service pages did not have any 'lock' icon indicating
the site was secure
- HTTP Onion Service pages would be marked as unencrypted in the Page
Info screen
- Mixed-mode content restrictions did not apply to HTTP Onion Service
pages embedding Non-Onion HTTP content
This patch fixes the above issues, and also adds several new 'Onion'
icons to the mix to indicate all of the various permutations of Onion
Services hosted HTTP or HTTPS pages with HTTP or HTTPS content.
Strings for Onion Service Page Info page are pulled from Torbutton's
localization strings.
- - - - -
000ef7b7 by Kathy Brade at 2025-02-25T14:50:15+01:00
TB 30237: Add v3 onion services client authentication prompt
When Tor informs the browser that client authentication is needed,
temporarily load about:blank instead of about:neterror and prompt
for the user's key.
If a correctly formatted key is entered, use Tor's ONION_CLIENT_AUTH_ADD
control port command to add the key (via Torbutton's control port
module) and reload the page.
If the user cancels the prompt, display the standard about:neterror
"Unable to connect" page. This requires a small change to
browser/actors/NetErrorChild.jsm to account for the fact that the
docShell no longer has the failedChannel information. The failedChannel
is used to extract TLS-related error info, which is not applicable
in the case of a canceled .onion authentication prompt.
Add a leaveOpen option to PopupNotifications.show so we can display
error messages within the popup notification doorhanger without
closing the prompt.
Add support for onion services strings to the TorStrings module.
Add support for Tor extended SOCKS errors (Tor proposal 304) to the
socket transport and SOCKS layers. Improved display of all of these
errors will be implemented as part of bug 30025.
Also fixes bug 19757:
Add a "Remember this key" checkbox to the client auth prompt.
Add an "Onion Services Authentication" section within the
about:preferences "Privacy & Security section" to allow
viewing and removal of v3 onion client auth keys that have
been stored on disk.
Also fixes bug 19251: use enhanced error pages for onion service errors.
- - - - -
36479d98 by Alex Catarineu at 2025-02-25T14:50:15+01:00
TB 21952: Implement Onion-Location
Whenever a valid Onion-Location HTTP header (or corresponding HTML
<meta> http-equiv attribute) is found in a document load, we either
redirect to it (if the user opted-in via preference) or notify the
presence of an onionsite alternative with a badge in the urlbar.
- - - - -
70122d2f by Pier Angelo Vendrame at 2025-02-25T14:50:16+01:00
TB 40458: Implement .tor.onion aliases
We have enabled HTTPS-Only mode, therefore we do not need
HTTPS-Everywhere anymore.
However, we want to keep supporting .tor.onion aliases (especially for
securedrop).
Therefore, in this patch we implemented the parsing of HTTPS-Everywhere
rulesets, and the redirect of .tor.onion domains.
Actually, Tor Browser believes they are actual domains. We change them
on the fly on the SOCKS proxy requests to resolve the domain, and on
the code that verifies HTTPS certificates.
- - - - -
5188b51a by Pier Angelo Vendrame at 2025-02-25T14:50:16+01:00
TB 11698: Incorporate Tor Browser Manual pages into Tor Browser
This patch associates the about:manual page to a translated page that
must be injected to browser/omni.ja after the build.
The content must be placed in chrome/browser/content/browser/manual/, so
that is then available at chrome://browser/content/manual/.
We preferred giving absolute freedom to the web team, rather than having
to change the patch in case of changes on the documentation.
- - - - -
320f2905 by Pier Angelo Vendrame at 2025-02-25T14:50:16+01:00
TB 41435: Add a Tor Browser migration function
For now this function only deletes old language packs for which we are
already packaging the strings with the application.
- - - - -
aa263951 by Dan Ballard at 2025-02-25T14:50:17+01:00
TB 40701: Add security warning when downloading a file
Shown in the downloads panel, about:downloads and places.xhtml.
- - - - -
7d4b482c by Henry Wilkes at 2025-02-25T14:50:17+01:00
TB 41736: Customize toolbar for tor-browser.
- - - - -
a7209047 by hackademix at 2025-02-25T14:50:17+01:00
TB 41728: Pin bridges.torproject.org domains to Let's Encrypt's root cert public key
- - - - -
fe717cfe by Richard Pospesel at 2025-02-25T14:50:18+01:00
TB 41822: Unconditionally disable default browser UX in about:preferences
- - - - -
16ba92b6 by Cecylia Bocovich at 2025-02-25T14:50:18+01:00
Temporary commit: manually place generated wasm files
These files are built reproducibly using tor-browser-build: https://gitlab.torproject.org/tpo/applications/tor-browser-build/-/merge_re…
We're manually adding them here while working on the interface, but
eventually these should be placed in the right location using
tor-browser-build.
- - - - -
0fbe5aac by Pier Angelo Vendrame at 2025-02-25T14:50:18+01:00
[android] TBA strings
- - - - -
9228e8b6 by Dan Ballard at 2025-02-25T14:50:19+01:00
TB 42660: Disable ProxySelector.openConnectionWithProxy and NOPify CrashReporter.sendCrashReport
- - - - -
c3c16c9c by Dan Ballard at 2025-02-25T14:50:19+01:00
TB 43006: Disable RFP for Font Visibility on Android
- - - - -
aa7c641f by Matthew Finkel at 2025-02-25T14:50:20+01:00
TB 40005: [android] Modify Default toolbar menu
Originally android-components#40005.
- - - - -
e4c98bb7 by Alex Catarineu at 2025-02-25T14:50:20+01:00
TB 34378: [android] Port external helper app prompting
Together with the corresponding fenix patch, this allows all `startActivity`
that may open external apps to be replaced by `TorUtils.startActivityPrompt`.
Originally, android-components#40007 and fenix#34378.
- - - - -
2c554adf by Alex Catarineu at 2025-02-25T14:50:20+01:00
TB 40002: [android] Ensure system download manager is not used
Originally, android-components#40002.
android-components#40075: Support scoped storage to enable downloads on API < 29
- in android-components!7, we blocked all usage of Scoped
Storage in an attempt to block usage of Android's
DownloadManager, which is known to cause proxy bypasses
- as of Android API 29, downloads will not work without Scoped Storage,
causing all downlaods to fail (see: fenix##40192)
- here, we enable usage of scoped storage for API >= 29, but block
calls to DownloadManager on API < 29
- - - - -
21265289 by Alex Catarineu at 2025-02-25T14:50:21+01:00
TB 40009: [android] Change the default search engines
Originally, android-components#40009.
This matches the search engines from desktop, that is:
DDG as the default, then YouTube, Google, DDGOnion,
Startpage, Twitter, Wikipedia and Yahoo.
android-components#40062: Update DuckDuckGo onion search plugin
- - - - -
c06400e0 by hackademix at 2025-02-25T14:50:21+01:00
TB 42191: [android] Temporary StrictMode relaxation to clear the thumbnail cache.
- - - - -
640bf0af by hackademix at 2025-02-25T14:50:21+01:00
[android] Modify add-on support
Bug 41160: One-time ultimate switch Tor Browser Android to HTTPS-Only.
Bug 41159: Remove HTTPS-Everywhere extension from Tor Browser Android.
Bug 41094: Enable HTTPS-Only Mode by default in Tor Browser Android.
Turn shouldUseHttpsOnly's default to true.
Bug 40225: Bundled extensions don't get updated with Android Tor
Browser updates.
Bug 40030: Install NoScript addon on startup.
Also 40070: Consider storing the list of recommended addons
This implements our own AddonsProvider, which loads the list of
available addons from assets instead of fetching it from an
endpoint.
Also, we hide the uninstall button for builtin addons.
Bug 40058: Hide option for disallowing addon in private mode
- - - - -
b4e50b61 by Alex Catarineu at 2025-02-25T14:50:22+01:00
[android] Modify Addon support
android-components#40011: Hide option for disallowing addons in private mode
android-components#40016: Allow inheriting from AddonCollectionProvider
This will allow implementing our own AddonsProvider in fenix.
- - - - -
6d79353f by Alex Catarineu at 2025-02-25T14:50:22+01:00
TB 40015: [android] Port padlock states for .onion services
Originally, android-components#40015.
- - - - -
bc29645a by Matthew Finkel at 2025-02-25T14:50:22+01:00
[android] Modify Tracking Protection configuration
android-components#40020: Disable third-party cookies
android-components#40024: Disable tracking protection by default
- - - - -
7a84f964 by Matthew Finkel at 2025-02-25T14:50:23+01:00
TB 40023: [android] Stop PrivateNotificationService
Originally, android-components#40023.
- - - - -
62f228c3 by Alex Catarineu at 2025-02-25T14:50:23+01:00
TB 34439 [android]: Isolate Icon loader on Android.
Originally, android-components#34439.
- - - - -
eb3dc2b1 by Matthew Finkel at 2025-02-25T14:50:24+01:00
[android] Disable features and functionality
Bug 33594: Disable data collection by default (Glean)
Bug 40019: Adjust is disabled on Release when data collection is disabled
Bug 34338: Disable the crash reporter
Bug 40014: Neuter Google Advertising ID
Bug 40018: Disable Push service
Bug 40034: Disable PWA onboading
Bug 40072: Disable Tracking Protection
Bug 40061: Do not show "Send to device" in sharing menu
Bug 40109: Reduce requested permissions
Exclude LOCATION and NETWORK_STATE
- - - - -
7cf8efcf by Matthew Finkel at 2025-02-25T14:50:24+01:00
TB 40032 [android]: Set usesCleartextTraffic as false
Originally, fenix#40032.
- - - - -
dca403c6 by Matthew Finkel at 2025-02-25T14:50:24+01:00
[android] Rename as Tor Browser
Bug 40020: Change applicationId
Bug 40020: Change app name
Bug 40020: Change deeplink scheme
Bug 40020: Change App icons
Bug 40073: Use correct branding on About page
Bug 40088: Use Tor Browser logo in migration screen
- - - - -
06b0e5bc by Georg Koppen at 2025-02-25T14:50:25+01:00
[android] Modify build system
Bug 40083: Make locale ordering in BuildConfig deterministic
Bug 40042: Add option do overwrite timestamp in extension version
Bug 40059: Use MOZ_BUILD_DATE for versionCode
At the same time we adapt MOZ_BUILD_DATE to our needs where it is
actually used and not in tor-browser-build. This gives us more
flexibility. See: tor-browser-build#40084.
Bug 40067: Fix reproducibility issue in classes2.dex
We make sure our MOZ_BUILD_DATE gets used as a source for showing date
related information on the Fenix about page.
Bug 40071: Show only supported locales
Bug 40064: Use Gecko Beta for Nightly and Debug variants
Bug 40123: Allow building the instrumented tests apks for variants other than debug
This allows to specify the variant of the instrumented tests via
a `testBuildType` gradle argument. It also applies a workaround for
a R8 issue from https://issuetracker.google.com/issues/140851070.
Bug 40143: Use deterministic date in Test apk
The build config was using Date() when generating the Test apk's
versionName.
- - - - -
88d8ddbb by Matthew Finkel at 2025-02-25T14:50:25+01:00
TB 40185: [android] Use NimbusDisabled
Originally, fenix#40185.
- - - - -
ea3d79a2 by Alex Catarineu at 2025-02-25T14:50:25+01:00
TB 40087 [android]: Implement a switch for spoof English.
Originally, fenix#40087 and android-components#40019.
- - - - -
f263f2e8 by Matthew Finkel at 2025-02-25T14:50:26+01:00
TB 34403 [android]: Disable Normal mode by default.
Originally, fenix#34403.
- - - - -
adc172e1 by Matthew Finkel at 2025-02-25T14:50:26+01:00
TB 40016 [android]: Don't install WebCompat webext.
Originally, fenix#40016.
- - - - -
e4f12a20 by Matthew Finkel at 2025-02-25T14:50:26+01:00
[android] Modify UI/UX
Bug 40015: Modify Home menu
Bug 40016: Hide unwanted Settings
Bug 40016: Modify Default toolbar menu
Bug 40016: Add Donate settings button
Bug 40016: Move Allow Screenshots under Advanced
Bug 40016: Don't install WebCompat webext
Bug 40016: Don't onboard Search Suggestions
Bug 40094: Do not use MasterPasswordTipProvider in HomeFragment
Bug 40095: Hide "Sign in to sync" in bookmarks
Bug 40031: Hide Mozilla-specific items on About page
Bug 40063: Do not sort search engines alphabetically
Bug 40141: Hide EME site permission
Bug 40166: Hide "Normal" tab (again) and Sync tab in TabTray
Bug 40167: Hide "Save to Collection" in menu
Bug 40172: Find the Quit button
Bug 40186: Hide Credit Cards in Settings
Bug 40198: Spoof English toggle now overlaps with locale list
- - - - -
0cf4243b by Matthew Finkel at 2025-02-25T14:50:27+01:00
TB 40026 [android]: Implement Security Level settings on Android.
Originally, fenix#40026.
- - - - -
37e64f07 by Dan Ballard at 2025-02-25T14:50:27+01:00
TB 41972: [android] Disable Mozilla onboarding
- - - - -
1bb1d3b8 by Dan Ballard at 2025-02-25T14:50:28+01:00
TB 41878: [android] Add standalone Tor Bootstrap
- - - - -
d6c330a1 by Matthew Finkel at 2025-02-25T14:50:28+01:00
TB 40041 [android]: Implement Tor Network Settings
Originally, fenix#40041.
- - - - -
c604742f by clairehurst at 2025-02-25T14:50:28+01:00
[android] Implement Android-native Connection Assist UI
- - - - -
9d89cb6a by clairehurst at 2025-02-25T14:50:29+01:00
TB 42655 [android]: Implement "New circuit for this site" on Android
- - - - -
42a2b377 by clairehurst at 2025-02-25T14:50:29+01:00
TB 42089: [android] Remove ability to submit site support requests
- - - - -
7970d87c by clairehurst at 2025-02-25T14:50:29+01:00
[android] Delete unused media
- - - - -
10add324 by clairehurst at 2025-02-25T14:50:30+01:00
[android] Bug_43351: Add function to disable forcing ALL CAPS for the fenix snackbar action button text
This is needed because the default snackbar will force all caps, which can cause problems in some languages. See tor-browser#43351 and bugzilla bug 1935387.
TODO: Remove once the forced all caps is removed by mozilla.
- - - - -
cb57af65 by Beatriz Rizental at 2025-02-25T14:50:30+01:00
TB 43243: [android] Implement Android launch test
Also remove exit call from terminate function.
It causes all espresso tests to crash on exit and otherwise doesn't do anything.
- - - - -
1807 changed files:
- .eslintrc-ignores.js
- .gitignore
- + .gitlab-ci.yml
- + .gitlab/ci/containers/base/Containerfile
- + .gitlab/ci/jobs/lint/helpers.py
- + .gitlab/ci/jobs/lint/lint.yml
- + .gitlab/ci/jobs/startup-test/startup-test-android.py
- + .gitlab/ci/jobs/startup-test/startup-test.py
- + .gitlab/ci/jobs/startup-test/startup-test.yml
- + .gitlab/ci/jobs/update-containers.yml
- + .gitlab/ci/jobs/update-translations.yml
- + .gitlab/ci/mixins.yml
- + .gitlab/issue_templates/Backport Android Security Fixes.md
- + .gitlab/issue_templates/Bugzilla Triage.md
- + .gitlab/issue_templates/Emergency Security Issue.md
- + .gitlab/issue_templates/QA - Android.md
- + .gitlab/issue_templates/QA - Desktop.md
- + .gitlab/issue_templates/Rebase Browser - Alpha.md
- + .gitlab/issue_templates/Rebase Browser - Legacy.md
- + .gitlab/issue_templates/Rebase Browser - Rapid.md
- + .gitlab/issue_templates/Rebase Browser - Stable.md
- + .gitlab/issue_templates/bug.md
- + .gitlab/merge_request_templates/Rebase.md
- + .gitlab/merge_request_templates/default.md
- .prettierignore
- + README.md
- − README.txt
- + browser/actors/CryptoSafetyChild.sys.mjs
- + browser/actors/CryptoSafetyParent.sys.mjs
- − browser/actors/RFPHelperChild.sys.mjs
- − browser/actors/RFPHelperParent.sys.mjs
- browser/actors/moz.build
- browser/app/Makefile.in
- browser/app/macbuild/Contents/Info.plist.in
- browser/app/macbuild/Contents/MacOS-files.in
- browser/app/moz.build
- browser/app/permissions
- + browser/app/profile/000-tor-browser.js
- + browser/app/profile/001-base-profile.js
- browser/app/profile/firefox.js
- browser/base/content/aboutDialog-appUpdater.js
- browser/base/content/aboutDialog.js
- browser/base/content/aboutDialog.xhtml
- + browser/base/content/aboutDialogTor.css
- browser/base/content/appmenu-viewcache.inc.xhtml
- browser/base/content/browser-addons.js
- browser/base/content/browser-context.js
- browser/base/content/browser-init.js
- browser/base/content/browser-menubar.inc
- browser/base/content/browser-places.js
- browser/base/content/browser-safebrowsing.js
- browser/base/content/browser-sets.inc
- browser/base/content/browser-siteIdentity.js
- browser/base/content/browser.js
- browser/base/content/browser.js.globals
- browser/base/content/browser.xhtml
- browser/base/content/default-bookmarks.html
- + browser/base/content/languageNotification.js
- browser/base/content/main-popupset.inc.xhtml
- browser/base/content/navigator-toolbox.inc.xhtml
- browser/base/content/pageinfo/pageInfo.xhtml
- browser/base/content/pageinfo/security.js
- browser/base/content/popup-notifications.inc
- browser/base/content/utilityOverlay.js
- browser/base/jar.mn
- browser/base/moz.build
- browser/branding/branding-common.mozbuild
- + browser/branding/tb-alpha/VisualElements_150.png
- + browser/branding/tb-alpha/VisualElements_70.png
- + browser/branding/tb-alpha/configure.sh
- + browser/branding/tb-alpha/content/about-logo.png
- + browser/branding/tb-alpha/content/about-logo.svg
- + browser/branding/tb-alpha/content/about-logo(a)2x.png
- + browser/branding/tb-alpha/content/about-wordmark.svg
- + browser/branding/tb-alpha/content/about.png
- + browser/branding/tb-alpha/content/aboutDialog.css
- + browser/branding/tb-alpha/content/firefox-wordmark.svg
- + browser/branding/tb-alpha/content/jar.mn
- + browser/branding/tb-alpha/content/moz.build
- + browser/branding/tb-alpha/default128.png
- + browser/branding/tb-alpha/default16.png
- + browser/branding/tb-alpha/default22.png
- + browser/branding/tb-alpha/default24.png
- + browser/branding/tb-alpha/default256.png
- + browser/branding/tb-alpha/default32.png
- + browser/branding/tb-alpha/default48.png
- + browser/branding/tb-alpha/default64.png
- + browser/branding/tb-alpha/document.icns
- + browser/branding/tb-alpha/document.ico
- + browser/branding/tb-alpha/document_pdf.ico
- + browser/branding/tb-alpha/firefox.VisualElementsManifest.xml
- + browser/branding/tb-alpha/firefox.icns
- + browser/branding/tb-alpha/firefox.ico
- + browser/branding/tb-alpha/locales/en-US/brand.ftl
- + browser/branding/tb-alpha/locales/en-US/brand.properties
- + browser/branding/tb-alpha/locales/jar.mn
- + browser/branding/tb-alpha/locales/moz.build
- + browser/branding/tb-alpha/moz.build
- + browser/branding/tb-alpha/newtab.ico
- + browser/branding/tb-alpha/newwindow.ico
- + browser/branding/tb-alpha/pbmode.ico
- + browser/branding/tb-alpha/pref/firefox-branding.js
- + browser/branding/tb-nightly/VisualElements_150.png
- + browser/branding/tb-nightly/VisualElements_70.png
- + browser/branding/tb-nightly/configure.sh
- + browser/branding/tb-nightly/content/about-logo.png
- + browser/branding/tb-nightly/content/about-logo.svg
- + browser/branding/tb-nightly/content/about-logo(a)2x.png
- + browser/branding/tb-nightly/content/about-wordmark.svg
- + browser/branding/tb-nightly/content/about.png
- + browser/branding/tb-nightly/content/aboutDialog.css
- + browser/branding/tb-nightly/content/firefox-wordmark.svg
- + browser/branding/tb-nightly/content/jar.mn
- + browser/branding/tb-nightly/content/moz.build
- + browser/branding/tb-nightly/default128.png
- + browser/branding/tb-nightly/default16.png
- + browser/branding/tb-nightly/default22.png
- + browser/branding/tb-nightly/default24.png
- + browser/branding/tb-nightly/default256.png
- + browser/branding/tb-nightly/default32.png
- + browser/branding/tb-nightly/default48.png
- + browser/branding/tb-nightly/default64.png
- + browser/branding/tb-nightly/document.icns
- + browser/branding/tb-nightly/document.ico
- + browser/branding/tb-nightly/document_pdf.ico
- + browser/branding/tb-nightly/firefox.VisualElementsManifest.xml
- + browser/branding/tb-nightly/firefox.icns
- + browser/branding/tb-nightly/firefox.ico
- + browser/branding/tb-nightly/locales/en-US/brand.ftl
- + browser/branding/tb-nightly/locales/en-US/brand.properties
- + browser/branding/tb-nightly/locales/jar.mn
- + browser/branding/tb-nightly/locales/moz.build
- + browser/branding/tb-nightly/moz.build
- + browser/branding/tb-nightly/newtab.ico
- + browser/branding/tb-nightly/newwindow.ico
- + browser/branding/tb-nightly/pbmode.ico
- + browser/branding/tb-nightly/pref/firefox-branding.js
- + browser/branding/tb-release/VisualElements_150.png
- + browser/branding/tb-release/VisualElements_70.png
- + browser/branding/tb-release/configure.sh
- + browser/branding/tb-release/content/about-logo.png
- + browser/branding/tb-release/content/about-logo.svg
- + browser/branding/tb-release/content/about-logo(a)2x.png
- + browser/branding/tb-release/content/about-wordmark.svg
- + browser/branding/tb-release/content/about.png
- + browser/branding/tb-release/content/aboutDialog.css
- + browser/branding/tb-release/content/firefox-wordmark.svg
- + browser/branding/tb-release/content/jar.mn
- + browser/branding/tb-release/content/moz.build
- + browser/branding/tb-release/default128.png
- + browser/branding/tb-release/default16.png
- + browser/branding/tb-release/default22.png
- + browser/branding/tb-release/default24.png
- + browser/branding/tb-release/default256.png
- + browser/branding/tb-release/default32.png
- + browser/branding/tb-release/default48.png
- + browser/branding/tb-release/default64.png
- + browser/branding/tb-release/document.icns
- + browser/branding/tb-release/document.ico
- + browser/branding/tb-release/document_pdf.ico
- + browser/branding/tb-release/firefox.VisualElementsManifest.xml
- + browser/branding/tb-release/firefox.icns
- + browser/branding/tb-release/firefox.ico
- + browser/branding/tb-release/locales/en-US/brand.ftl
- + browser/branding/tb-release/locales/en-US/brand.properties
- + browser/branding/tb-release/locales/jar.mn
- + browser/branding/tb-release/locales/moz.build
- + browser/branding/tb-release/moz.build
- + browser/branding/tb-release/newtab.ico
- + browser/branding/tb-release/newwindow.ico
- + browser/branding/tb-release/pbmode.ico
- + browser/branding/tb-release/pref/firefox-branding.js
- browser/components/BrowserContentHandler.sys.mjs
- browser/components/BrowserGlue.sys.mjs
- browser/components/about/AboutRedirector.cpp
- browser/components/about/components.conf
- browser/components/aboutlogins/AboutLoginsParent.sys.mjs
- browser/components/aboutlogins/content/aboutLogins.css
- browser/components/aboutlogins/content/aboutLogins.mjs
- browser/components/aboutlogins/content/components/fxaccounts-button.css
- + browser/components/abouttor/AboutTorChild.sys.mjs
- + browser/components/abouttor/AboutTorMessage.sys.mjs
- + browser/components/abouttor/AboutTorParent.sys.mjs
- + browser/components/abouttor/HomepageOverride.sys.mjs
- + browser/components/abouttor/content/1f4e3-megaphone.svg
- + browser/components/abouttor/content/26a1-high-voltage.svg
- + browser/components/abouttor/content/2728-sparkles.svg
- + browser/components/abouttor/content/2764-red-heart.svg
- + browser/components/abouttor/content/aboutTor.css
- + browser/components/abouttor/content/aboutTor.html
- + browser/components/abouttor/content/aboutTor.js
- + browser/components/abouttor/content/dax-logo.svg
- + browser/components/abouttor/jar.mn
- + browser/components/abouttor/moz.build
- browser/components/customizableui/CustomizableUI.sys.mjs
- browser/components/customizableui/content/panelUI.inc.xhtml
- browser/components/downloads/DownloadSpamProtection.sys.mjs
- + browser/components/downloads/DownloadsTorWarning.sys.mjs
- browser/components/downloads/content/contentAreaDownloadsView.js
- browser/components/downloads/content/contentAreaDownloadsView.xhtml
- browser/components/downloads/content/downloads.css
- browser/components/downloads/content/downloads.js
- browser/components/downloads/content/downloadsPanel.inc.xhtml
- browser/components/downloads/moz.build
- browser/components/extensions/parent/ext-browserAction.js
- browser/components/extensions/schemas/chrome_settings_overrides.json
- browser/components/migration/ChromeMigrationUtils.sys.mjs
- browser/components/migration/content/migration-wizard.mjs
- browser/components/moz.build
- + browser/components/newidentity/content/newIdentityDialog.css
- + browser/components/newidentity/content/newIdentityDialog.js
- + browser/components/newidentity/content/newIdentityDialog.xhtml
- + browser/components/newidentity/content/newidentity.js
- + browser/components/newidentity/jar.mn
- + browser/components/newidentity/moz.build
- browser/components/newtab/AboutNewTabService.sys.mjs
- + browser/components/onionservices/OnionAliasStore.sys.mjs
- + browser/components/onionservices/OnionLocationChild.sys.mjs
- + browser/components/onionservices/OnionLocationParent.sys.mjs
- + browser/components/onionservices/TorRequestWatch.sys.mjs
- + browser/components/onionservices/content/authNotificationIcon.inc.xhtml
- + browser/components/onionservices/content/authPopup.inc.xhtml
- + browser/components/onionservices/content/authPreferences.css
- + browser/components/onionservices/content/authPreferences.inc.xhtml
- + browser/components/onionservices/content/authPreferences.js
- + browser/components/onionservices/content/authPrompt.js
- + browser/components/onionservices/content/onionlocation-urlbar.inc.xhtml
- + browser/components/onionservices/content/onionlocation.css
- + browser/components/onionservices/content/onionservices.css
- + browser/components/onionservices/content/savedKeysDialog.js
- + browser/components/onionservices/content/savedKeysDialog.xhtml
- + browser/components/onionservices/jar.mn
- + browser/components/onionservices/moz.build
- browser/components/places/PlacesUIUtils.sys.mjs
- browser/components/places/content/controller.js
- browser/components/places/content/places.css
- browser/components/places/content/places.js
- browser/components/places/content/places.xhtml
- browser/components/preferences/home.inc.xhtml
- browser/components/preferences/home.js
- browser/components/preferences/jar.mn
- + browser/components/preferences/letterboxing-middle-dark.svg
- + browser/components/preferences/letterboxing-middle-light.svg
- + browser/components/preferences/letterboxing-top-dark.svg
- + browser/components/preferences/letterboxing-top-light.svg
- + browser/components/preferences/letterboxing.css
- + browser/components/preferences/letterboxing.inc.xhtml
- + browser/components/preferences/letterboxing.js
- browser/components/preferences/main.inc.xhtml
- browser/components/preferences/main.js
- browser/components/preferences/preferences.js
- browser/components/preferences/preferences.xhtml
- browser/components/preferences/privacy.inc.xhtml
- browser/components/preferences/privacy.js
- browser/components/resistfingerprinting/test/browser/browser_dynamical_window_rounding.js
- browser/components/resistfingerprinting/test/browser/browser_navigator.js
- browser/components/resistfingerprinting/test/browser/browser_navigator_iframes.js
- + browser/components/rulesets/RulesetsChild.sys.mjs
- + browser/components/rulesets/RulesetsParent.sys.mjs
- + browser/components/rulesets/content/aboutRulesets.css
- + browser/components/rulesets/content/aboutRulesets.html
- + browser/components/rulesets/content/aboutRulesets.js
- + browser/components/rulesets/content/securedrop.svg
- + browser/components/rulesets/jar.mn
- + browser/components/rulesets/moz.build
- browser/components/search/SearchSERPTelemetry.sys.mjs
- + browser/components/search/extensions/ddg-onion/favicon.ico
- + browser/components/search/extensions/ddg-onion/manifest.json
- browser/components/search/extensions/ddg/manifest.json
- + browser/components/search/extensions/startpage-onion/favicon.png
- + browser/components/search/extensions/startpage-onion/manifest.json
- + browser/components/search/extensions/startpage/favicon.png
- + browser/components/search/extensions/startpage/manifest.json
- + browser/components/securitylevel/content/securityLevel.js
- + browser/components/securitylevel/content/securityLevelButton.css
- + browser/components/securitylevel/content/securityLevelButton.inc.xhtml
- + browser/components/securitylevel/content/securityLevelIcon.svg
- + browser/components/securitylevel/content/securityLevelPanel.css
- + browser/components/securitylevel/content/securityLevelPanel.inc.xhtml
- + browser/components/securitylevel/content/securityLevelPreferences.css
- + browser/components/securitylevel/content/securityLevelPreferences.inc.xhtml
- + browser/components/securitylevel/jar.mn
- + browser/components/securitylevel/moz.build
- browser/components/shopping/jar.mn
- browser/components/shopping/moz.build
- browser/components/tabbrowser/content/tabbrowser.js
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e6-1f1e8.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e6-1f1e9.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e6-1f1ea.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e6-1f1eb.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e6-1f1ec.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e6-1f1ee.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e6-1f1f1.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e6-1f1f2.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e6-1f1f4.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e6-1f1f6.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e6-1f1f7.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e6-1f1f8.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e6-1f1f9.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e6-1f1fa.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e6-1f1fc.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e6-1f1fd.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e6-1f1ff.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e7-1f1e6.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e7-1f1e7.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e7-1f1e9.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e7-1f1ea.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e7-1f1eb.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e7-1f1ec.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e7-1f1ed.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e7-1f1ee.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e7-1f1ef.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e7-1f1f1.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e7-1f1f2.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e7-1f1f3.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e7-1f1f4.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e7-1f1f6.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e7-1f1f7.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e7-1f1f8.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e7-1f1f9.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e7-1f1fb.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e7-1f1fc.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e7-1f1fe.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e7-1f1ff.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e8-1f1e6.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e8-1f1e8.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e8-1f1e9.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e8-1f1eb.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e8-1f1ec.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e8-1f1ed.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e8-1f1ee.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e8-1f1f0.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e8-1f1f1.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e8-1f1f2.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e8-1f1f3.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e8-1f1f4.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e8-1f1f5.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e8-1f1f7.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e8-1f1fa.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e8-1f1fb.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e8-1f1fc.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e8-1f1fd.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e8-1f1fe.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e8-1f1ff.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e9-1f1ea.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e9-1f1ec.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e9-1f1ef.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e9-1f1f0.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e9-1f1f2.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e9-1f1f4.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1e9-1f1ff.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ea-1f1e6.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ea-1f1e8.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ea-1f1ea.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ea-1f1ec.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ea-1f1ed.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ea-1f1f7.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ea-1f1f8.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ea-1f1f9.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ea-1f1fa.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1eb-1f1ee.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1eb-1f1ef.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1eb-1f1f0.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1eb-1f1f2.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1eb-1f1f4.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1eb-1f1f7.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ec-1f1e6.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ec-1f1e7.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ec-1f1e9.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ec-1f1ea.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ec-1f1eb.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ec-1f1ec.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ec-1f1ed.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ec-1f1ee.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ec-1f1f1.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ec-1f1f2.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ec-1f1f3.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ec-1f1f5.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ec-1f1f6.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ec-1f1f7.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ec-1f1f8.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ec-1f1f9.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ec-1f1fa.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ec-1f1fc.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ec-1f1fe.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ed-1f1f0.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ed-1f1f2.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ed-1f1f3.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ed-1f1f7.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ed-1f1f9.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ed-1f1fa.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ee-1f1e8.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ee-1f1e9.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ee-1f1ea.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ee-1f1f1.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ee-1f1f2.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ee-1f1f3.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ee-1f1f4.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ee-1f1f6.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ee-1f1f7.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ee-1f1f8.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ee-1f1f9.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ef-1f1ea.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ef-1f1f2.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ef-1f1f4.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ef-1f1f5.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f0-1f1ea.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f0-1f1ec.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f0-1f1ed.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f0-1f1ee.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f0-1f1f2.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f0-1f1f3.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f0-1f1f5.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f0-1f1f7.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f0-1f1fc.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f0-1f1fe.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f0-1f1ff.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f1-1f1e6.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f1-1f1e7.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f1-1f1e8.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f1-1f1ee.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f1-1f1f0.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f1-1f1f7.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f1-1f1f8.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f1-1f1f9.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f1-1f1fa.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f1-1f1fb.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f1-1f1fe.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f2-1f1e6.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f2-1f1e8.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f2-1f1e9.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f2-1f1ea.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f2-1f1eb.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f2-1f1ec.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f2-1f1ed.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f2-1f1f0.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f2-1f1f1.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f2-1f1f2.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f2-1f1f3.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f2-1f1f4.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f2-1f1f5.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f2-1f1f6.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f2-1f1f7.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f2-1f1f8.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f2-1f1f9.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f2-1f1fa.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f2-1f1fb.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f2-1f1fc.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f2-1f1fd.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f2-1f1fe.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f2-1f1ff.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f3-1f1e6.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f3-1f1e8.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f3-1f1ea.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f3-1f1eb.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f3-1f1ec.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f3-1f1ee.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f3-1f1f1.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f3-1f1f4.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f3-1f1f5.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f3-1f1f7.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f3-1f1fa.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f3-1f1ff.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f4-1f1f2.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f5-1f1e6.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f5-1f1ea.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f5-1f1eb.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f5-1f1ec.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f5-1f1ed.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f5-1f1f0.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f5-1f1f1.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f5-1f1f2.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f5-1f1f3.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f5-1f1f7.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f5-1f1f8.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f5-1f1f9.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f5-1f1fc.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f5-1f1fe.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f6-1f1e6.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f7-1f1ea.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f7-1f1f4.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f7-1f1f8.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f7-1f1fa.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f7-1f1fc.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f8-1f1e6.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f8-1f1e7.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f8-1f1e8.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f8-1f1e9.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f8-1f1ea.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f8-1f1ec.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f8-1f1ed.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f8-1f1ee.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f8-1f1ef.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f8-1f1f0.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f8-1f1f1.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f8-1f1f2.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f8-1f1f3.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f8-1f1f4.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f8-1f1f7.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f8-1f1f8.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f8-1f1f9.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f8-1f1fb.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f8-1f1fd.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f8-1f1fe.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f8-1f1ff.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f9-1f1e6.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f9-1f1e8.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f9-1f1e9.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f9-1f1eb.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f9-1f1ec.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f9-1f1ed.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f9-1f1ef.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f9-1f1f0.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f9-1f1f1.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f9-1f1f2.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f9-1f1f3.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f9-1f1f4.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f9-1f1f7.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f9-1f1f9.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f9-1f1fb.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f9-1f1fc.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1f9-1f1ff.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1fa-1f1e6.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1fa-1f1ec.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1fa-1f1f2.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1fa-1f1f3.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1fa-1f1f8.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1fa-1f1fe.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1fa-1f1ff.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1fb-1f1e6.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1fb-1f1e8.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1fb-1f1ea.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1fb-1f1ec.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1fb-1f1ee.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1fb-1f1f3.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1fb-1f1fa.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1fc-1f1eb.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1fc-1f1f8.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1fd-1f1f0.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1fe-1f1ea.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1fe-1f1f9.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ff-1f1e6.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ff-1f1f2.svg
- + browser/components/torcircuit/content/tor-circuit-flags/1f1ff-1f1fc.svg
- + browser/components/torcircuit/content/tor-circuit-flags/README.txt
- + browser/components/torcircuit/content/tor-circuit-icon-mask.svg
- + browser/components/torcircuit/content/tor-circuit-node-end.svg
- + browser/components/torcircuit/content/tor-circuit-node-middle.svg
- + browser/components/torcircuit/content/tor-circuit-node-relays.svg
- + browser/components/torcircuit/content/tor-circuit-node-start.svg
- + browser/components/torcircuit/content/tor-circuit-redirect.svg
- + browser/components/torcircuit/content/torCircuitPanel.css
- + browser/components/torcircuit/content/torCircuitPanel.inc.xhtml
- + browser/components/torcircuit/content/torCircuitPanel.js
- + browser/components/torcircuit/jar.mn
- + browser/components/torcircuit/moz.build
- + browser/components/torpreferences/content/bridge-bot.svg
- + browser/components/torpreferences/content/bridge-qr.svg
- + browser/components/torpreferences/content/bridge.svg
- + browser/components/torpreferences/content/bridgeQrDialog.js
- + browser/components/torpreferences/content/bridgeQrDialog.xhtml
- + browser/components/torpreferences/content/bridgemoji/BridgeEmoji.js
- + browser/components/torpreferences/content/bridgemoji/annotations.json
- + browser/components/torpreferences/content/bridgemoji/bridge-emojis.json
- + browser/components/torpreferences/content/bridgemoji/svgs/1f300.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f308.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f30a.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f30b.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f319.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f31f.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f321.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f32d.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f32e.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f332.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f333.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f334.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f335.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f336.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f337.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f339.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f33a.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f33b.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f33d.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f33f.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f341.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f344.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f345.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f346.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f347.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f348.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f349.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f34a.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f34b.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f34c.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f34d.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f34f.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f350.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f351.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f352.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f353.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f354.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f355.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f368.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f369.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f36a.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f36b.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f36c.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f36d.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f37f.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f380.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f381.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f382.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f383.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f388.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f389.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f38f.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f392.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f399.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f39f.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f3a0.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f3a1.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f3a2.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f3a8.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f3ac.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f3af.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f3b2.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f3b6.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f3b7.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f3b8.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f3ba.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f3bb.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f3be.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f3c0.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f3c6.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f3c8.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f3d3.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f3d4.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f3d5.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f3dd.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f3e1.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f3ee.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f3f7.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f3f8.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f3f9.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f40a.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f40c.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f40d.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f417.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f418.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f419.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f41a.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f41b.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f41d.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f41e.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f41f.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f420.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f422.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f425.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f426.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f428.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f42a.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f42c.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f42d.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f42e.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f42f.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f430.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f431.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f432.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f433.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f434.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f435.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f436.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f437.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f43a.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f43b.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f43f.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f441.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f451.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f455.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f457.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f45f.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f47d.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f484.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f488.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f48d.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f48e.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f490.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f4a1.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f4a7.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f4b3.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f4bf.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f4cc.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f4ce.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f4d5.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f4e1.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f4e2.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f4fb.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f50b.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f511.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f525.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f526.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f52c.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f52d.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f52e.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f54a.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f58c.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f58d.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f5ff.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f680.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f681.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f686.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f68b.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f68d.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f695.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f697.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f69a.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f69c.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f6a0.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f6a2.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f6a4.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f6f0.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f6f4.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f6f5.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f6f6.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f6f8.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f6f9.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f6fa.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f6fc.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f916.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f93f.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f941.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f94c.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f94f.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f950.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f951.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f955.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f956.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f95c.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f95d.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f95e.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f965.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f966.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f968.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f96c.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f96d.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f96f.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f980.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f981.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f984.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f986.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f987.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f988.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f989.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f98a.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f98b.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f98c.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f98e.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f98f.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f992.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f993.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f994.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f995.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f998.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f999.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f99a.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f99c.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f99d.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f99e.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f9a3.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f9a4.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f9a5.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f9a6.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f9a7.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f9a9.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f9ad.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f9c1.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f9c3.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f9c5.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f9c7.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f9c9.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f9d9.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f9da.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f9dc.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f9e0.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f9e2.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f9e6.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f9e9.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f9ea.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f9ec.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f9ed.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f9ee.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f9f2.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f9f5.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1f9f9.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1fa73.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1fa80.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1fa81.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1fa83.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1fa90.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1fa91.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1fa95.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1fa97.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1fab6.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1fad0.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1fad2.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/1fad6.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/23f0.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/2600.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/2602.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/2604.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/260e.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/2693.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/2696.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/26bd.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/26f2.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/26f5.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/2708.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/270f.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/2728.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/2744.svg
- + browser/components/torpreferences/content/bridgemoji/svgs/README.txt
- + browser/components/torpreferences/content/builtinBridgeDialog.js
- + browser/components/torpreferences/content/builtinBridgeDialog.xhtml
- + browser/components/torpreferences/content/connectionCategory.inc.xhtml
- + browser/components/torpreferences/content/connectionPane.js
- + browser/components/torpreferences/content/connectionPane.xhtml
- + browser/components/torpreferences/content/connectionSettingsDialog.js
- + browser/components/torpreferences/content/connectionSettingsDialog.xhtml
- + browser/components/torpreferences/content/lox-bridge-icon.svg
- + browser/components/torpreferences/content/lox-bridge-pass.svg
- + browser/components/torpreferences/content/lox-complete-ring.svg
- + browser/components/torpreferences/content/lox-invite-icon.svg
- + browser/components/torpreferences/content/lox-progress-ring.svg
- + browser/components/torpreferences/content/lox-success.svg
- + browser/components/torpreferences/content/loxInviteDialog.js
- + browser/components/torpreferences/content/loxInviteDialog.xhtml
- + browser/components/torpreferences/content/mail.svg
- + browser/components/torpreferences/content/network-broken.svg
- + browser/components/torpreferences/content/network.svg
- + browser/components/torpreferences/content/provideBridgeDialog.js
- + browser/components/torpreferences/content/provideBridgeDialog.xhtml
- + browser/components/torpreferences/content/requestBridgeDialog.js
- + browser/components/torpreferences/content/requestBridgeDialog.xhtml
- + browser/components/torpreferences/content/telegram-logo.svg
- + browser/components/torpreferences/content/torLogDialog.js
- + browser/components/torpreferences/content/torLogDialog.xhtml
- + browser/components/torpreferences/content/torPreferences.css
- + browser/components/torpreferences/jar.mn
- + browser/components/torpreferences/moz.build
- browser/components/urlbar/UrlbarInput.sys.mjs
- browser/components/urlbar/UrlbarProvidersManager.sys.mjs
- browser/components/urlbar/UrlbarUtils.sys.mjs
- browser/components/urlbar/moz.build
- + browser/config/mozconfigs/base-browser
- + browser/config/mozconfigs/base-browser-android
- + browser/config/mozconfigs/tor-browser
- + browser/config/mozconfigs/tor-browser-android
- browser/confvars.sh
- browser/extensions/moz.build
- + browser/fonts/fonts.conf
- browser/fonts/moz.build
- browser/installer/Makefile.in
- browser/installer/package-manifest.in
- browser/installer/windows/nsis/shared.nsh
- browser/locales/Makefile.in
- − browser/locales/en-US/chrome/overrides/appstrings.properties
- browser/locales/jar.mn
- browser/modules/BrowserWindowTracker.sys.mjs
- browser/modules/HomePage.sys.mjs
- browser/modules/LaterRun.sys.mjs
- + browser/modules/TorUIUtils.sys.mjs
- browser/modules/URILoadingHelper.sys.mjs
- browser/modules/moz.build
- browser/moz.build
- browser/moz.configure
- browser/themes/shared/addons/unified-extensions.css
- browser/themes/shared/browser-shared.css
- browser/themes/shared/controlcenter/panel.css
- browser/themes/shared/downloads/contentAreaDownloadsView.css
- + browser/themes/shared/icons/new_circuit.svg
- + browser/themes/shared/icons/new_identity.svg
- browser/themes/shared/identity-block/identity-block.css
- browser/themes/shared/jar.inc.mn
- browser/themes/shared/notification-icons.css
- browser/themes/shared/preferences/preferences.css
- browser/themes/shared/tabbrowser/tabs.css
- browser/themes/shared/toolbarbutton-icons.css
- + browser/themes/shared/tor-branding.css
- + browser/themes/shared/tor-urlbar-button.css
- build/application.ini.in
- build/moz.build
- build/moz.configure/init.configure
- build/moz.configure/rust.configure
- build/moz.configure/update-programs.configure
- build/moz.configure/windows.configure
- build/variables.py
- config/createprecomplete.py
- devtools/client/aboutdebugging/src/actions/runtimes.js
- devtools/client/netmonitor/src/components/SecurityState.js
- devtools/client/themes/images/aboutdebugging-firefox-logo.svg
- docshell/base/URIFixup.sys.mjs
- docshell/base/nsAboutRedirector.cpp
- docshell/base/nsDocShell.cpp
- docshell/build/components.conf
- dom/base/ContentAreaDropListener.sys.mjs
- dom/base/Document.cpp
- dom/base/Document.h
- dom/base/Navigator.cpp
- dom/base/nsContentUtils.cpp
- dom/base/nsContentUtils.h
- dom/base/nsCopySupport.cpp
- dom/base/nsGlobalWindowOuter.cpp
- dom/base/nsNodeInfoManager.cpp
- dom/canvas/ClientWebGLContext.cpp
- dom/ipc/BrowserParent.cpp
- dom/ipc/BrowserParent.h
- dom/ipc/PBrowser.ipdl
- dom/ipc/WindowGlobalActor.cpp
- dom/ipc/WindowGlobalChild.cpp
- dom/locales/moz.build
- dom/media/systemservices/video_engine/desktop_device_info.cc
- dom/media/webrtc/libwebrtcglue/VideoConduit.cpp
- dom/media/webrtc/sdp/RsdparsaSdpAttributeList.cpp
- dom/media/webrtc/transport/nrinterfaceprioritizer.cpp
- dom/media/webrtc/transport/sigslot.h
- dom/media/webrtc/transport/test/ice_unittest.cpp
- dom/media/webrtc/transport/third_party/nICEr/src/net/local_addr.c
- dom/media/webrtc/transport/third_party/nICEr/src/net/local_addr.h
- dom/media/webrtc/transport/third_party/nICEr/src/stun/addrs-netlink.c
- dom/media/webrtc/transport/third_party/nICEr/src/stun/addrs-win32.c
- dom/media/webrtc/transport/third_party/nICEr/src/stun/addrs.c
- dom/media/webrtc/transport/third_party/nrappkit/src/log/r_log.c
- dom/media/webrtc/transport/third_party/nrappkit/src/registry/registry.c
- dom/security/nsContentSecurityUtils.cpp
- dom/security/nsMixedContentBlocker.cpp
- dom/webidl/Document.webidl
- dom/websocket/WebSocket.cpp
- dom/xslt/xslt/txMozillaXSLTProcessor.cpp
- dom/xslt/xslt/txXSLTMsgsURL.h
- extensions/auth/nsHttpNegotiateAuth.cpp
- gfx/thebes/StandardFonts-linux.inc → gfx/thebes/StandardFonts-linux-upstream.inc
- + gfx/thebes/StandardFonts-macos-bb.inc
- gfx/thebes/StandardFonts-macos.inc → gfx/thebes/StandardFonts-macos-upstream.inc
- + gfx/thebes/StandardFonts-win10-bb.inc
- gfx/thebes/StandardFonts-win10.inc → gfx/thebes/StandardFonts-win10-upstream.inc
- gfx/thebes/gfxDWriteFontList.cpp
- gfx/thebes/gfxDWriteFontList.h
- gfx/thebes/gfxFcPlatformFontList.cpp
- gfx/thebes/gfxGDIFontList.cpp
- gfx/thebes/gfxMacPlatformFontList.mm
- gfx/thebes/gfxPlatformFontList.cpp
- intl/l10n/Localization.h
- intl/locale/LocaleService.cpp
- intl/strres/nsIStringBundle.idl
- intl/strres/nsStringBundle.cpp
- js/xpconnect/src/xpc.msg
- layout/base/nsLayoutUtils.cpp
- mobile/android/android-components/components/browser/engine-gecko/src/main/java/mozilla/components/browser/engine/gecko/GeckoEngine.kt
- mobile/android/android-components/components/browser/engine-gecko/src/main/java/mozilla/components/browser/engine/gecko/GeckoEngineSession.kt
- mobile/android/android-components/components/browser/engine-gecko/src/main/java/mozilla/components/browser/engine/gecko/cookiebanners/GeckoCookieBannersStorage.kt
- mobile/android/android-components/components/browser/engine-gecko/src/main/java/mozilla/components/browser/engine/gecko/cookiebanners/ReportSiteDomainsRepository.kt
- mobile/android/android-components/components/browser/engine-gecko/src/main/java/mozilla/components/browser/engine/gecko/fetch/GeckoViewFetchClient.kt
- mobile/android/android-components/components/browser/engine-gecko/src/main/java/mozilla/components/browser/engine/gecko/webextension/GeckoWebExtension.kt
- mobile/android/android-components/components/browser/engine-gecko/src/test/java/mozilla/components/browser/engine/gecko/cookiebanners/GeckoCookieBannersStorageTest.kt
- mobile/android/android-components/components/browser/engine-gecko/src/test/java/mozilla/components/browser/engine/gecko/cookiebanners/ReportSiteDomainsRepositoryTest.kt
- mobile/android/android-components/components/browser/icons/src/main/java/mozilla/components/browser/icons/loader/HttpIconLoader.kt
- mobile/android/android-components/components/browser/menu/src/main/java/mozilla/components/browser/menu/WebExtensionBrowserMenuBuilder.kt
- mobile/android/android-components/components/browser/thumbnails/src/main/java/mozilla/components/browser/thumbnails/utils/ThumbnailDiskCache.kt
- mobile/android/android-components/components/browser/toolbar/src/main/java/mozilla/components/browser/toolbar/display/DisplayToolbar.kt
- mobile/android/android-components/components/browser/toolbar/src/main/java/mozilla/components/browser/toolbar/display/SiteSecurityIconView.kt
- mobile/android/android-components/components/browser/toolbar/src/main/res/drawable/mozac_ic_site_security.xml
- mobile/android/android-components/components/browser/toolbar/src/main/res/values/attrs_browser_toolbar.xml
- mobile/android/android-components/components/browser/toolbar2/src/main/java/mozilla/components/browser/toolbar2/display/DisplayToolbar.kt
- mobile/android/android-components/components/browser/toolbar2/src/main/java/mozilla/components/browser/toolbar2/display/SiteSecurityIconView.kt
- mobile/android/android-components/components/browser/toolbar2/src/main/res/drawable/mozac_ic_site_security.xml
- mobile/android/android-components/components/browser/toolbar2/src/main/res/values/attrs_browser_toolbar.xml
- mobile/android/android-components/components/concept/engine/src/main/java/mozilla/components/concept/engine/EngineSession.kt
- mobile/android/android-components/components/concept/engine/src/main/java/mozilla/components/concept/engine/Settings.kt
- mobile/android/android-components/components/concept/engine/src/main/java/mozilla/components/concept/engine/cookiehandling/CookieBannersStorage.kt
- mobile/android/android-components/components/concept/engine/src/main/java/mozilla/components/concept/engine/webextension/WebExtension.kt
- mobile/android/android-components/components/concept/engine/src/test/java/mozilla/components/concept/engine/SettingsTest.kt
- mobile/android/android-components/components/concept/fetch/src/main/java/mozilla/components/concept/fetch/Request.kt
- mobile/android/android-components/components/concept/toolbar/src/main/java/mozilla/components/concept/toolbar/Toolbar.kt
- mobile/android/android-components/components/feature/accounts/build.gradle
- mobile/android/android-components/components/feature/addons/src/main/java/mozilla/components/feature/addons/AddonManager.kt
- mobile/android/android-components/components/feature/addons/src/main/java/mozilla/components/feature/addons/amo/AMOAddonsProvider.kt
- mobile/android/android-components/components/feature/addons/src/main/res/layout/mozac_feature_addons_fragment_dialog_addon_installed.xml
- mobile/android/android-components/components/feature/app-links/build.gradle
- mobile/android/android-components/components/feature/app-links/src/main/java/mozilla/components/feature/app/links/AppLinksFeature.kt
- mobile/android/android-components/components/feature/app-links/src/main/java/mozilla/components/feature/app/links/AppLinksUseCases.kt
- mobile/android/android-components/components/feature/awesomebar/src/main/java/mozilla/components/feature/awesomebar/provider/SessionAutocompleteProvider.kt
- mobile/android/android-components/components/feature/awesomebar/src/main/java/mozilla/components/feature/awesomebar/provider/SessionSuggestionProvider.kt
- mobile/android/android-components/components/feature/contextmenu/src/main/java/mozilla/components/feature/contextmenu/ContextMenuCandidate.kt
- mobile/android/android-components/components/feature/downloads/src/main/java/mozilla/components/feature/downloads/AbstractFetchDownloadService.kt
- mobile/android/android-components/components/feature/downloads/src/main/java/mozilla/components/feature/downloads/DownloadsFeature.kt
- mobile/android/android-components/components/feature/downloads/src/test/java/mozilla/components/feature/downloads/DownloadsFeatureTest.kt
- mobile/android/android-components/components/feature/privatemode/src/main/java/mozilla/components/feature/privatemode/notification/PrivateNotificationFeature.kt
- mobile/android/android-components/components/feature/search/build.gradle
- mobile/android/android-components/components/feature/search/src/main/assets/search/list.json
- + mobile/android/android-components/components/feature/search/src/main/assets/searchplugins/ddg-onion.xml
- mobile/android/android-components/components/feature/search/src/main/assets/searchplugins/ddg.xml
- + mobile/android/android-components/components/feature/search/src/main/assets/searchplugins/startpage-onion.xml
- + mobile/android/android-components/components/feature/search/src/main/assets/searchplugins/startpage.xml
- mobile/android/android-components/components/feature/search/src/main/java/mozilla/components/feature/search/SearchUseCases.kt
- mobile/android/android-components/components/feature/search/src/main/java/mozilla/components/feature/search/ext/SearchEngine.kt
- mobile/android/android-components/components/feature/search/src/main/java/mozilla/components/feature/search/internal/SearchUrlBuilder.kt
- mobile/android/android-components/components/feature/search/src/main/java/mozilla/components/feature/search/storage/SearchEngineReader.kt
- mobile/android/android-components/components/feature/search/src/main/java/mozilla/components/feature/search/telemetry/SerpTelemetryRepository.kt
- mobile/android/android-components/components/feature/search/src/test/java/mozilla/components/feature/search/telemetry/BaseSearchTelemetryTest.kt
- mobile/android/android-components/components/feature/search/src/test/java/mozilla/components/feature/search/telemetry/SerpTelemetryRepositoryTest.kt
- mobile/android/android-components/components/feature/toolbar/src/main/java/mozilla/components/feature/toolbar/ToolbarPresenter.kt
- mobile/android/android-components/components/service/nimbus/src/main/java/mozilla/components/service/nimbus/messaging/NimbusMessagingController.kt
- mobile/android/android-components/components/service/nimbus/src/main/java/mozilla/components/service/nimbus/messaging/NimbusMessagingStorage.kt
- mobile/android/android-components/components/support/ktx/src/main/java/mozilla/components/support/ktx/android/content/Context.kt
- mobile/android/android-components/components/support/ktx/src/main/java/mozilla/components/support/ktx/kotlin/String.kt
- mobile/android/android-components/components/support/remotesettings/src/main/java/mozilla/components/support/remotesettings/RemoteSettingsClient.kt
- + mobile/android/android-components/components/support/utils/src/main/java/mozilla/components/support/utils/TorUtils.kt
- mobile/android/android-components/components/support/webextensions/src/main/java/mozilla/components/support/webextensions/WebExtensionSupport.kt
- + mobile/android/android-components/components/ui/icons/src/main/res/drawable/mozac_ic_onion.xml
- mobile/android/android-components/plugins/config/src/main/java/ConfigPlugin.kt
- mobile/android/android-components/samples/browser/src/main/res/layout/activity_installed_add_on_details.xml
- + mobile/android/app/000-tor-browser-android.js
- mobile/android/app/geckoview-prefs.js
- mobile/android/app/moz.build
- + mobile/android/basebrowser.configure
- mobile/android/branding/beta/locales/jar.mn
- mobile/android/branding/nightly/locales/jar.mn
- mobile/android/branding/official/locales/jar.mn
- mobile/android/branding/unofficial/locales/jar.mn
- mobile/android/confvars.sh
- mobile/android/exoplayer2/src/main/java/org/mozilla/thirdparty/com/google/android/exoplayer2/upstream/DefaultHttpDataSource.java
- mobile/android/fenix/.buildconfig.yml
- mobile/android/fenix/app/build.gradle
- mobile/android/fenix/app/lint-baseline.xml
- mobile/android/fenix/app/onboarding.fml.yaml
- mobile/android/fenix/app/proguard-rules.pro
- + mobile/android/fenix/app/src/androidTest/java/org/mozilla/fenix/AppStartupTest.kt
- mobile/android/fenix/app/src/androidTest/java/org/mozilla/fenix/onboarding/view/OnboardingMapperTest.kt
- mobile/android/fenix/app/src/androidTest/java/org/mozilla/fenix/ui/robots/BrowserRobot.kt
- mobile/android/fenix/app/src/androidTest/java/org/mozilla/fenix/ui/robots/SettingsSubMenuAboutRobot.kt
- + mobile/android/fenix/app/src/beta/ic_launcher-playstore.png
- + mobile/android/fenix/app/src/beta/res/drawable-hdpi/fenix_search_widget.png
- − mobile/android/fenix/app/src/beta/res/drawable-hdpi/fenix_search_widget.webp
- − mobile/android/fenix/app/src/beta/res/drawable/animated_splash_screen.xml
- + mobile/android/fenix/app/src/beta/res/drawable/ic_launcher_background.xml
- − mobile/android/fenix/app/src/beta/res/drawable/ic_launcher_foreground.xml
- + mobile/android/fenix/app/src/beta/res/drawable/ic_launcher_monochrome_foreground.xml
- mobile/android/fenix/app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml → mobile/android/fenix/app/src/beta/res/mipmap-anydpi-v26/ic_launcher.xml
- + mobile/android/fenix/app/src/beta/res/mipmap-anydpi-v26/ic_launcher_monochrome.xml
- + mobile/android/fenix/app/src/beta/res/mipmap-anydpi-v26/ic_launcher_monochrome_round.xml
- + mobile/android/fenix/app/src/beta/res/mipmap-anydpi-v26/ic_launcher_round.xml
- mobile/android/fenix/app/src/beta/res/mipmap-hdpi/ic_launcher.webp
- + mobile/android/fenix/app/src/beta/res/mipmap-hdpi/ic_launcher_foreground.webp
- + mobile/android/fenix/app/src/beta/res/mipmap-hdpi/ic_launcher_monochrome.webp
- + mobile/android/fenix/app/src/beta/res/mipmap-hdpi/ic_launcher_monochrome_round.webp
- mobile/android/fenix/app/src/beta/res/mipmap-hdpi/ic_launcher_round.webp
- mobile/android/fenix/app/src/beta/res/mipmap-mdpi/ic_launcher.webp
- + mobile/android/fenix/app/src/beta/res/mipmap-mdpi/ic_launcher_foreground.webp
- + mobile/android/fenix/app/src/beta/res/mipmap-mdpi/ic_launcher_monochrome.webp
- + mobile/android/fenix/app/src/beta/res/mipmap-mdpi/ic_launcher_monochrome_round.webp
- mobile/android/fenix/app/src/beta/res/mipmap-mdpi/ic_launcher_round.webp
- mobile/android/fenix/app/src/beta/res/mipmap-xhdpi/ic_launcher.webp
- + mobile/android/fenix/app/src/beta/res/mipmap-xhdpi/ic_launcher_foreground.webp
- + mobile/android/fenix/app/src/beta/res/mipmap-xhdpi/ic_launcher_monochrome.webp
- + mobile/android/fenix/app/src/beta/res/mipmap-xhdpi/ic_launcher_monochrome_round.webp
- mobile/android/fenix/app/src/beta/res/mipmap-xhdpi/ic_launcher_round.webp
- mobile/android/fenix/app/src/beta/res/mipmap-xxhdpi/ic_launcher.webp
- + mobile/android/fenix/app/src/beta/res/mipmap-xxhdpi/ic_launcher_foreground.webp
- + mobile/android/fenix/app/src/beta/res/mipmap-xxhdpi/ic_launcher_monochrome.webp
- + mobile/android/fenix/app/src/beta/res/mipmap-xxhdpi/ic_launcher_monochrome_round.webp
- mobile/android/fenix/app/src/beta/res/mipmap-xxhdpi/ic_launcher_round.webp
- mobile/android/fenix/app/src/beta/res/mipmap-xxxhdpi/ic_launcher.webp
- + mobile/android/fenix/app/src/beta/res/mipmap-xxxhdpi/ic_launcher_foreground.webp
- + mobile/android/fenix/app/src/beta/res/mipmap-xxxhdpi/ic_launcher_monochrome.webp
- + mobile/android/fenix/app/src/beta/res/mipmap-xxxhdpi/ic_launcher_monochrome_round.webp
- mobile/android/fenix/app/src/beta/res/mipmap-xxxhdpi/ic_launcher_round.webp
- + mobile/android/fenix/app/src/beta/res/values/ic_launcher_monochrome_background.xml
- mobile/android/fenix/app/src/beta/res/values/static_strings.xml
- mobile/android/fenix/app/src/beta/res/xml/shortcuts.xml
- − mobile/android/fenix/app/src/debug/ic_launcher-web.webp
- + mobile/android/fenix/app/src/debug/res/drawable-hdpi/fenix_search_widget.png
- − mobile/android/fenix/app/src/debug/res/drawable/animated_splash_screen.xml
- + mobile/android/fenix/app/src/debug/res/drawable/ic_launcher_background.xml
- − mobile/android/fenix/app/src/debug/res/drawable/ic_launcher_foreground.xml
- + mobile/android/fenix/app/src/debug/res/drawable/ic_launcher_monochrome_foreground.xml
- + mobile/android/fenix/app/src/debug/res/mipmap-anydpi-v26/ic_launcher.xml
- + mobile/android/fenix/app/src/debug/res/mipmap-anydpi-v26/ic_launcher_monochrome.xml
- + mobile/android/fenix/app/src/debug/res/mipmap-anydpi-v26/ic_launcher_monochrome_round.xml
- + mobile/android/fenix/app/src/debug/res/mipmap-anydpi-v26/ic_launcher_round.xml
- mobile/android/fenix/app/src/debug/res/mipmap-hdpi/ic_launcher.webp
- + mobile/android/fenix/app/src/debug/res/mipmap-hdpi/ic_launcher_foreground.webp
- + mobile/android/fenix/app/src/debug/res/mipmap-hdpi/ic_launcher_monochrome.webp
- + mobile/android/fenix/app/src/debug/res/mipmap-hdpi/ic_launcher_monochrome_round.webp
- mobile/android/fenix/app/src/debug/res/mipmap-hdpi/ic_launcher_round.webp
- mobile/android/fenix/app/src/debug/res/mipmap-mdpi/ic_launcher.webp
- + mobile/android/fenix/app/src/debug/res/mipmap-mdpi/ic_launcher_foreground.webp
- + mobile/android/fenix/app/src/debug/res/mipmap-mdpi/ic_launcher_monochrome.webp
- + mobile/android/fenix/app/src/debug/res/mipmap-mdpi/ic_launcher_monochrome_round.webp
- mobile/android/fenix/app/src/debug/res/mipmap-mdpi/ic_launcher_round.webp
- mobile/android/fenix/app/src/debug/res/mipmap-xhdpi/ic_launcher.webp
- + mobile/android/fenix/app/src/debug/res/mipmap-xhdpi/ic_launcher_foreground.webp
- + mobile/android/fenix/app/src/debug/res/mipmap-xhdpi/ic_launcher_monochrome.webp
- + mobile/android/fenix/app/src/debug/res/mipmap-xhdpi/ic_launcher_monochrome_round.webp
- mobile/android/fenix/app/src/debug/res/mipmap-xhdpi/ic_launcher_round.webp
- mobile/android/fenix/app/src/debug/res/mipmap-xxhdpi/ic_launcher.webp
- + mobile/android/fenix/app/src/debug/res/mipmap-xxhdpi/ic_launcher_foreground.webp
- + mobile/android/fenix/app/src/debug/res/mipmap-xxhdpi/ic_launcher_monochrome.webp
- + mobile/android/fenix/app/src/debug/res/mipmap-xxhdpi/ic_launcher_monochrome_round.webp
- mobile/android/fenix/app/src/debug/res/mipmap-xxhdpi/ic_launcher_round.webp
- mobile/android/fenix/app/src/debug/res/mipmap-xxxhdpi/ic_launcher.webp
- + mobile/android/fenix/app/src/debug/res/mipmap-xxxhdpi/ic_launcher_foreground.webp
- + mobile/android/fenix/app/src/debug/res/mipmap-xxxhdpi/ic_launcher_monochrome.webp
- + mobile/android/fenix/app/src/debug/res/mipmap-xxxhdpi/ic_launcher_monochrome_round.webp
- mobile/android/fenix/app/src/debug/res/mipmap-xxxhdpi/ic_launcher_round.webp
- mobile/android/fenix/app/src/debug/res/values/colors.xml
- + mobile/android/fenix/app/src/debug/res/values/ic_launcher_monochrome_background.xml
- mobile/android/fenix/app/src/debug/res/xml/shortcuts.xml
- mobile/android/fenix/app/src/main/AndroidManifest.xml
- + mobile/android/fenix/app/src/main/assets/common/torrc-defaults
- − mobile/android/fenix/app/src/main/assets/searchplugins/reddit.xml
- − mobile/android/fenix/app/src/main/assets/searchplugins/youtube.xml
- − mobile/android/fenix/app/src/main/ic_launcher-web.webp
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/BrowserDirection.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/FenixApplication.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/HomeActivity.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/IntentReceiverActivity.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/addons/InstalledAddonDetailsFragment.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/browser/BaseBrowserFragment.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/browser/BrowserFragment.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/browser/OpenInAppOnboardingObserver.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/components/Analytics.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/components/BackgroundServices.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/components/Components.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/components/Core.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/components/FenixSnackbar.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/components/NimbusComponents.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/components/NotificationManager.kt
- + mobile/android/fenix/app/src/main/java/org/mozilla/fenix/components/TorBrowserFeatures.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/components/UseCases.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/components/menu/middleware/MenuNavigationMiddleware.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/components/metrics/AdjustMetricsService.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/components/metrics/GleanMetricsService.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/components/metrics/MetricController.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/components/metrics/MetricsUtils.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/components/toolbar/BrowserMenuSignIn.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/components/toolbar/BrowserToolbarCFRPresenter.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/components/toolbar/BrowserToolbarMenuController.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/components/toolbar/DefaultToolbarMenu.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/components/toolbar/ToolbarMenu.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/customtabs/CustomTabToolbarMenu.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/customtabs/PoweredByNotification.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/downloads/dialog/DynamicDownloadDialog.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/experiments/view/ResearchSurfaceSurvey.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/ext/Activity.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/gecko/GeckoProvider.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/home/HomeFragment.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/home/HomeMenu.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/home/HomeMenuView.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/home/intent/HomeDeepLinkIntentProcessor.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/home/pocket/PocketStoriesComposables.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/home/recentsyncedtabs/view/RecentSyncedTab.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/home/sessioncontrol/viewholders/PrivateBrowsingDescriptionViewHolder.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/home/topsites/PagerIndicator.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/home/topsites/TopSiteItemViewHolder.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/home/topsites/TopSites.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/library/bookmarks/BookmarkFragment.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/library/bookmarks/BookmarkItemMenu.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/microsurvey/ui/MicrosurveyCompleted.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/microsurvey/ui/MicrosurveyHeader.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/microsurvey/ui/MicrosurveyRequestPrompt.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/onboarding/FenixOnboarding.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/onboarding/ReEngagementNotificationWorker.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/onboarding/view/OnboardingPage.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/onboarding/view/OnboardingScreen.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/onboarding/view/UpgradeOnboarding.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/search/SearchDialogFragment.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/search/awesomebar/AwesomeBarView.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/HttpsOnlyFragment.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/PhoneFeature.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/SettingsFragment.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/SupportUtils.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/TabsSettingsFragment.kt
- + mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/TorBridgeConfigFragment.kt
- + mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/TorSecurityLevelFragment.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/about/AboutFragment.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/account/AccountUiView.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/advanced/DefaultLocaleSettingsController.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/advanced/LocaleSettingsFragment.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/logins/view/SavedLoginsListView.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/quicksettings/QuickSettingsSheetDialogFragment.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/quicksettings/protections/ProtectionsView.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/quicksettings/protections/cookiebanners/CookieBannerDetailsController.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/quicksettings/protections/cookiebanners/CookieBannerDetailsInteractor.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/quicksettings/protections/cookiebanners/CookieBannerHandlingDetailsView.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/quicksettings/protections/cookiebanners/CookieBannersStorageExt.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/search/SearchEngineFragment.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/sitepermissions/SitePermissionsFragment.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/settings/sitepermissions/SitePermissionsManagePhoneFeatureFragment.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/share/SaveToPDFMiddleware.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/share/ShareController.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/share/ShareFragment.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/shopping/ui/NoAnalysis.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/shopping/ui/ReviewQualityCheckContextualOnboarding.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/shortcut/PwaOnboardingObserver.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/tabstray/TabLayoutMediator.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/tabstray/TabsTrayBanner.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/tabstray/syncedtabs/SyncedTabsList.kt
- + mobile/android/fenix/app/src/main/java/org/mozilla/fenix/tor/ConnectAssistUiState.kt
- + mobile/android/fenix/app/src/main/java/org/mozilla/fenix/tor/QuickStartPreference.kt
- + mobile/android/fenix/app/src/main/java/org/mozilla/fenix/tor/SecurityLevel.kt
- + mobile/android/fenix/app/src/main/java/org/mozilla/fenix/tor/TorBootstrapStatus.kt
- + mobile/android/fenix/app/src/main/java/org/mozilla/fenix/tor/TorBridgeTransports.kt
- + mobile/android/fenix/app/src/main/java/org/mozilla/fenix/tor/TorConnectionAssistFragment.kt
- + mobile/android/fenix/app/src/main/java/org/mozilla/fenix/tor/TorConnectionAssistViewModel.kt
- + mobile/android/fenix/app/src/main/java/org/mozilla/fenix/tor/TorController.kt
- + mobile/android/fenix/app/src/main/java/org/mozilla/fenix/tor/TorControllerGV.kt
- + mobile/android/fenix/app/src/main/java/org/mozilla/fenix/tor/TorLog.kt
- + mobile/android/fenix/app/src/main/java/org/mozilla/fenix/tor/TorLogsComposeFragment.kt
- + mobile/android/fenix/app/src/main/java/org/mozilla/fenix/tor/TorLogsViewModel.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/trackingprotection/ProtectionsStore.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/NotificationBase.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/fenix/utils/Settings.kt
- mobile/android/fenix/app/src/main/java/org/mozilla/gecko/search/SearchWidgetProvider.kt
- + mobile/android/fenix/app/src/main/res/drawable-hdpi/fenix_search_widget.png
- − mobile/android/fenix/app/src/main/res/drawable-hdpi/fenix_search_widget.webp
- − mobile/android/fenix/app/src/main/res/drawable-hdpi/ic_logo_wordmark_normal.webp
- − mobile/android/fenix/app/src/main/res/drawable-hdpi/ic_logo_wordmark_private.webp
- − mobile/android/fenix/app/src/main/res/drawable-hdpi/shopping_no_analysis.webp
- − mobile/android/fenix/app/src/main/res/drawable-hdpi/shopping_onboarding.webp
- − mobile/android/fenix/app/src/main/res/drawable-mdpi/ic_logo_wordmark_normal.webp
- − mobile/android/fenix/app/src/main/res/drawable-mdpi/ic_logo_wordmark_private.webp
- − mobile/android/fenix/app/src/main/res/drawable-mdpi/shopping_no_analysis.webp
- − mobile/android/fenix/app/src/main/res/drawable-mdpi/shopping_onboarding.webp
- − mobile/android/fenix/app/src/main/res/drawable-night-hdpi/shopping_no_analysis.webp
- − mobile/android/fenix/app/src/main/res/drawable-night-hdpi/shopping_onboarding.webp
- − mobile/android/fenix/app/src/main/res/drawable-night-mdpi/shopping_no_analysis.webp
- − mobile/android/fenix/app/src/main/res/drawable-night-mdpi/shopping_onboarding.webp
- − mobile/android/fenix/app/src/main/res/drawable-night-xhdpi/shopping_no_analysis.webp
- − mobile/android/fenix/app/src/main/res/drawable-night-xhdpi/shopping_onboarding.webp
- − mobile/android/fenix/app/src/main/res/drawable-night-xxhdpi/shopping_no_analysis.webp
- − mobile/android/fenix/app/src/main/res/drawable-night-xxhdpi/shopping_onboarding.webp
- − mobile/android/fenix/app/src/main/res/drawable-night-xxxhdpi/shopping_no_analysis.webp
- − mobile/android/fenix/app/src/main/res/drawable-night-xxxhdpi/shopping_onboarding.webp
- − mobile/android/fenix/app/src/main/res/drawable-night/onboarding_ctd_default_browser.xml
- mobile/android/fenix/app/src/main/res/drawable-v23/splash_screen.xml
- − mobile/android/fenix/app/src/main/res/drawable-xhdpi/ic_logo_wordmark_normal.webp
- − mobile/android/fenix/app/src/main/res/drawable-xhdpi/ic_logo_wordmark_private.webp
- − mobile/android/fenix/app/src/main/res/drawable-xhdpi/shopping_no_analysis.webp
- − mobile/android/fenix/app/src/main/res/drawable-xhdpi/shopping_onboarding.webp
- − mobile/android/fenix/app/src/main/res/drawable-xxhdpi/ic_logo_wordmark_normal.webp
- − mobile/android/fenix/app/src/main/res/drawable-xxhdpi/ic_logo_wordmark_private.webp
- − mobile/android/fenix/app/src/main/res/drawable-xxhdpi/shopping_no_analysis.webp
- − mobile/android/fenix/app/src/main/res/drawable-xxhdpi/shopping_onboarding.webp
- − mobile/android/fenix/app/src/main/res/drawable-xxxhdpi/ic_logo_wordmark_normal.webp
- − mobile/android/fenix/app/src/main/res/drawable-xxxhdpi/ic_logo_wordmark_private.webp
- − mobile/android/fenix/app/src/main/res/drawable-xxxhdpi/shopping_no_analysis.webp
- − mobile/android/fenix/app/src/main/res/drawable-xxxhdpi/shopping_onboarding.webp
- − mobile/android/fenix/app/src/main/res/drawable/animated_splash_screen.xml
- + mobile/android/fenix/app/src/main/res/drawable/browser_location.xml
- + mobile/android/fenix/app/src/main/res/drawable/connect.xml
- + mobile/android/fenix/app/src/main/res/drawable/connect_broken.xml
- + mobile/android/fenix/app/src/main/res/drawable/globe_broken.xml
- − mobile/android/fenix/app/src/main/res/drawable/ic_account.xml
- − mobile/android/fenix/app/src/main/res/drawable/ic_account_warning.xml
- + mobile/android/fenix/app/src/main/res/drawable/ic_favorite.xml
- − mobile/android/fenix/app/src/main/res/drawable/ic_firefox.xml
- − mobile/android/fenix/app/src/main/res/drawable/ic_fx_accounts_avatar.xml
- − mobile/android/fenix/app/src/main/res/drawable/ic_launcher_foreground.xml
- − mobile/android/fenix/app/src/main/res/drawable/ic_launcher_monochrome.xml
- − mobile/android/fenix/app/src/main/res/drawable/ic_notification_permission.xml
- − mobile/android/fenix/app/src/main/res/drawable/ic_onboarding_key_features.xml
- − mobile/android/fenix/app/src/main/res/drawable/ic_onboarding_key_features_icons_only.xml
- − mobile/android/fenix/app/src/main/res/drawable/ic_onboarding_search_widget.xml
- − mobile/android/fenix/app/src/main/res/drawable/ic_onboarding_sync.xml
- − mobile/android/fenix/app/src/main/res/drawable/ic_onboarding_welcome.xml
- + mobile/android/fenix/app/src/main/res/drawable/ic_onion_pattern.xml
- − mobile/android/fenix/app/src/main/res/drawable/ic_pocket.xml
- − mobile/android/fenix/app/src/main/res/drawable/ic_scan.xml
- + mobile/android/fenix/app/src/main/res/drawable/ic_screenshot.xml
- − mobile/android/fenix/app/src/main/res/drawable/ic_sign_in.xml
- − mobile/android/fenix/app/src/main/res/drawable/ic_signed_out.xml
- − mobile/android/fenix/app/src/main/res/drawable/ic_status_logo.xml
- − mobile/android/fenix/app/src/main/res/drawable/ic_sync_disconnected.xml
- − mobile/android/fenix/app/src/main/res/drawable/ic_synced_tabs.xml
- + mobile/android/fenix/app/src/main/res/drawable/ic_tor_config_bridge.xml
- + mobile/android/fenix/app/src/main/res/drawable/ic_tor_network_settings.xml
- − mobile/android/fenix/app/src/main/res/drawable/ic_wordmark_logo.webp
- − mobile/android/fenix/app/src/main/res/drawable/ic_wordmark_text_normal.webp
- − mobile/android/fenix/app/src/main/res/drawable/ic_wordmark_text_private.webp
- − mobile/android/fenix/app/src/main/res/drawable/microsurvey_success.xml
- + mobile/android/fenix/app/src/main/res/drawable/new_circuit.xml
- − mobile/android/fenix/app/src/main/res/drawable/onboarding_ctd_default_browser.xml
- − mobile/android/fenix/app/src/main/res/drawable/onboarding_ctd_notification.xml
- − mobile/android/fenix/app/src/main/res/drawable/onboarding_ctd_sync.xml
- − mobile/android/fenix/app/src/main/res/drawable/pocket_vector.xml
- mobile/android/fenix/app/src/main/res/drawable/progress_gradient.xml
- mobile/android/fenix/app/src/main/res/drawable/pager_dot.xml → mobile/android/fenix/app/src/main/res/drawable/rounded_corners.xml
- mobile/android/fenix/app/src/main/res/drawable-night/ic_logo_wordmark_normal.xml → mobile/android/fenix/app/src/main/res/drawable/tor_bootstrap_background_gradient.xml
- mobile/android/fenix/app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml → mobile/android/fenix/app/src/main/res/drawable/tor_onboarding_donate_gradient.xml
- mobile/android/fenix/app/src/main/res/drawable/onboarding_popup_shape.xml → mobile/android/fenix/app/src/main/res/drawable/tor_onboarding_donate_rounded_corners.xml
- mobile/android/fenix/app/src/main/res/layout/component_cookie_banner_details_panel.xml
- mobile/android/fenix/app/src/main/res/layout/component_tabstray2.xml
- mobile/android/fenix/app/src/main/res/layout/fenix_snackbar.xml
- mobile/android/fenix/app/src/main/res/layout/fragment_about.xml
- mobile/android/fenix/app/src/main/res/layout/fragment_create_shortcut.xml
- mobile/android/fenix/app/src/main/res/layout/fragment_home.xml
- mobile/android/fenix/app/src/main/res/layout/fragment_locale_settings.xml
- + mobile/android/fenix/app/src/main/res/layout/fragment_tor_connection_assist.xml
- mobile/android/fenix/app/src/main/res/layout/fragment_turn_on_sync.xml
- mobile/android/fenix/app/src/main/res/layout/onboarding_inactive_tabs_cfr.xml
- mobile/android/fenix/app/src/main/res/mipmap-anydpi-v26/ic_launcher_private.xml → mobile/android/fenix/app/src/main/res/layout/preference_quick_start.xml
- mobile/android/fenix/app/src/main/res/layout/quicksettings_permissions.xml
- mobile/android/fenix/app/src/main/res/layout/quicksettings_protections_panel.xml
- mobile/android/fenix/app/src/main/res/layout/search_widget_extra_small_v1.xml
- mobile/android/fenix/app/src/main/res/layout/search_widget_extra_small_v2.xml
- mobile/android/fenix/app/src/main/res/layout/search_widget_large.xml
- mobile/android/fenix/app/src/main/res/layout/search_widget_medium.xml
- mobile/android/fenix/app/src/main/res/layout/search_widget_small.xml
- mobile/android/fenix/app/src/main/res/layout/sign_in_preference.xml
- − mobile/android/fenix/app/src/main/res/mipmap-anydpi-v26/ic_launcher_private_round.xml
- − mobile/android/fenix/app/src/main/res/mipmap-hdpi/ic_launcher.webp
- − mobile/android/fenix/app/src/main/res/mipmap-hdpi/ic_launcher_round.webp
- − mobile/android/fenix/app/src/main/res/mipmap-mdpi/ic_launcher.webp
- − mobile/android/fenix/app/src/main/res/mipmap-mdpi/ic_launcher_round.webp
- − mobile/android/fenix/app/src/main/res/mipmap-xhdpi/ic_launcher.webp
- − mobile/android/fenix/app/src/main/res/mipmap-xhdpi/ic_launcher_round.webp
- − mobile/android/fenix/app/src/main/res/mipmap-xxhdpi/ic_launcher.webp
- − mobile/android/fenix/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.webp
- − mobile/android/fenix/app/src/main/res/mipmap-xxxhdpi/ic_launcher.webp
- − mobile/android/fenix/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.webp
- mobile/android/fenix/app/src/main/res/navigation/nav_graph.xml
- mobile/android/fenix/app/src/main/res/values-night-v27/styles.xml
- mobile/android/fenix/app/src/main/res/values-night/styles.xml
- mobile/android/fenix/app/src/main/res/values-v24/styles.xml
- mobile/android/fenix/app/src/main/res/values-v27/styles.xml
- mobile/android/fenix/app/src/main/res/values/attrs.xml
- mobile/android/fenix/app/src/main/res/values/colors.xml
- + mobile/android/fenix/app/src/main/res/values/ic_launcher_monochrome_background.xml
- mobile/android/fenix/app/src/main/res/values/preference_keys.xml
- mobile/android/fenix/app/src/main/res/values/static_strings.xml
- mobile/android/fenix/app/src/main/res/values/styles.xml
- + mobile/android/fenix/app/src/main/res/values/torbrowser_strings.xml
- mobile/android/fenix/app/src/main/res/xml/logins_preferences.xml
- mobile/android/fenix/app/src/main/res/xml/preferences.xml
- mobile/android/fenix/app/src/main/res/xml/private_browsing_preferences.xml
- mobile/android/fenix/app/src/main/res/xml/search_settings_preferences.xml
- mobile/android/fenix/app/src/main/res/xml/shortcuts.xml
- mobile/android/fenix/app/src/main/res/xml/site_permissions_details_exceptions_preferences.xml
- mobile/android/fenix/app/src/main/res/xml/site_permissions_preferences.xml
- mobile/android/fenix/app/src/main/res/xml/sync_problem.xml
- + mobile/android/fenix/app/src/main/res/xml/tor_bridge_config_preferences.xml
- + mobile/android/fenix/app/src/main/res/xml/tor_security_level_preferences.xml
- + mobile/android/fenix/app/src/nightly/ic_launcher-playstore.png
- + mobile/android/fenix/app/src/nightly/res/drawable-hdpi/fenix_search_widget.png
- − mobile/android/fenix/app/src/nightly/res/drawable-hdpi/fenix_search_widget.webp
- − mobile/android/fenix/app/src/nightly/res/drawable-hdpi/ic_logo_wordmark_normal.webp
- − mobile/android/fenix/app/src/nightly/res/drawable-hdpi/ic_logo_wordmark_private.webp
- − mobile/android/fenix/app/src/nightly/res/drawable-mdpi/ic_logo_wordmark_normal.webp
- − mobile/android/fenix/app/src/nightly/res/drawable-mdpi/ic_logo_wordmark_private.webp
- − mobile/android/fenix/app/src/nightly/res/drawable-xhdpi/ic_logo_wordmark_normal.webp
- − mobile/android/fenix/app/src/nightly/res/drawable-xhdpi/ic_logo_wordmark_private.webp
- − mobile/android/fenix/app/src/nightly/res/drawable-xxhdpi/ic_logo_wordmark_normal.webp
- − mobile/android/fenix/app/src/nightly/res/drawable-xxhdpi/ic_logo_wordmark_private.webp
- − mobile/android/fenix/app/src/nightly/res/drawable-xxxhdpi/ic_logo_wordmark_normal.webp
- − mobile/android/fenix/app/src/nightly/res/drawable-xxxhdpi/ic_logo_wordmark_private.webp
- − mobile/android/fenix/app/src/nightly/res/drawable/animated_splash_screen.xml
- + mobile/android/fenix/app/src/nightly/res/drawable/ic_launcher_background.xml
- − mobile/android/fenix/app/src/nightly/res/drawable/ic_launcher_foreground.xml
- + mobile/android/fenix/app/src/nightly/res/drawable/ic_launcher_monochrome_foreground.xml
- − mobile/android/fenix/app/src/nightly/res/drawable/ic_wordmark_logo.webp
- − mobile/android/fenix/app/src/nightly/res/drawable/ic_wordmark_text_normal.webp
- − mobile/android/fenix/app/src/nightly/res/drawable/ic_wordmark_text_private.webp
- − mobile/android/fenix/app/src/nightly/res/ic_launcher-web.webp
- + mobile/android/fenix/app/src/nightly/res/mipmap-anydpi-v26/ic_launcher.xml
- + mobile/android/fenix/app/src/nightly/res/mipmap-anydpi-v26/ic_launcher_monochrome.xml
- + mobile/android/fenix/app/src/nightly/res/mipmap-anydpi-v26/ic_launcher_monochrome_round.xml
- + mobile/android/fenix/app/src/nightly/res/mipmap-anydpi-v26/ic_launcher_round.xml
- mobile/android/fenix/app/src/nightly/res/mipmap-hdpi/ic_launcher.webp
- + mobile/android/fenix/app/src/nightly/res/mipmap-hdpi/ic_launcher_foreground.webp
- + mobile/android/fenix/app/src/nightly/res/mipmap-hdpi/ic_launcher_monochrome.webp
- + mobile/android/fenix/app/src/nightly/res/mipmap-hdpi/ic_launcher_monochrome_round.webp
- mobile/android/fenix/app/src/nightly/res/mipmap-hdpi/ic_launcher_round.webp
- mobile/android/fenix/app/src/nightly/res/mipmap-mdpi/ic_launcher.webp
- + mobile/android/fenix/app/src/nightly/res/mipmap-mdpi/ic_launcher_foreground.webp
- + mobile/android/fenix/app/src/nightly/res/mipmap-mdpi/ic_launcher_monochrome.webp
- + mobile/android/fenix/app/src/nightly/res/mipmap-mdpi/ic_launcher_monochrome_round.webp
- mobile/android/fenix/app/src/nightly/res/mipmap-mdpi/ic_launcher_round.webp
- mobile/android/fenix/app/src/nightly/res/mipmap-xhdpi/ic_launcher.webp
- + mobile/android/fenix/app/src/nightly/res/mipmap-xhdpi/ic_launcher_foreground.webp
- + mobile/android/fenix/app/src/nightly/res/mipmap-xhdpi/ic_launcher_monochrome.webp
- + mobile/android/fenix/app/src/nightly/res/mipmap-xhdpi/ic_launcher_monochrome_round.webp
- mobile/android/fenix/app/src/nightly/res/mipmap-xhdpi/ic_launcher_round.webp
- mobile/android/fenix/app/src/nightly/res/mipmap-xxhdpi/ic_launcher.webp
- + mobile/android/fenix/app/src/nightly/res/mipmap-xxhdpi/ic_launcher_foreground.webp
- + mobile/android/fenix/app/src/nightly/res/mipmap-xxhdpi/ic_launcher_monochrome.webp
- + mobile/android/fenix/app/src/nightly/res/mipmap-xxhdpi/ic_launcher_monochrome_round.webp
- mobile/android/fenix/app/src/nightly/res/mipmap-xxhdpi/ic_launcher_round.webp
- mobile/android/fenix/app/src/nightly/res/mipmap-xxxhdpi/ic_launcher.webp
- + mobile/android/fenix/app/src/nightly/res/mipmap-xxxhdpi/ic_launcher_foreground.webp
- + mobile/android/fenix/app/src/nightly/res/mipmap-xxxhdpi/ic_launcher_monochrome.webp
- + mobile/android/fenix/app/src/nightly/res/mipmap-xxxhdpi/ic_launcher_monochrome_round.webp
- mobile/android/fenix/app/src/nightly/res/mipmap-xxxhdpi/ic_launcher_round.webp
- + mobile/android/fenix/app/src/nightly/res/values/ic_launcher_monochrome_background.xml
- mobile/android/fenix/app/src/nightly/res/values/static_strings.xml
- mobile/android/fenix/app/src/nightly/res/xml/shortcuts.xml
- + mobile/android/fenix/app/src/release/ic_launcher-playstore.png
- + mobile/android/fenix/app/src/release/res/drawable-hdpi/fenix_search_widget.png
- − mobile/android/fenix/app/src/release/res/drawable-hdpi/fenix_search_widget.webp
- − mobile/android/fenix/app/src/release/res/drawable-hdpi/ic_logo_wordmark_normal.webp
- − mobile/android/fenix/app/src/release/res/drawable-hdpi/ic_logo_wordmark_private.webp
- − mobile/android/fenix/app/src/release/res/drawable/animated_splash_screen.xml
- + mobile/android/fenix/app/src/release/res/drawable/ic_launcher_background.xml
- − mobile/android/fenix/app/src/release/res/drawable/ic_launcher_foreground.xml
- + mobile/android/fenix/app/src/release/res/drawable/ic_launcher_monochrome_foreground.xml
- + mobile/android/fenix/app/src/release/res/mipmap-anydpi-v26/ic_launcher.xml
- + mobile/android/fenix/app/src/release/res/mipmap-anydpi-v26/ic_launcher_monochrome.xml
- + mobile/android/fenix/app/src/release/res/mipmap-anydpi-v26/ic_launcher_monochrome_round.xml
- + mobile/android/fenix/app/src/release/res/mipmap-anydpi-v26/ic_launcher_round.xml
- mobile/android/fenix/app/src/release/res/mipmap-hdpi/ic_launcher.webp
- + mobile/android/fenix/app/src/release/res/mipmap-hdpi/ic_launcher_foreground.webp
- + mobile/android/fenix/app/src/release/res/mipmap-hdpi/ic_launcher_monochrome.webp
- + mobile/android/fenix/app/src/release/res/mipmap-hdpi/ic_launcher_monochrome_round.webp
- mobile/android/fenix/app/src/release/res/mipmap-hdpi/ic_launcher_round.webp
- mobile/android/fenix/app/src/release/res/mipmap-mdpi/ic_launcher.webp
- + mobile/android/fenix/app/src/release/res/mipmap-mdpi/ic_launcher_foreground.webp
- + mobile/android/fenix/app/src/release/res/mipmap-mdpi/ic_launcher_monochrome.webp
- + mobile/android/fenix/app/src/release/res/mipmap-mdpi/ic_launcher_monochrome_round.webp
- mobile/android/fenix/app/src/release/res/mipmap-mdpi/ic_launcher_round.webp
- mobile/android/fenix/app/src/release/res/mipmap-xhdpi/ic_launcher.webp
- + mobile/android/fenix/app/src/release/res/mipmap-xhdpi/ic_launcher_foreground.webp
- + mobile/android/fenix/app/src/release/res/mipmap-xhdpi/ic_launcher_monochrome.webp
- + mobile/android/fenix/app/src/release/res/mipmap-xhdpi/ic_launcher_monochrome_round.webp
- mobile/android/fenix/app/src/release/res/mipmap-xhdpi/ic_launcher_round.webp
- mobile/android/fenix/app/src/release/res/mipmap-xxhdpi/ic_launcher.webp
- + mobile/android/fenix/app/src/release/res/mipmap-xxhdpi/ic_launcher_foreground.webp
- + mobile/android/fenix/app/src/release/res/mipmap-xxhdpi/ic_launcher_monochrome.webp
- + mobile/android/fenix/app/src/release/res/mipmap-xxhdpi/ic_launcher_monochrome_round.webp
- mobile/android/fenix/app/src/release/res/mipmap-xxhdpi/ic_launcher_round.webp
- mobile/android/fenix/app/src/release/res/mipmap-xxxhdpi/ic_launcher.webp
- + mobile/android/fenix/app/src/release/res/mipmap-xxxhdpi/ic_launcher_foreground.webp
- + mobile/android/fenix/app/src/release/res/mipmap-xxxhdpi/ic_launcher_monochrome.webp
- + mobile/android/fenix/app/src/release/res/mipmap-xxxhdpi/ic_launcher_monochrome_round.webp
- mobile/android/fenix/app/src/release/res/mipmap-xxxhdpi/ic_launcher_round.webp
- + mobile/android/fenix/app/src/release/res/values/ic_launcher_monochrome_background.xml
- mobile/android/fenix/app/src/release/res/values/static_strings.xml
- mobile/android/fenix/app/src/release/res/xml/shortcuts.xml
- mobile/android/fenix/app/src/test/java/org/mozilla/fenix/components/menu/MenuNavigationMiddlewareTest.kt
- mobile/android/fenix/app/src/test/java/org/mozilla/fenix/components/metrics/MetricsUtilsTest.kt
- mobile/android/fenix/app/src/test/java/org/mozilla/fenix/ext/ContextTest.kt
- mobile/android/fenix/app/src/test/java/org/mozilla/fenix/home/HomeMenuViewTest.kt
- mobile/android/fenix/app/src/test/java/org/mozilla/fenix/onboarding/view/OnboardingMapperTest.kt
- mobile/android/fenix/app/src/test/java/org/mozilla/fenix/onboarding/view/OnboardingPageUiDataTest.kt
- mobile/android/fenix/app/src/test/java/org/mozilla/fenix/settings/SupportUtilsTest.kt
- mobile/android/fenix/app/src/test/java/org/mozilla/fenix/settings/quicksettings/ProtectionsViewTest.kt
- mobile/android/fenix/app/src/test/java/org/mozilla/fenix/settings/quicksettings/QuickSettingsSheetDialogFragmentTest.kt
- mobile/android/fenix/app/src/test/java/org/mozilla/fenix/settings/quicksettings/protections/cookiebanners/CookieBannerHandlingDetailsViewTest.kt
- mobile/android/fenix/app/src/test/java/org/mozilla/fenix/settings/quicksettings/protections/cookiebanners/DefaultCookieBannerDetailsControllerTest.kt
- mobile/android/fenix/app/src/test/java/org/mozilla/fenix/share/viewholders/AppViewHolderTest.kt
- mobile/android/fenix/app/src/test/java/org/mozilla/fenix/trackingprotection/ProtectionsStoreTest.kt
- mobile/android/fenix/app/src/test/java/org/mozilla/fenix/utils/SettingsTest.kt
- mobile/android/fenix/build.gradle
- mobile/android/fenix/plugins/fenixdependencies/src/main/java/FenixDependenciesPlugin.kt
- + mobile/android/fenix/tools/tba-fetch-deps.sh
- + mobile/android/fenix/tools/tba-sign-devbuilds.sh
- mobile/android/geckoview/api.txt
- mobile/android/geckoview/build.gradle
- − mobile/android/geckoview/src/androidTest/java/org/mozilla/geckoview/test/VideoCaptureTest.kt
- mobile/android/geckoview/src/main/AndroidManifest.xml
- mobile/android/geckoview/src/main/java/org/mozilla/gecko/media/GeckoMediaDrmBridgeV21.java
- mobile/android/geckoview/src/main/java/org/mozilla/gecko/util/ProxySelector.java
- mobile/android/geckoview/src/main/java/org/mozilla/geckoview/CrashReporter.java
- mobile/android/geckoview/src/main/java/org/mozilla/geckoview/GeckoRuntime.java
- mobile/android/geckoview/src/main/java/org/mozilla/geckoview/GeckoRuntimeSettings.java
- mobile/android/geckoview/src/main/java/org/mozilla/geckoview/GeckoSession.java
- + mobile/android/geckoview/src/main/java/org/mozilla/geckoview/TorIntegrationAndroid.java
- + mobile/android/geckoview/src/main/java/org/mozilla/geckoview/TorSettings.java
- mobile/android/geckoview/src/main/java/org/mozilla/geckoview/WebExtensionController.java
- mobile/android/geckoview/src/main/java/org/mozilla/geckoview/WebRequest.java
- + mobile/android/geckoview/src/main/java/org/mozilla/geckoview/androidlegacysettings/Prefs.java
- + mobile/android/geckoview/src/main/java/org/mozilla/geckoview/androidlegacysettings/TorLegacyAndroidSettings.java
- mobile/android/gradle/with_gecko_binaries.gradle
- mobile/android/installer/package-manifest.in
- mobile/android/moz.configure
- mobile/android/shared-settings.gradle
- mobile/shared/chrome/geckoview/geckoview.js
- mobile/shared/components/geckoview/GeckoViewStartup.sys.mjs
- mobile/shared/modules/geckoview/GeckoViewContent.sys.mjs
- mobile/shared/modules/geckoview/GeckoViewProgress.sys.mjs
- mobile/shared/modules/geckoview/GeckoViewWebExtension.sys.mjs
- modules/libpref/Preferences.cpp
- modules/libpref/init/StaticPrefList.yaml
- modules/libpref/init/all.js
- moz.configure
- + mozconfig-android-aarch64
- + mozconfig-android-all
- + mozconfig-android-armv7
- + mozconfig-android-x86
- + mozconfig-android-x86_64
- + mozconfig-linux-aarch64
- + mozconfig-linux-aarch64-dev
- + mozconfig-linux-arm
- + mozconfig-linux-i686
- + mozconfig-linux-x86_64
- + mozconfig-linux-x86_64-asan
- + mozconfig-linux-x86_64-dev
- + mozconfig-macos
- + mozconfig-macos-dev
- + mozconfig-windows-i686
- + mozconfig-windows-x86_64
- netwerk/base/nsNetUtil.cpp
- netwerk/base/nsSocketTransport2.cpp
- netwerk/build/components.conf
- netwerk/build/nsNetCID.h
- + netwerk/dns/IOnionAliasService.idl
- + netwerk/dns/OnionAliasService.cpp
- + netwerk/dns/OnionAliasService.h
- netwerk/dns/effective_tld_names.dat
- netwerk/dns/moz.build
- netwerk/protocol/http/HttpBaseChannel.cpp
- netwerk/protocol/http/nsHttpHandler.cpp
- netwerk/protocol/http/nsHttpNTLMAuth.cpp
- netwerk/sctp/src/moz.build
- netwerk/sctp/src/netinet/sctp_cc_functions.c
- netwerk/sctp/src/netinet/sctp_indata.c
- netwerk/sctp/src/netinet/sctp_input.c
- netwerk/sctp/src/netinet/sctp_output.c
- netwerk/sctp/src/netinet/sctp_usrreq.c
- netwerk/sctp/src/netinet/sctputil.c
- netwerk/sctp/src/user_mbuf.c
- netwerk/sctp/src/user_socket.c
- netwerk/socket/nsSOCKSIOLayer.cpp
- netwerk/system/android/nsAndroidNetworkLinkService.cpp
- netwerk/system/linux/nsNetworkLinkService.cpp
- netwerk/system/mac/nsNetworkLinkService.mm
- netwerk/system/netlink/NetlinkService.cpp
- netwerk/system/win32/nsNotifyAddrListener.cpp
- netwerk/url-classifier/UrlClassifierFeatureBase.cpp
- netwerk/url-classifier/components.conf
- python/mach/mach/site.py
- python/mozbuild/mozbuild/artifacts.py
- python/mozbuild/mozbuild/mach_commands.py
- python/mozlint/mozlint/cli.py
- security/certverifier/CertVerifier.cpp
- security/manager/ssl/NSSSocketControl.cpp
- security/manager/ssl/RemoteSecuritySettings.sys.mjs
- security/manager/ssl/SSLServerCertVerification.cpp
- security/manager/ssl/SSLServerCertVerification.h
- security/manager/ssl/StaticHPKPins.h
- security/manager/ssl/nsSecureBrowserUI.cpp
- security/moz.build
- security/nss/lib/certhigh/ocsp.c
- security/nss/lib/libpkix/pkix_pl_nss/module/pkix_pl_socket.c
- security/nss/lib/mozpkix/include/pkix/Result.h
- security/nss/lib/mozpkix/include/pkix/pkixnss.h
- security/nss/lib/ssl/Makefile
- security/sandbox/common/SandboxUtils.sys.mjs
- services/settings/Attachments.sys.mjs
- services/settings/IDBHelpers.sys.mjs
- services/settings/RemoteSettingsClient.sys.mjs
- services/settings/dumps/gen_last_modified.py
- services/settings/dumps/main/moz.build
- services/settings/remote-settings.sys.mjs
- services/settings/servicesSettings.manifest
- services/settings/static-dumps/main/moz.build
- + services/settings/static-dumps/main/query-stripping.json
- services/sync/components.conf
- testing/mozbase/mozinstall/mozinstall/mozinstall.py
- testing/mozbase/setup_development.py
- testing/mozharness/scripts/does_it_crash.py
- third_party/libwebrtc/modules/audio_coding/codecs/isac/main/source/os_specific_inline.h
- third_party/libwebrtc/modules/desktop_capture/desktop_capture_types.h
- third_party/libwebrtc/modules/desktop_capture/win/desktop_capture_utils.cc
- third_party/libwebrtc/modules/desktop_capture/win/wgc_capture_session.cc
- third_party/libwebrtc/modules/desktop_capture/win/wgc_capturer_win.cc
- third_party/libwebrtc/modules/desktop_capture/win/wgc_capturer_win.h
- third_party/libwebrtc/modules/video_capture/windows/device_info_ds.h
- third_party/libwebrtc/rtc_base/platform_thread_types.cc
- third_party/libwebrtc/rtc_base/socket.h
- third_party/libwebrtc/rtc_base/system/file_wrapper.cc
- third_party/libwebrtc/rtc_base/win/create_direct3d_device.h
- third_party/sipcc/cpr_win_types.h
- third_party/sipcc/sdp_token.c
- toolkit/.eslintrc.js
- toolkit/actors/AboutHttpsOnlyErrorParent.sys.mjs
- + toolkit/actors/FilesFilterChild.sys.mjs
- + toolkit/actors/FilesFilterParent.sys.mjs
- toolkit/actors/NetErrorChild.sys.mjs
- toolkit/actors/NetErrorParent.sys.mjs
- toolkit/actors/moz.build
- toolkit/components/antitracking/antitracking.manifest
- toolkit/components/antitracking/components.conf
- toolkit/components/downloads/DownloadCore.sys.mjs
- toolkit/components/downloads/DownloadIntegration.sys.mjs
- toolkit/components/extensions/Extension.sys.mjs
- toolkit/components/extensions/ExtensionParent.sys.mjs
- toolkit/components/httpsonlyerror/content/errorpage.js
- + toolkit/components/lox/Lox.sys.mjs
- + toolkit/components/lox/content/lox_wasm_bg.wasm
- + toolkit/components/lox/jar.mn
- + toolkit/components/lox/lox_wasm.jsm
- + toolkit/components/lox/moz.build
- toolkit/components/moz.build
- toolkit/components/places/PlacesUtils.sys.mjs
- toolkit/components/remotebrowserutils/RemoteWebNavigation.sys.mjs
- toolkit/components/resistfingerprinting/RFPHelper.sys.mjs
- + toolkit/components/resistfingerprinting/content/letterboxing.css
- toolkit/components/resistfingerprinting/jar.mn
- toolkit/components/resistfingerprinting/nsRFPService.cpp
- toolkit/components/resistfingerprinting/nsRFPService.h
- toolkit/components/search/AppProvidedSearchEngine.sys.mjs
- toolkit/components/search/SearchEngine.sys.mjs
- toolkit/components/search/SearchService.sys.mjs
- + toolkit/components/search/content/duckduckgo.ico
- + toolkit/components/search/content/startpage.png
- + toolkit/components/search/content/torBrowserSearchEngineIcons.json
- + toolkit/components/search/content/torBrowserSearchEngines.json
- + toolkit/components/search/content/wikipedia.ico
- + toolkit/components/search/jar.mn
- toolkit/components/search/moz.build
- + toolkit/components/securitylevel/SecurityLevel.manifest
- + toolkit/components/securitylevel/SecurityLevel.sys.mjs
- + toolkit/components/securitylevel/components.conf
- + toolkit/components/securitylevel/moz.build
- toolkit/components/shopping/jar.mn
- toolkit/components/telemetry/app/TelemetrySend.sys.mjs
- toolkit/components/telemetry/moz.build
- + toolkit/components/tor-launcher/TorBootstrapRequest.sys.mjs
- + toolkit/components/tor-launcher/TorControlPort.sys.mjs
- + toolkit/components/tor-launcher/TorDomainIsolator.sys.mjs
- + toolkit/components/tor-launcher/TorLauncherUtil.sys.mjs
- + toolkit/components/tor-launcher/TorParsers.sys.mjs
- + toolkit/components/tor-launcher/TorProcess.sys.mjs
- + toolkit/components/tor-launcher/TorProcessAndroid.sys.mjs
- + toolkit/components/tor-launcher/TorProvider.sys.mjs
- + toolkit/components/tor-launcher/TorProviderBuilder.sys.mjs
- + toolkit/components/tor-launcher/TorStartupService.sys.mjs
- + toolkit/components/tor-launcher/components.conf
- + toolkit/components/tor-launcher/moz.build
- + toolkit/components/tor-launcher/tor-launcher.manifest
- + toolkit/components/torconnect/TorConnectChild.sys.mjs
- + toolkit/components/torconnect/TorConnectParent.sys.mjs
- + toolkit/components/torconnect/content/aboutTorConnect.css
- + toolkit/components/torconnect/content/aboutTorConnect.html
- + toolkit/components/torconnect/content/aboutTorConnect.js
- + toolkit/components/torconnect/content/arrow-right.svg
- + toolkit/components/torconnect/content/bridge.svg
- + toolkit/components/torconnect/content/connection-failure.svg
- + toolkit/components/torconnect/content/connection-location.svg
- + toolkit/components/torconnect/content/tor-connect-broken.svg
- + toolkit/components/torconnect/content/tor-connect.svg
- + toolkit/components/torconnect/content/tor-not-connected-to-connected-animated.svg
- + toolkit/components/torconnect/content/torConnectTitlebarStatus.css
- + toolkit/components/torconnect/content/torConnectTitlebarStatus.js
- + toolkit/components/torconnect/content/torConnectUrlbarButton.js
- + toolkit/components/torconnect/jar.mn
- + toolkit/components/torconnect/moz.build
- toolkit/components/windowwatcher/nsWindowWatcher.cpp
- toolkit/content/.eslintrc.js
- toolkit/content/aboutNetError.html
- toolkit/content/aboutNetError.mjs
- toolkit/content/jar.mn
- toolkit/content/license.html
- + toolkit/content/pt_config.json
- toolkit/content/widgets/infobar.css
- toolkit/content/widgets/moz-message-bar/moz-message-bar.mjs
- toolkit/content/widgets/moz-support-link/moz-support-link.mjs
- toolkit/content/widgets/moz-toggle/moz-toggle.mjs
- toolkit/content/widgets/notificationbox.js
- + toolkit/locales-preview/base-browser-no-translate.ftl
- + toolkit/locales-preview/tor-browser-no-translate.ftl
- + toolkit/locales/en-US/toolkit/global/base-browser.ftl
- + toolkit/locales/en-US/toolkit/global/tor-browser.ftl
- toolkit/locales/jar.mn
- toolkit/modules/ActorManagerParent.sys.mjs
- toolkit/modules/AppConstants.sys.mjs
- + toolkit/modules/Bech32Decode.sys.mjs
- + toolkit/modules/BridgeDB.sys.mjs
- + toolkit/modules/DomainFrontedRequests.sys.mjs
- + toolkit/modules/DragDropFilter.sys.mjs
- toolkit/modules/FinderParent.sys.mjs
- + toolkit/modules/Moat.sys.mjs
- toolkit/modules/PopupNotifications.sys.mjs
- + toolkit/modules/QRCode.sys.mjs
- toolkit/modules/RemotePageAccessManager.sys.mjs
- + toolkit/modules/TorAndroidIntegration.sys.mjs
- + toolkit/modules/TorConnect.sys.mjs
- + toolkit/modules/TorSettings.sys.mjs
- + toolkit/modules/TorStrings.sys.mjs
- toolkit/modules/UpdateUtils.sys.mjs
- toolkit/modules/moz.build
- toolkit/moz.build
- toolkit/mozapps/extensions/AddonManager.sys.mjs
- toolkit/mozapps/extensions/components.conf
- toolkit/mozapps/extensions/content/aboutaddons.html
- toolkit/mozapps/extensions/content/aboutaddons.js
- toolkit/mozapps/extensions/internal/XPIDatabase.sys.mjs
- toolkit/mozapps/extensions/internal/XPIInstall.sys.mjs
- toolkit/mozapps/extensions/internal/XPIProvider.sys.mjs
- toolkit/mozapps/extensions/test/browser/head.js
- toolkit/mozapps/extensions/test/xpcshell/head_addons.js
- toolkit/mozapps/update/UpdateService.sys.mjs
- toolkit/mozapps/update/UpdateServiceStub.sys.mjs
- toolkit/mozapps/update/common/updatehelper.cpp
- toolkit/mozapps/update/updater/launchchild_osx.mm
- toolkit/mozapps/update/updater/moz.build
- toolkit/mozapps/update/updater/nightly_aurora_level3_primary.der
- toolkit/mozapps/update/updater/nightly_aurora_level3_secondary.der
- toolkit/mozapps/update/updater/release_primary.der
- toolkit/mozapps/update/updater/release_secondary.der
- toolkit/mozapps/update/updater/updater.cpp
- toolkit/themes/shared/aboutNetError.css
- toolkit/themes/shared/desktop-jar.inc.mn
- toolkit/themes/shared/findbar.css
- + toolkit/themes/shared/icons/onion-site.svg
- + toolkit/themes/shared/icons/onion-slash.svg
- + toolkit/themes/shared/icons/onion-warning.svg
- + toolkit/themes/shared/icons/tor-dark-loading.png
- + toolkit/themes/shared/icons/tor-dark-loading(a)2x.png
- + toolkit/themes/shared/icons/tor-light-loading.png
- + toolkit/themes/shared/icons/tor-light-loading(a)2x.png
- + toolkit/themes/shared/icons/torbrowser.png
- toolkit/themes/shared/minimal-toolkit.jar.inc.mn
- + toolkit/themes/shared/onion-pattern.css
- + toolkit/themes/shared/onion-pattern.svg
- + toolkit/themes/shared/tor-colors.css
- + toolkit/torbutton/chrome/locale/en-US/onionLocation.properties
- + toolkit/torbutton/chrome/locale/en-US/settings.properties
- + toolkit/torbutton/chrome/locale/en-US/torConnect.properties
- + toolkit/torbutton/chrome/locale/en-US/torlauncher.properties
- + toolkit/torbutton/jar.mn
- + toolkit/torbutton/moz.build
- toolkit/xre/LauncherRegistryInfo.cpp
- toolkit/xre/MacLaunchHelper.h
- toolkit/xre/MacLaunchHelper.mm
- toolkit/xre/MacRunFromDmgUtils.mm
- toolkit/xre/ProfileReset.cpp
- toolkit/xre/dllservices/mozglue/WindowsDllBlocklist.cpp
- toolkit/xre/nsAppRunner.cpp
- toolkit/xre/nsIXREDirProvider.idl
- toolkit/xre/nsUpdateDriver.cpp
- toolkit/xre/nsXREDirProvider.cpp
- toolkit/xre/nsXREDirProvider.h
- + tools/base-browser/git-rebase-fixup-preprocessor
- + tools/base-browser/l10n/combine-translation-versions.py
- + tools/base-browser/l10n/combine/__init__.py
- + tools/base-browser/l10n/combine/combine.py
- + tools/base-browser/l10n/combine/tests/README
- + tools/base-browser/l10n/combine/tests/__init__.py
- + tools/base-browser/l10n/combine/tests/test_android.py
- + tools/base-browser/l10n/combine/tests/test_dtd.py
- + tools/base-browser/l10n/combine/tests/test_fluent.py
- + tools/base-browser/l10n/combine/tests/test_properties.py
- + tools/base-browser/tb-dev
- + tools/geckoview/.gitignore
- + tools/geckoview/Makefile
- + tools/geckoview/android-env-linux-template.sh
- + tools/geckoview/android-env-macos-template.sh
- + tools/geckoview/build-fenix.sh
- + tools/geckoview/build-geckoview.sh
- + tools/geckoview/clobber.sh
- + tools/geckoview/config.sh
- + tools/geckoview/jslint.sh
- tools/lint/fluent-lint/exclusions.yml
- + tools/torbrowser/Makefile
- + tools/torbrowser/browser-self-sign-macos.sh
- + tools/torbrowser/build.sh
- + tools/torbrowser/clobber.sh
- + tools/torbrowser/config.sh
- + tools/torbrowser/deploy.sh
- + tools/torbrowser/fetch.sh
- + tools/torbrowser/generate-bugzilla-triage-csv.sh
- + tools/torbrowser/generate_tor_loading_png.py
- + tools/torbrowser/ide.sh
- + tools/torbrowser/jslint.sh
- + tools/torbrowser/l10n/migrate.py
- + tools/torbrowser/l10n/migrations/__init__.py
- + tools/torbrowser/l10n/migrations/bug-41333-new-about-tor.py
- + tools/torbrowser/l10n/migrations/bug-41622-neterror.py
- + tools/torbrowser/l10n/migrations/bug-41820-moz-message-bar-download-warning.py
- + tools/torbrowser/l10n/migrations/bug-42202-crypto-safety.py
- + tools/torbrowser/l10n/migrations/bug-42203-about-dialog.py
- + tools/torbrowser/l10n/migrations/bug-42206-rulesets.py
- + tools/torbrowser/l10n/migrations/bug-42207-settings.py
- + tools/torbrowser/l10n/migrations/bug-42209-tor-circuit.py
- + tools/torbrowser/l10n/migrations/bug-42210-download-warning.py
- + tools/torbrowser/l10n/migrations/bug-42211-new-identity.py
- + tools/torbrowser/l10n/migrations/bug-42212-onion-services.py
- + tools/torbrowser/l10n/migrations/bug-42214-security-level.py
- + tools/torbrowser/update_emojis.py
- tools/update-packaging/common.sh
- tools/update-packaging/make_full_update.sh
- tools/update-packaging/make_incremental_update.sh
- uriloader/base/nsDocLoader.cpp
- uriloader/base/nsURILoader.cpp
- uriloader/exthandler/nsExternalHelperAppService.cpp
- widget/ScrollbarDrawingWin.cpp
- widget/ScrollbarDrawingWin11.cpp
- widget/android/WebExecutorSupport.cpp
- widget/gtk/MPRISServiceHandler.cpp
- widget/gtk/WidgetUtilsGtk.cpp
- widget/windows/WinTaskbar.cpp
- widget/windows/nsDataObj.cpp
- xpcom/base/ErrorList.py
- xpcom/ds/StaticAtoms.py
- xpcom/io/CocoaFileUtils.mm
- xpcom/io/nsAppFileLocationProvider.cpp
- xpfe/appshell/AppWindow.cpp
The diff was not included because it is too large.
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/compare/d5c41c…
--
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/compare/d5c41c…
You're receiving this email because of your account on gitlab.torproject.org.
1
0

[Git][tpo/applications/tor-browser][tor-browser-128.7.0esr-14.5-1] fixup! Adding issue and merge request templates
by morgan (@morgan) 25 Feb '25
by morgan (@morgan) 25 Feb '25
25 Feb '25
morgan pushed to branch tor-browser-128.7.0esr-14.5-1 at The Tor Project / Applications / Tor Browser
Commits:
61b37c2e by Morgan at 2025-02-25T13:36:48+00:00
fixup! Adding issue and merge request templates
include Bugzilla as potential source of backports
- - - - -
1 changed file:
- .gitlab/issue_templates/Backport.md
Changes:
=====================================
.gitlab/issue_templates/Backport.md
=====================================
@@ -1,23 +1,26 @@
<!--
Title:
Backport tor-browser#12345: Title of Issue
+ Backport Bugzilla 1234567: Title of Issue
-This is an issue for tracking back-porting a patch-set (e.g. from Alpha to Stable)
+This is an issue for tracking back-porting a patch-set (e.g. from Alpha to Stable or from Mozilla Rapid-Release to Alpha)
-->
## Backport Patchset
### Book-keeping
-#### Gitlab Issue(s)
+#### Issue(s)
- tor-browser#12345
- mullvad-browser#123
+- https://bugzilla.mozilla.org/show_bug.cgi?id=1234567
#### Merge Request(s)
- tor-browser!123
#### Target Channels
+- [ ] Alpha
- [ ] Stable
- [ ] Legacy
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/commit/61b37c2…
--
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/commit/61b37c2…
You're receiving this email because of your account on gitlab.torproject.org.
1
0

[Git][tpo/applications/tor-browser][tor-browser-128.7.0esr-14.5-1] fixup! Adding issue and merge request templates
by morgan (@morgan) 25 Feb '25
by morgan (@morgan) 25 Feb '25
25 Feb '25
morgan pushed to branch tor-browser-128.7.0esr-14.5-1 at The Tor Project / Applications / Tor Browser
Commits:
6df481f4 by Morgan at 2025-02-25T13:35:38+00:00
fixup! Adding issue and merge request templates
include Bugzilla as potential source of backports
- - - - -
1 changed file:
- .gitlab/issue_templates/Backport.md
Changes:
=====================================
.gitlab/issue_templates/Backport.md
=====================================
@@ -2,22 +2,24 @@
Title:
Backport tor-browser#12345: Title of Issue
-This is an issue for tracking back-porting a patch-set (e.g. from Alpha to Stable)
+This is an issue for tracking back-porting a patch-set (e.g. from Alpha to Stable or from Mozilla Rapid-Release to Alpha)
-->
## Backport Patchset
### Book-keeping
-#### Gitlab Issue(s)
+#### Issue(s)
- tor-browser#12345
- mullvad-browser#123
+- https://bugzilla.mozilla.org/show_bug.cgi?id=1234567
#### Merge Request(s)
- tor-browser!123
#### Target Channels
+- [ ] Alpha
- [ ] Stable
- [ ] Legacy
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/commit/6df481f…
--
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/commit/6df481f…
You're receiving this email because of your account on gitlab.torproject.org.
1
0

[Git][tpo/applications/mullvad-browser][mullvad-browser-128.7.0esr-14.5-1] fixup! MB 188: Customize Gitlab Issue and Merge templates
by morgan (@morgan) 25 Feb '25
by morgan (@morgan) 25 Feb '25
25 Feb '25
morgan pushed to branch mullvad-browser-128.7.0esr-14.5-1 at The Tor Project / Applications / Mullvad Browser
Commits:
420b63df by Morgan at 2025-02-25T13:34:22+00:00
fixup! MB 188: Customize Gitlab Issue and Merge templates
include Bugzilla as potential source of backports
- - - - -
1 changed file:
- .gitlab/issue_templates/Backport.md
Changes:
=====================================
.gitlab/issue_templates/Backport.md
=====================================
@@ -1,23 +1,26 @@
<!--
Title:
Backport mullvad-browser#123: Title of Issue
+ Backport Bugzilla 1234567: Title of Issue
-This is an issue for tracking back-porting a patch-set (e.g. from Alpha to Stable)
+This is an issue for tracking back-porting a patch-set (e.g. from Alpha to Stable or from Mozilla Rapid-Release to Alpha)
-->
## Backport Patchset
### Book-keeping
-#### Gitlab Issue(s)
+#### Issue(s)
- tor-browser#12345
- mullvad-browser#123
+- https://bugzilla.mozilla.org/show_bug.cgi?id=1234567
#### Merge Request(s)
- mullvad-browser!123
#### Target Channels
+- [ ] Alpha
- [ ] Stable
### Notes
View it on GitLab: https://gitlab.torproject.org/tpo/applications/mullvad-browser/-/commit/420…
--
View it on GitLab: https://gitlab.torproject.org/tpo/applications/mullvad-browser/-/commit/420…
You're receiving this email because of your account on gitlab.torproject.org.
1
0

[Git][tpo/applications/tor-browser] Pushed new tag FIREFOX_128_8_0esr_BUILD1
by ma1 (@ma1) 25 Feb '25
by ma1 (@ma1) 25 Feb '25
25 Feb '25
ma1 pushed new tag FIREFOX_128_8_0esr_BUILD1 at The Tor Project / Applications / Tor Browser
--
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/tree/FIREFOX_1…
You're receiving this email because of your account on gitlab.torproject.org.
1
0

[Git][tpo/applications/tor-browser] Pushed new branch tor-browser-128.8.0esr-14.0-1
by ma1 (@ma1) 25 Feb '25
by ma1 (@ma1) 25 Feb '25
25 Feb '25
ma1 pushed new branch tor-browser-128.8.0esr-14.0-1 at The Tor Project / Applications / Tor Browser
--
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/tree/tor-brows…
You're receiving this email because of your account on gitlab.torproject.org.
1
0

[Git][tpo/applications/tor-browser] Pushed new branch base-browser-128.8.0esr-14.0-1
by ma1 (@ma1) 25 Feb '25
by ma1 (@ma1) 25 Feb '25
25 Feb '25
ma1 pushed new branch base-browser-128.8.0esr-14.0-1 at The Tor Project / Applications / Tor Browser
--
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/tree/base-brow…
You're receiving this email because of your account on gitlab.torproject.org.
1
0

[Git][tpo/applications/mullvad-browser][mullvad-browser-128.7.0esr-14.5-1] fixup! MB 213: Customize the search engines list
by morgan (@morgan) 24 Feb '25
by morgan (@morgan) 24 Feb '25
24 Feb '25
morgan pushed to branch mullvad-browser-128.7.0esr-14.5-1 at The Tor Project / Applications / Mullvad Browser
Commits:
b4851e25 by Pier Angelo Vendrame at 2025-02-24T17:14:27+01:00
fixup! MB 213: Customize the search engines list
MB 395: Make Leta the default search engine.
- - - - -
1 changed file:
- toolkit/components/search/content/mullvadBrowserSearchEngines.json
Changes:
=====================================
toolkit/components/search/content/mullvadBrowserSearchEngines.json
=====================================
@@ -1,48 +1,48 @@
[
{
- "aliases": ["duckduckgo", "ddg"],
- "name": "DuckDuckGo",
+ "aliases": ["mullvad-leta", "leta", "mullvad", "ml"],
+ "name": "Mullvad Leta",
"urls": {
"search": {
- "base": "https://duckduckgo.com/",
+ "base": "https://leta.mullvad.net/",
"params": [],
"searchTermParamName": "q"
}
},
- "id": "04e99a38-13ee-47d8-8aa4-64482b3dea99",
- "identifier": "ddg",
+ "id": "ee88d691-6d7a-4adb-9fec-5a205565505a",
+ "identifier": "mullvad-leta",
"recordType": "engine",
"orderHint": 100,
"variants": []
},
{
- "aliases": ["ddg-html", "duckduckgohtml", "ddgh"],
- "name": "DuckDuckGo (HTML)",
+ "aliases": ["duckduckgo", "ddg"],
+ "name": "DuckDuckGo",
"urls": {
"search": {
- "base": "https://html.duckduckgo.com/html/",
+ "base": "https://duckduckgo.com/",
"params": [],
"searchTermParamName": "q"
}
},
- "id": "98d8c84b-7455-431d-98b9-890e7bcc0041",
- "identifier": "ddg-html",
+ "id": "04e99a38-13ee-47d8-8aa4-64482b3dea99",
+ "identifier": "ddg",
"recordType": "engine",
"orderHint": 90,
"variants": []
},
{
- "aliases": ["mullvad-leta", "leta", "mullvad", "ml"],
- "name": "Mullvad Leta",
+ "aliases": ["ddg-html", "duckduckgohtml", "ddgh"],
+ "name": "DuckDuckGo (HTML)",
"urls": {
"search": {
- "base": "https://leta.mullvad.net/",
+ "base": "https://html.duckduckgo.com/html/",
"params": [],
"searchTermParamName": "q"
}
},
- "id": "ee88d691-6d7a-4adb-9fec-5a205565505a",
- "identifier": "mullvad-leta",
+ "id": "98d8c84b-7455-431d-98b9-890e7bcc0041",
+ "identifier": "ddg-html",
"recordType": "engine",
"orderHint": 80,
"variants": []
View it on GitLab: https://gitlab.torproject.org/tpo/applications/mullvad-browser/-/commit/b48…
--
View it on GitLab: https://gitlab.torproject.org/tpo/applications/mullvad-browser/-/commit/b48…
You're receiving this email because of your account on gitlab.torproject.org.
1
0

[Git][tpo/applications/tor-browser][tor-browser-128.7.0esr-14.5-1] fixup! TB 42669: [android] Use custom no-op app-services
by Dan Ballard (@dan) 20 Feb '25
by Dan Ballard (@dan) 20 Feb '25
20 Feb '25
Dan Ballard pushed to branch tor-browser-128.7.0esr-14.5-1 at The Tor Project / Applications / Tor Browser
Commits:
4b5dd7c9 by clairehurst at 2025-02-20T14:14:29-07:00
fixup! TB 42669: [android] Use custom no-op app-services
- - - - -
1 changed file:
- tools/geckoview/build-fenix.sh
Changes:
=====================================
tools/geckoview/build-fenix.sh
=====================================
@@ -6,8 +6,6 @@ VARIANT=$3
source android-env.sh
-export NIMBUS_FML=$DEV_ROOT/mobile/android/fenix/app/nimbus-fml
-
cd $DEV_ROOT/mobile/android/fenix
MOZCONFIG=mozconfig-android-$ARCH $GRADLE_HOME/bin/gradle --no-daemon -Dorg.gradle.jvmargs=-Xmx20g -PdisableOptimization assemble$VARIANT
tools/tba-sign-devbuilds.sh
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/commit/4b5dd7c…
--
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/commit/4b5dd7c…
You're receiving this email because of your account on gitlab.torproject.org.
1
0

[Git][tpo/applications/tor-browser][tor-browser-128.7.0esr-14.5-1] fixup! fixup! [android] Modify build system
by Dan Ballard (@dan) 20 Feb '25
by Dan Ballard (@dan) 20 Feb '25
20 Feb '25
Dan Ballard pushed to branch tor-browser-128.7.0esr-14.5-1 at The Tor Project / Applications / Tor Browser
Commits:
8cee8bc2 by Dan Ballard at 2025-02-20T18:24:27+00:00
fixup! fixup! [android] Modify build system
bug 42669: fenix dir missing from nimbusFml path
- - - - -
1 changed file:
- mobile/android/fenix/app/build.gradle
Changes:
=====================================
mobile/android/fenix/app/build.gradle
=====================================
@@ -315,7 +315,7 @@ android.applicationVariants.configureEach { variant ->
if (project.hasProperty("disableTor")) {
disableTor = project.getProperty("disableTor")
}
- System.setProperty("nimbusFml", "${topsrcdir}/mobile/android/tools/nimbus-fml")
+ System.setProperty("nimbusFml", "${topsrcdir}/mobile/android/fenix/tools/nimbus-fml")
println("----------------------------------------------")
println("Variant name: " + variant.name)
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/commit/8cee8bc…
--
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/commit/8cee8bc…
You're receiving this email because of your account on gitlab.torproject.org.
1
0

[Git][tpo/applications/tor-browser][tor-browser-128.7.0esr-14.5-1] 3 commits: fixup! Bug 31286: Implementation of bridge, proxy, and firewall settings in...
by morgan (@morgan) 20 Feb '25
by morgan (@morgan) 20 Feb '25
20 Feb '25
morgan pushed to branch tor-browser-128.7.0esr-14.5-1 at The Tor Project / Applications / Tor Browser
Commits:
8e663084 by Henry Wilkes at 2025-02-20T17:30:12+00:00
fixup! Bug 31286: Implementation of bridge, proxy, and firewall settings in about:preferences#connection
TB 43328: Improve the Tor log dialog.
- - - - -
0cc2f849 by Henry Wilkes at 2025-02-20T17:38:02+00:00
fixup! TB 40933: Add tor-launcher functionality
TB 43328: Make getLog return the LogEntry data.
- - - - -
21c61532 by Henry Wilkes at 2025-02-20T17:38:03+00:00
fixup! Tor Browser strings
TB 43328: Improve the Tor log.
- - - - -
5 changed files:
- browser/components/torpreferences/content/torLogDialog.js
- browser/components/torpreferences/content/torLogDialog.xhtml
- browser/components/torpreferences/content/torPreferences.css
- toolkit/components/tor-launcher/TorProvider.sys.mjs
- toolkit/locales/en-US/toolkit/global/tor-browser.ftl
Changes:
=====================================
browser/components/torpreferences/content/torLogDialog.js
=====================================
@@ -4,20 +4,18 @@ const { setTimeout, clearTimeout } = ChromeUtils.importESModule(
"resource://gre/modules/Timer.sys.mjs"
);
-const { TorProviderBuilder } = ChromeUtils.importESModule(
+const { TorProviderBuilder, TorProviderTopics } = ChromeUtils.importESModule(
"resource://gre/modules/TorProviderBuilder.sys.mjs"
);
-window.addEventListener(
- "DOMContentLoaded",
- () => {
+const gTorLogDialog = {
+ init() {
const dialog = document.getElementById("torPreferences-torLog-dialog");
const copyLogButton = dialog.getButton("extra1");
copyLogButton.setAttribute("data-l10n-id", "tor-log-dialog-copy-button");
- const logText = document.getElementById(
- "torPreferences-torDialog-textarea"
- );
+ this._logTable = document.getElementById("tor-log-table");
+ this._logBody = document.getElementById("tor-log-body");
let restoreButtonTimeout = null;
copyLogButton.addEventListener("command", () => {
@@ -25,7 +23,14 @@ window.addEventListener(
let clipboard = Cc["@mozilla.org/widget/clipboardhelper;1"].getService(
Ci.nsIClipboardHelper
);
- clipboard.copyString(logText.value);
+ // The copied text should match the text content the user would get if
+ // they hand-selected the entire table.
+ clipboard.copyString(
+ Array.from(
+ this._logTable.querySelectorAll("td"),
+ el => el.textContent
+ ).join("\n")
+ );
copyLogButton.setAttribute(
"data-l10n-id",
@@ -47,13 +52,79 @@ window.addEventListener(
}, RESTORE_TIME);
});
+ // Intercept the copy event.
+ // NOTE: We attach this to the window rather than the _logTable because if
+ // the whole table is selected it will not receive the "copy" event.
+ window.addEventListener("copy", event => {
+ event.preventDefault();
+ event.clipboardData.setData(
+ "text",
+ // By default the selected text will insert "\n\t" between the <td>
+ // elements, which separates the timestamp from the message column.
+ // We drop this "\t" character, to just keep the "\n".
+ window.getSelection().toString().replace(/^\t/gm, "")
+ );
+ });
+
// A waiting state should not be needed at this point.
// Also, we probably cannot even arrive here if the provider failed to
// initialize, otherwise we could use a try/catch, and write the exception
// text in the logs, instead.
- TorProviderBuilder.build().then(
- provider => (logText.value = provider.getLog())
- );
+ TorProviderBuilder.build().then(provider => {
+ Services.obs.addObserver(this, TorProviderTopics.TorLog);
+ window.addEventListener(
+ "unload",
+ () => {
+ Services.obs.removeObserver(this, TorProviderTopics.TorLog);
+ },
+ { once: true }
+ );
+
+ for (const logEntry of provider.getLog()) {
+ this.addLogEntry(logEntry, true);
+ }
+ // Set the initial scroll to the bottom.
+ this._logTable.scrollTo({
+ top: this._logTable.scrollTopMax,
+ behaviour: "instant",
+ });
+ });
+ },
+
+ observe(subject, topic) {
+ if (topic === TorProviderTopics.TorLog) {
+ this.addLogEntry(subject.wrappedJSObject, false);
+ }
+ },
+
+ addLogEntry(logEntry, initial) {
+ const timeEl = document.createElement("td");
+ timeEl.textContent = logEntry.timestamp;
+ timeEl.classList.add("time");
+ const messageEl = document.createElement("td");
+ messageEl.textContent = `[${logEntry.type}] ${logEntry.msg}`;
+ messageEl.classList.add("message");
+
+ const row = document.createElement("tr");
+ row.append(timeEl, messageEl);
+
+ // If this is a new entry, and we are currently scrolled to the bottom (with
+ // a 6px allowance) we keep the scroll position at the bottom to "follow"
+ // the updates.
+ const scrollToBottom =
+ !initial && this._logTable.scrollTop >= this._logTable.scrollTopMax - 6;
+
+ this._logBody.append(row);
+ if (scrollToBottom) {
+ this._logTable.scrollTo({ top: this._logTable.scrollTopMax });
+ }
+ },
+};
+
+window.addEventListener(
+ "DOMContentLoaded",
+ () => {
+ gTorLogDialog.init();
},
{ once: true }
);
=====================================
browser/components/torpreferences/content/torLogDialog.xhtml
=====================================
@@ -23,10 +23,33 @@
<script src="chrome://browser/content/torpreferences/torLogDialog.js" />
- <html:textarea
- id="torPreferences-torDialog-textarea"
- multiline="true"
- readonly="true"
- />
+ <!-- We use a <table> element rather than a <ol>. A table structure allows
+ - screen reader users to navigate within one column so they can avoid the
+ - readback of the timestamp on every row. See tor-browser#43328.
+ - NOTE: We add the explicit role="table". Whilst this should not be
+ - neccessary, nor is it recommended, some screen readers (Orca 46) do not
+ - read out the default table role if the CSS `display` is not `table`.
+ - NOTE: Even though this table is updated with live information, we do
+ - not want to make this an aria-live area or use a "log updated"
+ - notification because the log messages are potentially busy.
+ - Moreover, the live updates is a convience so that the log doesn't need
+ - to be manually refreshed, rather than important information.
+ - NOTE: We add a tabindex=0 to make this element focusable with or
+ - without the overflow. This also makes the table the the initial focus
+ - of the dialog.
+ - NOTE: We add lang="en" and dir="ltr" to the <tbody> since the content
+ - of the log is in English. We do not add this to the <table> element
+ - since its aria-label is localised and we want the scrollbar to match
+ - the locale direction.
+ - NOTE: We avoid any whitespace between the <table> and <tbody> to ensure
+ - it does not contribute to the text content when the top of the table is
+ - manually copied. -->
+ <html:table
+ id="tor-log-table"
+ role="table"
+ data-l10n-id="tor-log-dialog-table"
+ tabindex="0"
+ ><html:tbody id="tor-log-body" lang="en" dir="ltr"></html:tbody
+ ></html:table>
</dialog>
</window>
=====================================
browser/components/torpreferences/content/torPreferences.css
=====================================
@@ -1058,12 +1058,39 @@ groupbox#torPreferences-bridges-group textarea {
}
/* Tor logs dialog */
-textarea#torPreferences-torDialog-textarea {
+#tor-log-table {
flex: 1 0 auto;
- font-family: monospace;
- font-size: 0.8em;
- white-space: pre;
overflow: auto;
- /* 10 lines */
min-height: 20em;
+ height: 20em;
+ display: flex;
+ flex-direction: column;
+ padding: var(--space-small);
+ margin-block-end: 4px;
+ border: 1px solid var(--in-content-box-border-color);
+ border-radius: var(--border-radius-small);
+ font-size: var(--font-size-small);
+}
+
+#tor-log-body,
+#tor-log-table tr {
+ display: contents;
+}
+
+#tor-log-table td {
+ flex: 0 0 auto;
+ padding: 0;
+}
+
+#tor-log-table td.time {
+ color: var(--text-color-deemphasized);
+ margin-block-end: var(--space-xsmall);
+}
+
+#tor-log-table td.message {
+ overflow-wrap: anywhere;
+}
+
+#tor-log-table tr:not(:last-of-type) td.message {
+ margin-block-end: var(--space-medium);
}
=====================================
toolkit/components/tor-launcher/TorProvider.sys.mjs
=====================================
@@ -512,14 +512,12 @@ export class TorProvider {
}
/**
- * Returns captured log message as a text string (one message per line).
+ * Returns captured log messages.
*
- * @returns {string} The logs we collected from the tor daemon so far
+ * @returns {LogEntry[]} The logs we collected from the tor daemon so far.
*/
getLog() {
- return this.#logs
- .map(logObj => `${logObj.timestamp} [${logObj.type}] ${logObj.msg}`)
- .join(TorLauncherUtil.isWindows ? "\r\n" : "\n");
+ return structuredClone(this.#logs);
}
/**
=====================================
toolkit/locales/en-US/toolkit/global/tor-browser.ftl
=====================================
@@ -423,6 +423,9 @@ tor-view-log-button = View log…
# "log" is a noun, referring to the recorded text output of the Tor process.
tor-log-dialog-title =
.title = Tor log
+# The screen-reader name for the Tor log table. Should match the dialog title.
+tor-log-dialog-table =
+ .aria-label = { tor-log-dialog-title.title }
# "log" is a noun, referring to the recorded text output of the Tor process.
tor-log-dialog-copy-button =
.label = Copy Tor log to clipboard
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/compare/8aa4f8…
--
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/compare/8aa4f8…
You're receiving this email because of your account on gitlab.torproject.org.
1
0

[Git][tpo/applications/tor-browser-build][maint-14.0] bug 41337: always copy gcc/stdlibc++ into firefox and remove from tor-expert-bundle
by Dan Ballard (@dan) 20 Feb '25
by Dan Ballard (@dan) 20 Feb '25
20 Feb '25
Dan Ballard pushed to branch maint-14.0 at The Tor Project / Applications / tor-browser-build
Commits:
90a754f9 by Dan Ballard at 2025-02-19T13:50:34-08:00
bug 41337: always copy gcc/stdlibc++ into firefox and remove from tor-expert-bundle
- - - - -
4 changed files:
- projects/browser/build
- projects/firefox/build
- projects/tor/README.md
- projects/tor/build
Changes:
=====================================
projects/browser/build
=====================================
@@ -120,12 +120,6 @@ mv [% c('input_files_by_name/noscript') %] "$TBDIR/$EXTSPATH/{73a6fe31-595d-460b
# Move tor and dependencies to where TB expects them
mv_tbdir tor/* "$TORBINPATH"
- # on linux, libstdc++ lives in it's own directory
- [% IF c("var/linux") %]
- mkdir -p "$TBDIR/$TORBINPATH/libstdc++"
- mv "$TBDIR/$TORBINPATH"/libstdc++.so.* "$TBDIR/$TORBINPATH/libstdc++"
- [% END %]
-
# the expert bundle includes tor-gencert, which isn't needed for browser releases
[% IF c("var/windows") %]
rm "$TBDIR/$TORBINPATH/tor-gencert.exe"
@@ -189,6 +183,13 @@ tar -C "${TB_STAGE_DIR}" -xf [% c('input_files_by_name/firefox') %]/browser.tar.
done
popd
rm -rf $TMP_MANUAL_PATH
+
+ # on linux, libstdc++ lives in it's own directory
+ [% IF c("var/linux") %]
+ # For legacy reasons, libstdc++ is with tor binaries in Tor Browser.
+ # We would have to test the updater to move it outside.
+ mv "$TBDIR/libstdc++" "$TBDIR/$TORBINPATH/libstdc++"
+ [% END %]
[% END -%]
[% IF c("var/namecoin") %]
=====================================
projects/firefox/build
=====================================
@@ -329,16 +329,20 @@ END;
[% IF c("var/linux") -%]
/var/tmp/dist/gcc/bin/g++ $rootdir/abicheck.cc -o Browser/abicheck -std=c++17
- [% IF !c("var/tor-browser") -%]
- libdest=Browser/libstdc++
- mkdir -p "$libdest"
- # FIXME: tor-browser-build#40749
- cp /var/tmp/dist/gcc/[% c("var/libdir") %]/libstdc++.so.* "$libdest"
- [% IF c("var/asan") -%]
- cp /var/tmp/dist/gcc/[% c("var/libdir") %]/libasan.so.* "$libdest"
- cp /var/tmp/dist/gcc/[% c("var/libdir") %]/libubsan.so.* "$libdest"
- [% END -%]
+ libdest=Browser/libstdc++
+ mkdir -p "$libdest"
+ # Not copying libstdc++.so.* as that dups with the full libstdc++.so.6.0.xx the .6 links to
+ # and libstdc++.so.6.0.28-gdb.py which is also not needed
+ cp /var/tmp/dist/gcc/[% c("var/libdir") %]/libstdc++.so.* "$libdest"
+ [% IF c("var/asan") -%]
+ cp /var/tmp/dist/gcc/[% c("var/libdir") %]/libasan.so.* "$libdest"
+ cp /var/tmp/dist/gcc/[% c("var/libdir") %]/libubsan.so.* "$libdest"
[% END -%]
+ # Strip and generate debuginfo for libs
+ for LIB in "$libdest"/*so*
+ do
+ "$STRIP" "$LIB"
+ done
[% END -%]
echo "Starting to package artifacts $(date)"
=====================================
projects/tor/README.md
=====================================
@@ -38,8 +38,5 @@ We plan to do it also on desktop platforms, see
## Other Linux libraries
-For Linux we also include here libstdc++ (and the sanitizers, if enabled), even
-though they aren't needed by tor.
-
-Also, on we provide debug symbols, but only for Linux, and only in
+For Linux we provide debug symbols, but only for Linux, and only in
`tor-expert-bundle`.
=====================================
projects/tor/build
=====================================
@@ -52,22 +52,7 @@ openssldir=/var/tmp/dist/openssl
cp $openssldir/lib/libssl.so.3 "$TORBINDIR"
cp $openssldir/lib/libcrypto.so.3 "$TORBINDIR"
cp $libeventdir/lib/libevent-2.1.so.7 "$TORBINDIR"
- # We need to copy the libstdc++.so.6 for Tor Browser on older Linux distros.
- # Copying it into /Browser, which feels more natural, and amending
- # LD_LIBRARY_PATH breaks updates from a Tor Browser with the old
- # LD_LIBRARY_PATH value to the Tor Browser with the newer one. Thus, we copy
- # the libstdc++ into the directory with the libs tor depends on, too. See bug
- # 13359 for further details.
- libdir=[% c("var/libdir") %]
- [% IF c("var/linux-cross") -%]
- libdir="[% c("var/crosstarget") %]/$libdir"
- [% END -%]
- cp "/var/tmp/dist/gcc/$libdir/libstdc++.so.6" "$TORBINDIR"
- [% IF c("var/asan") -%]
- cp "/var/tmp/dist/gcc/$libdir/libasan.so.6" "$TORBINDIR"
- cp "/var/tmp/dist/gcc/$libdir/libubsan.so.1" "$TORBINDIR"
- [% END -%]
- chmod 700 "$TORBINDIR"/*.so*
+
# This is needed to make RPATH unavailable. See bug 9150.
export LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$TORBINDIR"
[% END %]
@@ -136,17 +121,9 @@ cd $distdir
do
LIB=`basename $i`
- if [ $LIB == 'libstdc++.so.6' ]; then
- # keeping this separate to maintain reproducibility; we can probably
- # treat this the same as the rest (though it seems libstdc++ doesn't come with
- # any useful debug symbols since we don't build it, so maybe we should figure
- # out how to package them
- "$STRIP" "$TORBINDIR/$LIB"
- else
- "$OBJCOPY" --only-keep-debug "$TORBINDIR/$LIB" "$TORDEBUGDIR/$LIB"
- "$STRIP" "$TORBINDIR/$LIB"
- "$OBJCOPY" --add-gnu-debuglink="$TORDEBUGDIR/$LIB" "$TORBINDIR/$LIB"
- fi
+ "$OBJCOPY" --only-keep-debug "$TORBINDIR/$LIB" "$TORDEBUGDIR/$LIB"
+ "$STRIP" "$TORBINDIR/$LIB"
+ "$OBJCOPY" --add-gnu-debuglink="$TORDEBUGDIR/$LIB" "$TORBINDIR/$LIB"
done
[% END %]
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser-build/-/commit/9…
--
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser-build/-/commit/9…
You're receiving this email because of your account on gitlab.torproject.org.
1
0

[Git][tpo/applications/tor-browser-build][main] Update uplift and add backport issue template for consistency with tor-browser
by morgan (@morgan) 20 Feb '25
by morgan (@morgan) 20 Feb '25
20 Feb '25
morgan pushed to branch main at The Tor Project / Applications / tor-browser-build
Commits:
fa7e94b4 by Morgan at 2025-02-20T14:59:12+00:00
Update uplift and add backport issue template for consistency with tor-browser
- - - - -
2 changed files:
- + .gitlab/issue_templates/Backport.md
- .gitlab/issue_templates/Uplift.md
Changes:
=====================================
.gitlab/issue_templates/Backport.md
=====================================
@@ -0,0 +1,29 @@
+<!--
+Title:
+ Backport tor-browser-build-browser#12345: Title of Issue
+
+This is an issue for tracking back-porting a patch-set (e.g. from main to maint-14.0)
+-->
+
+## Backport Patchset
+
+### Book-keeping
+
+#### Gitlab Issue(s)
+- tor-browser#12345
+- mullvad-browser#123
+- tor-browser-build#12345
+
+#### Merge Request(s)
+- tor-browser-build!1234
+
+#### Target Channels
+
+- [ ] maint-14.0
+- [ ] maint-13.5
+
+### Notes
+
+<!-- whatever additional info, context, etc that would be helpful for backporting -->
+
+/label ~"Apps::Type::Backport"
=====================================
.gitlab/issue_templates/Uplift.md
=====================================
@@ -1,17 +1,25 @@
<!--
Title:
Uplift tor-browser-build#12345: Title of Issue
+
+This is an issue for tracking uplift of a patch-set to an upstream build-dependency (e.g. MinGW, clang, etc)
+
-->
-# Uplift Patchset
+## Uplift Patchset
-## Gitlab Issue(s)
+### Book-keeping
+
+#### Gitlab Issue(s)
- tor-browser-build#12345
-## Upstream Project Issue(s):
+#### Merge Request(s)
+- tor-browser-build!1234
+
+#### Upstream Project Issue(s):
-## Notes
+### Notes
<!-- whatever additional info, context, etc that would be helpful for uplifting -->
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser-build/-/commit/f…
--
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser-build/-/commit/f…
You're receiving this email because of your account on gitlab.torproject.org.
1
0

[Git][tpo/applications/mullvad-browser][mullvad-browser-128.7.0esr-14.5-1] 2 commits: fixup! Adding issue and merge request templates
by morgan (@morgan) 20 Feb '25
by morgan (@morgan) 20 Feb '25
20 Feb '25
morgan pushed to branch mullvad-browser-128.7.0esr-14.5-1 at The Tor Project / Applications / Mullvad Browser
Commits:
a4dcc590 by Morgan at 2025-02-20T14:41:28+00:00
fixup! Adding issue and merge request templates
add backport template and tweak the uplift template
- - - - -
3551913c by Morgan at 2025-02-20T14:46:09+00:00
fixup! MB 188: Customize Gitlab Issue and Merge templates
tweak backport temlpate for mullvad-browser
- - - - -
1 changed file:
- + .gitlab/issue_templates/Backport.md
Changes:
=====================================
.gitlab/issue_templates/Backport.md
=====================================
@@ -0,0 +1,27 @@
+<!--
+Title:
+ Backport mullvad-browser#123: Title of Issue
+
+This is an issue for tracking back-porting a patch-set (e.g. from Alpha to Stable)
+-->
+
+## Backport Patchset
+
+### Book-keeping
+
+#### Gitlab Issue(s)
+- tor-browser#12345
+- mullvad-browser#123
+
+#### Merge Request(s)
+- mullvad-browser!123
+
+#### Target Channels
+
+- [ ] Stable
+
+### Notes
+
+<!-- whatever additional info, context, etc that would be helpful for backporting -->
+
+/label ~"Apps::Type::Backport"
View it on GitLab: https://gitlab.torproject.org/tpo/applications/mullvad-browser/-/compare/db…
--
View it on GitLab: https://gitlab.torproject.org/tpo/applications/mullvad-browser/-/compare/db…
You're receiving this email because of your account on gitlab.torproject.org.
1
0

[Git][tpo/applications/tor-browser][tor-browser-128.7.0esr-14.5-1] fixup! Adding issue and merge request templates
by morgan (@morgan) 20 Feb '25
by morgan (@morgan) 20 Feb '25
20 Feb '25
morgan pushed to branch tor-browser-128.7.0esr-14.5-1 at The Tor Project / Applications / Tor Browser
Commits:
8aa4f8c7 by Morgan at 2025-02-20T14:38:14+00:00
fixup! Adding issue and merge request templates
add backport template and tweak the uplift template
- - - - -
2 changed files:
- + .gitlab/issue_templates/Backport.md
- .gitlab/issue_templates/Uplift.md
Changes:
=====================================
.gitlab/issue_templates/Backport.md
=====================================
@@ -0,0 +1,28 @@
+<!--
+Title:
+ Backport tor-browser#12345: Title of Issue
+
+This is an issue for tracking back-porting a patch-set (e.g. from Alpha to Stable)
+-->
+
+## Backport Patchset
+
+### Book-keeping
+
+#### Gitlab Issue(s)
+- tor-browser#12345
+- mullvad-browser#123
+
+#### Merge Request(s)
+- tor-browser!123
+
+#### Target Channels
+
+- [ ] Stable
+- [ ] Legacy
+
+### Notes
+
+<!-- whatever additional info, context, etc that would be helpful for backporting -->
+
+/label ~"Apps::Type::Backport"
=====================================
.gitlab/issue_templates/Uplift.md
=====================================
@@ -1,18 +1,25 @@
<!--
Title:
Uplift tor-browser#12345: Title of Issue
+
+This is an issue for tracking uplift of a patch-set to Firefox
-->
-# Uplift Patchset
+## Uplift Patchset
+
+### Book-keeping
-## Gitlab Issue(s)
+#### Gitlab Issue(s)
- tor-browser#12345
-- mullvad-browser#12345
+- mullvad-browser#123
+
+#### Merge Request(s)
+- tor-browser!123
-## Upstream Mozilla Issue(s):
+#### Upstream Mozilla Issue(s):
- https://bugzilla.mozilla.org/show_bug.cgi?id=12345
-## Notes
+### Notes
<!-- whatever additional info, context, etc that would be helpful for uplifting -->
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/commit/8aa4f8c…
--
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/commit/8aa4f8c…
You're receiving this email because of your account on gitlab.torproject.org.
1
0

[Git][tpo/applications/tor-browser][tor-browser-128.7.0esr-14.5-1] fixup! TB 42669: [android] Use custom no-op app-services
by Dan Ballard (@dan) 19 Feb '25
by Dan Ballard (@dan) 19 Feb '25
19 Feb '25
Dan Ballard pushed to branch tor-browser-128.7.0esr-14.5-1 at The Tor Project / Applications / Tor Browser
Commits:
6c42a1f6 by Dan Ballard at 2025-02-19T18:04:53+00:00
fixup! TB 42669: [android] Use custom no-op app-services
Bug 42669: use topsrcdir as defined by us in local.properties for gradle to support different project dirs in AS
- - - - -
1 changed file:
- mobile/android/fenix/app/build.gradle
Changes:
=====================================
mobile/android/fenix/app/build.gradle
=====================================
@@ -315,8 +315,7 @@ android.applicationVariants.configureEach { variant ->
if (project.hasProperty("disableTor")) {
disableTor = project.getProperty("disableTor")
}
- System.setProperty("nimbusFml", rootProject.projectDir.toPath().resolve("tools").resolve("nimbus-fml").toAbsolutePath().toString())
-
+ System.setProperty("nimbusFml", "${topsrcdir}/mobile/android/tools/nimbus-fml")
println("----------------------------------------------")
println("Variant name: " + variant.name)
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/commit/6c42a1f…
--
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/commit/6c42a1f…
You're receiving this email because of your account on gitlab.torproject.org.
1
0

[Git][tpo/applications/mullvad-browser][mullvad-browser-128.7.0esr-14.5-1] 2 commits: dropme! BB 40925: Implemented the Security Level component
by morgan (@morgan) 19 Feb '25
by morgan (@morgan) 19 Feb '25
19 Feb '25
morgan pushed to branch mullvad-browser-128.7.0esr-14.5-1 at The Tor Project / Applications / Mullvad Browser
Commits:
155722f5 by Pier Angelo Vendrame at 2025-02-19T14:29:30+00:00
dropme! BB 40925: Implemented the Security Level component
BB 43498: Remove our old patch for 43129.
This commit should be ignored at the next rebase (and we will likely
have a conflict on the security level commit).
- - - - -
db2459bd by Pier Angelo Vendrame at 2025-02-19T14:29:30+00:00
Bug 1923260 - Exempt Android resources from svg.disabled. r=peterv
Differential Revision: https://phabricator.services.mozilla.com/D224895
- - - - -
1 changed file:
- dom/base/nsNodeInfoManager.cpp
Changes:
=====================================
dom/base/nsNodeInfoManager.cpp
=====================================
@@ -344,16 +344,6 @@ void nsNodeInfoManager::RemoveNodeInfo(NodeInfo* aNodeInfo) {
}
static bool IsSystemOrAddonOrAboutPrincipal(nsIPrincipal* aPrincipal) {
-#ifdef ANDROID
- if (aPrincipal->SchemeIs("resource")) {
- nsAutoCString spec;
- aPrincipal->GetAsciiSpec(spec);
- if (StringBeginsWith(spec, "resource://android/assets/"_ns)) {
- return true;
- }
- }
-#endif
-
return aPrincipal->IsSystemPrincipal() ||
BasePrincipal::Cast(aPrincipal)->AddonPolicy() ||
// NOTE: about:blank and about:srcdoc inherit the principal of their
@@ -361,6 +351,21 @@ static bool IsSystemOrAddonOrAboutPrincipal(nsIPrincipal* aPrincipal) {
aPrincipal->SchemeIs("about");
}
+static bool IsAndroidResource(nsIURI* aURI) {
+#ifdef ANDROID
+ if (aURI->SchemeIs("resource")) {
+ nsAutoCString host, path;
+ aURI->GetHost(host);
+ aURI->GetFilePath(path);
+ if (host.EqualsLiteral("android") &&
+ StringBeginsWith(path, "/assets/"_ns)) {
+ return true;
+ }
+ }
+#endif
+ return false;
+}
+
bool nsNodeInfoManager::InternalSVGEnabled() {
MOZ_ASSERT(!mSVGEnabled, "Caller should use the cached mSVGEnabled!");
@@ -386,6 +391,7 @@ bool nsNodeInfoManager::InternalSVGEnabled() {
// of system or add-on UI or about: page)
bool conclusion =
(SVGEnabled || IsSystemOrAddonOrAboutPrincipal(mPrincipal) ||
+ IsAndroidResource(mDocument->GetDocumentURI()) ||
(loadInfo &&
(loadInfo->GetExternalContentPolicyType() ==
ExtContentPolicy::TYPE_IMAGE ||
View it on GitLab: https://gitlab.torproject.org/tpo/applications/mullvad-browser/-/compare/5b…
--
View it on GitLab: https://gitlab.torproject.org/tpo/applications/mullvad-browser/-/compare/5b…
You're receiving this email because of your account on gitlab.torproject.org.
1
0

[Git][tpo/applications/tor-browser-build][main] Bug 41372: Fix rename-branding-strings.py path.
by boklm (@boklm) 19 Feb '25
by boklm (@boklm) 19 Feb '25
19 Feb '25
boklm pushed to branch main at The Tor Project / Applications / tor-browser-build
Commits:
a395d359 by Henry Wilkes at 2025-02-19T14:11:51+00:00
Bug 41372: Fix rename-branding-strings.py path.
- - - - -
1 changed file:
- projects/firefox/build
Changes:
=====================================
projects/firefox/build
=====================================
@@ -178,8 +178,8 @@ branding_dir=browser/branding/[% c("var/branding_directory_prefix") %]-[% c("var
mkdir -p "$l10n_branding_dir"
# Convert the translations repository branding files into files that work
# for this specific build.
- python3 rename-branding-strings.py $lang/branding/brand.ftl "$brand_ftl_renames" > "$l10n_branding_dir/brand.ftl"
- python3 rename-branding-strings.py $lang/brand.properties "$brand_properties_renames" > "$l10n_branding_dir/brand.properties"
+ python3 $rootdir/rename-branding-strings.py $lang/branding/brand.ftl "$brand_ftl_renames" > "$l10n_branding_dir/brand.ftl"
+ python3 $rootdir/rename-branding-strings.py $lang/brand.properties "$brand_properties_renames" > "$l10n_branding_dir/brand.properties"
done
popd
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser-build/-/commit/a…
--
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser-build/-/commit/a…
You're receiving this email because of your account on gitlab.torproject.org.
1
0

[Git][tpo/applications/tor-browser][base-browser-128.7.0esr-14.5-1] 2 commits: dropme! BB 40925: Implemented the Security Level component
by morgan (@morgan) 19 Feb '25
by morgan (@morgan) 19 Feb '25
19 Feb '25
morgan pushed to branch base-browser-128.7.0esr-14.5-1 at The Tor Project / Applications / Tor Browser
Commits:
f675e2ca by Pier Angelo Vendrame at 2025-02-19T14:24:57+00:00
dropme! BB 40925: Implemented the Security Level component
BB 43498: Remove our old patch for 43129.
This commit should be ignored at the next rebase (and we will likely
have a conflict on the security level commit).
- - - - -
20e649a8 by Pier Angelo Vendrame at 2025-02-19T14:24:57+00:00
Bug 1923260 - Exempt Android resources from svg.disabled. r=peterv
Differential Revision: https://phabricator.services.mozilla.com/D224895
- - - - -
1 changed file:
- dom/base/nsNodeInfoManager.cpp
Changes:
=====================================
dom/base/nsNodeInfoManager.cpp
=====================================
@@ -344,16 +344,6 @@ void nsNodeInfoManager::RemoveNodeInfo(NodeInfo* aNodeInfo) {
}
static bool IsSystemOrAddonOrAboutPrincipal(nsIPrincipal* aPrincipal) {
-#ifdef ANDROID
- if (aPrincipal->SchemeIs("resource")) {
- nsAutoCString spec;
- aPrincipal->GetAsciiSpec(spec);
- if (StringBeginsWith(spec, "resource://android/assets/"_ns)) {
- return true;
- }
- }
-#endif
-
return aPrincipal->IsSystemPrincipal() ||
BasePrincipal::Cast(aPrincipal)->AddonPolicy() ||
// NOTE: about:blank and about:srcdoc inherit the principal of their
@@ -361,6 +351,21 @@ static bool IsSystemOrAddonOrAboutPrincipal(nsIPrincipal* aPrincipal) {
aPrincipal->SchemeIs("about");
}
+static bool IsAndroidResource(nsIURI* aURI) {
+#ifdef ANDROID
+ if (aURI->SchemeIs("resource")) {
+ nsAutoCString host, path;
+ aURI->GetHost(host);
+ aURI->GetFilePath(path);
+ if (host.EqualsLiteral("android") &&
+ StringBeginsWith(path, "/assets/"_ns)) {
+ return true;
+ }
+ }
+#endif
+ return false;
+}
+
bool nsNodeInfoManager::InternalSVGEnabled() {
MOZ_ASSERT(!mSVGEnabled, "Caller should use the cached mSVGEnabled!");
@@ -386,6 +391,7 @@ bool nsNodeInfoManager::InternalSVGEnabled() {
// of system or add-on UI or about: page)
bool conclusion =
(SVGEnabled || IsSystemOrAddonOrAboutPrincipal(mPrincipal) ||
+ IsAndroidResource(mDocument->GetDocumentURI()) ||
(loadInfo &&
(loadInfo->GetExternalContentPolicyType() ==
ExtContentPolicy::TYPE_IMAGE ||
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/compare/523639…
--
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/compare/523639…
You're receiving this email because of your account on gitlab.torproject.org.
1
0

[Git][tpo/applications/tor-browser][tor-browser-128.7.0esr-14.5-1] 2 commits: dropme! BB 40925: Implemented the Security Level component
by morgan (@morgan) 19 Feb '25
by morgan (@morgan) 19 Feb '25
19 Feb '25
morgan pushed to branch tor-browser-128.7.0esr-14.5-1 at The Tor Project / Applications / Tor Browser
Commits:
7fc0ffe8 by Pier Angelo Vendrame at 2025-02-19T08:57:31+01:00
dropme! BB 40925: Implemented the Security Level component
BB 43498: Remove our old patch for 43129.
This commit should be ignored at the next rebase (and we will likely
have a conflict on the security level commit).
- - - - -
7b27fd84 by Pier Angelo Vendrame at 2025-02-19T08:57:43+01:00
Bug 1923260 - Exempt Android resources from svg.disabled. r=peterv
Differential Revision: https://phabricator.services.mozilla.com/D224895
- - - - -
1 changed file:
- dom/base/nsNodeInfoManager.cpp
Changes:
=====================================
dom/base/nsNodeInfoManager.cpp
=====================================
@@ -344,16 +344,6 @@ void nsNodeInfoManager::RemoveNodeInfo(NodeInfo* aNodeInfo) {
}
static bool IsSystemOrAddonOrAboutPrincipal(nsIPrincipal* aPrincipal) {
-#ifdef ANDROID
- if (aPrincipal->SchemeIs("resource")) {
- nsAutoCString spec;
- aPrincipal->GetAsciiSpec(spec);
- if (StringBeginsWith(spec, "resource://android/assets/"_ns)) {
- return true;
- }
- }
-#endif
-
return aPrincipal->IsSystemPrincipal() ||
BasePrincipal::Cast(aPrincipal)->AddonPolicy() ||
// NOTE: about:blank and about:srcdoc inherit the principal of their
@@ -361,6 +351,21 @@ static bool IsSystemOrAddonOrAboutPrincipal(nsIPrincipal* aPrincipal) {
aPrincipal->SchemeIs("about");
}
+static bool IsAndroidResource(nsIURI* aURI) {
+#ifdef ANDROID
+ if (aURI->SchemeIs("resource")) {
+ nsAutoCString host, path;
+ aURI->GetHost(host);
+ aURI->GetFilePath(path);
+ if (host.EqualsLiteral("android") &&
+ StringBeginsWith(path, "/assets/"_ns)) {
+ return true;
+ }
+ }
+#endif
+ return false;
+}
+
bool nsNodeInfoManager::InternalSVGEnabled() {
MOZ_ASSERT(!mSVGEnabled, "Caller should use the cached mSVGEnabled!");
@@ -386,6 +391,7 @@ bool nsNodeInfoManager::InternalSVGEnabled() {
// of system or add-on UI or about: page)
bool conclusion =
(SVGEnabled || IsSystemOrAddonOrAboutPrincipal(mPrincipal) ||
+ IsAndroidResource(mDocument->GetDocumentURI()) ||
(loadInfo &&
(loadInfo->GetExternalContentPolicyType() ==
ExtContentPolicy::TYPE_IMAGE ||
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/compare/6fa642…
--
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/compare/6fa642…
You're receiving this email because of your account on gitlab.torproject.org.
1
0

[Git][tpo/applications/tor-browser-build][main] 3 commits: Bug 41363: Split update_responses files per platform
by morgan (@morgan) 19 Feb '25
by morgan (@morgan) 19 Feb '25
19 Feb '25
morgan pushed to branch main at The Tor Project / Applications / tor-browser-build
Commits:
8b3ef788 by Nicolas Vigier at 2025-02-19T04:18:14+01:00
Bug 41363: Split update_responses files per platform
To make reverting update for a single platform easier, we split update
response files, using a separate directory for each platform.
- - - - -
38dcaae7 by Nicolas Vigier at 2025-02-19T04:19:25+01:00
Bug 41363: Make separate update_responses commit for each platform
- - - - -
7504979e by Nicolas Vigier at 2025-02-19T04:19:29+01:00
Bug 41363: Fix error message about $update_responses_repository_dir being undefined
- - - - -
4 changed files:
- projects/release/create_update_responses_tar
- tools/signing/functions
- tools/signing/upload-update_responses-to-staticiforme
- tools/update-responses/update_responses
Changes:
=====================================
projects/release/create_update_responses_tar
=====================================
@@ -1,9 +1,10 @@
#!/bin/bash
[% c("var/set_default_env") -%]
[% SET channel = c('var/channel') -%]
+rm -Rf [% shell_quote(c("basedir")) %]/tools/update-responses/htdocs/[% channel %]
[% shell_quote(c("basedir")) %]/tools/update-responses/update_responses [% channel %]
mkdir -p [% shell_quote(path(dest_dir)) %]/update-responses
mv [% shell_quote(c("basedir")) %]/tools/update-responses/htdocs/[% channel %] [% channel %]
-chmod 775 [% channel %]
-chmod 664 [% channel %]/.htaccess [% channel %]/*
+find [% channel %] -type d -exec chmod 775 {} \;
+find [% channel %] -type f -exec chmod 664 {} \;
tar cf [% shell_quote(path(dest_dir)) %]/update-responses/update-responses-[% channel %]-[% c("version") %].tar [% channel %]
=====================================
tools/signing/functions
=====================================
@@ -23,7 +23,7 @@ function check_update_responses_repository_dir {
if test -z "$update_responses_repository_dir" || ! test -d "$update_responses_repository_dir"
then
cat << 'EOF' > /dev/stderr
-$aus1_repository_dir is not defined, or the directory does not exist
+$update_responses_repository_dir is not defined, or the directory does not exist
You should clone git@gitlab.torproject.org:tpo/applications/tor-browser-update-responses.git
and set $update_responses_repository_dir in set-config.update-responses
EOF
=====================================
tools/signing/upload-update_responses-to-staticiforme
=====================================
@@ -39,8 +39,32 @@ do
mv "$file" "$tbb_version_type/$fname"
done
+# Keep directory from previous release if they are not in the new release.
+# This happens when a release does not include some platforms.
+for file in $(ls -1 "$old_ur/$tbb_version_type")
+do
+ test -d "$old_ur/$tbb_version_type/$file" || continue
+ test -d "$tbb_version_type/$file" && continue
+ mv -f "$old_ur/$tbb_version_type/$file" "$tbb_version_type/$file"
+done
+
+# Commit each sub-directory separately
+for file in $(ls -1 "$tbb_version_type")
+do
+ test -d "$tbb_version_type/$file" || continue
+ git add "$tbb_version_type/$file"
+ git add "$tbb_version_type/download-$file.json"
+ git diff --quiet --cached --exit-code || \
+ git commit -m "$tbb_version_type: new version, $tbb_version ($file)"
+done
+
+git add "$tbb_version_type"/download-android-*.json
+git diff --quiet --cached --exit-code || \
+ git commit -m "$tbb_version_type: new version, $tbb_version (android)"
+
git add "$tbb_version_type"
-git commit -m "$tbb_version_type: new version, $tbb_version"
+git diff --quiet --cached --exit-code || \
+ git commit -m "$tbb_version_type: new version, $tbb_version"
git push
# we just need to push mullvadbrowser's update responses to git, not deploy to staticiforme
=====================================
tools/update-responses/update_responses
=====================================
@@ -29,7 +29,6 @@ setlocale(LC_ALL, "C");
my $htdocsdir = "$FindBin::Bin/htdocs";
my $config = LoadFile("$FindBin::Bin/config.yml");
-my %htdocsfiles;
my $releases_dir = $config->{releases_dir};
$releases_dir = "$FindBin::Bin/$releases_dir" unless $releases_dir =~ m/^\//;
my @check_errors;
@@ -51,12 +50,6 @@ sub get_tmpdir {
: ());
}
-sub build_targets_by_os {
- exit_error "Unknown build target for OS $_[0]" unless $config->{build_targets}{$_[0]};
- my $r = $config->{build_targets}{$_[0]};
- return ref $r eq 'ARRAY' ? @$r : ($r);
-}
-
sub get_nbprocs {
return $ENV{NUM_PROCS} if defined $ENV{NUM_PROCS};
if (-f '/proc/cpuinfo') {
@@ -80,19 +73,11 @@ sub setup_martools {
}
sub write_htdocs {
- my ($channel, $file, $content) = @_;
+ my ($channel, $dir, $file, $content) = @_;
mkdir $htdocsdir unless -d $htdocsdir;
mkdir "$htdocsdir/$channel" unless -d "$htdocsdir/$channel";
- write_file("$htdocsdir/$channel/$file", $content);
- $htdocsfiles{$channel}->{$file} = 1;
-}
-
-sub clean_htdocs {
- my ($channel) = @_;
- opendir(my $d, "$htdocsdir/$channel");
- my @files = grep { ! $htdocsfiles{$channel}->{$_} } readdir $d;
- closedir $d;
- unlink map { "$htdocsdir/$channel/$_" } @files;
+ mkdir "$htdocsdir/$channel/$dir" unless -d "$htdocsdir/$channel/$dir";
+ write_file("$htdocsdir/$channel/$dir/$file", $content);
}
sub get_sha512_hex_of_file {
@@ -418,24 +403,31 @@ sub write_responses {
my $versions_str = join('+', @$versions);
foreach my $os (keys %oses) {
my $resp = get_response($config, $versions, $os);
- write_htdocs($channel, "$versions_str-$os.xml", $resp);
+ write_htdocs($channel, $os, "$versions_str-$os.xml", $resp);
foreach my $from_version (keys %from_versions) {
$resp = get_response($config, $versions, $os, $from_version);
- write_htdocs($channel, "$from_version-$versions_str-$os.xml", $resp);
+ write_htdocs($channel, $os, "$from_version-$versions_str-$os.xml", $resp);
}
+ write_htdocs($channel, $os, 'no-update.xml',
+ '<?xml version="1.0" encoding="UTF-8"?>'
+ . "\n<updates></updates>\n");
}
- write_htdocs($channel, 'no-update.xml',
- '<?xml version="1.0" encoding="UTF-8"?>'
- . "\n<updates></updates>\n");
}
sub write_htaccess {
my ($config, $channel) = @_;
- my $flags = "[last]";
- my $htaccess = "RewriteEngine On\n";
- $htaccess .= $config->{htaccess_rewrite_rules}{$channel} // '';
+
+ my $htaccess_main = "RewriteEngine On\n";
+ $htaccess_main .= $config->{htaccess_rewrite_rules}{$channel} // '';
my $versions = as_array($config->{channels}{$channel});
my $versions_str = join('+', @$versions);
+ foreach my $os (sort keys %{$config->{build_targets}}) {
+ foreach my $bt (@{ as_array($config->{build_targets}{$os}) }) {
+ $htaccess_main .= "RewriteRule ^$bt/(.*) $os/\$1 [last]\n";
+ }
+ }
+ write_htdocs($channel, '.', '.htaccess', $htaccess_main);
+
my (%oses, %from_versions);
foreach my $version (@$versions) {
my $files = $config->{versions}{$version}{files};
@@ -445,20 +437,20 @@ sub write_htaccess {
$from_versions{$from_version} = 1;
}
}
- $htaccess .= "RewriteRule ^[^\/]+/$version/ no-update.xml $flags\n";
}
- foreach my $os (sort keys %oses) {
- foreach my $bt (build_targets_by_os($os)) {
+ foreach my $version (@$versions) {
+ my $files = $config->{versions}{$version}{files};
+ foreach my $os (sort keys %oses) {
+ my $htaccess_os = "RewriteEngine On\n";
+ $htaccess_os .= "RewriteRule ^$version/ no-update.xml [last]\n";
foreach my $from_version (sort keys %from_versions) {
- $htaccess .= "RewriteRule ^$bt/$from_version/ALL "
- . "$from_version-$versions_str-$os.xml $flags\n";
+ $htaccess_os .= "RewriteRule ^$from_version/ "
+ . "$from_version-$versions_str-$os.xml [last]\n";
}
- $htaccess .= "RewriteRule ^$bt/[^\/]+/ALL "
- . "$versions_str-$os.xml $flags\n";
- $htaccess .= "RewriteRule ^$bt/ $versions_str-$os.xml $flags\n";
+ $htaccess_os .= "RewriteRule ^[^\/]+/ $versions_str-$os.xml [last]\n";
+ write_htdocs($channel, $os, '.htaccess', $htaccess_os);
}
}
- write_htdocs($channel, '.htaccess', $htaccess);
}
sub write_downloads_json {
@@ -472,11 +464,11 @@ sub write_downloads_json {
tag => "$tag",
downloads => get_version_downloads($config, $version),
};
- write_htdocs($channel, 'downloads.json',
+ write_htdocs($channel, '.', 'downloads.json',
JSON->new->utf8->canonical->encode($data));
my $pp_downloads = get_perplatform_downloads($config, $version, $tag);
foreach my $os (keys %{$pp_downloads}) {
- write_htdocs($channel, "download-$os.json",
+ write_htdocs($channel, '.', "download-$os.json",
JSON->new->utf8->canonical->encode($pp_downloads->{$os}));
}
}
@@ -636,11 +628,9 @@ my %actions = (
exit_error "Wrong arguments" unless @ARGV == 1;
my $channel = $ARGV[0];
exit_error "Unknown channel $channel" unless $config->{channels}{$channel};
- $htdocsfiles{$channel} = { '.' => 1, '..' => 1 };
write_responses($config, $channel);
write_htaccess($config, $channel);
write_downloads_json($config, $channel);
- clean_htdocs($channel);
},
gen_incrementals => sub {
my ($config) = @_;
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser-build/-/compare/…
--
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser-build/-/compare/…
You're receiving this email because of your account on gitlab.torproject.org.
1
0

[Git][tpo/applications/tor-browser-build][main] 3 commits: Bug 41374: Remove support for migrate_archs and migrate_langs in update_responses
by morgan (@morgan) 18 Feb '25
by morgan (@morgan) 18 Feb '25
18 Feb '25
morgan pushed to branch main at The Tor Project / Applications / tor-browser-build
Commits:
8adf3820 by Nicolas Vigier at 2025-02-18T13:29:49+00:00
Bug 41374: Remove support for migrate_archs and migrate_langs in update_responses
Those options have not been used for some time, and removing them
simplifies the following changes we're doing to split files per platform.
- - - - -
16dabc5e by Nicolas Vigier at 2025-02-18T13:29:49+00:00
Bug 40799: Remove legacy locale iteration in update-responses
- - - - -
002fb3b9 by Nicolas Vigier at 2025-02-18T13:29:49+00:00
Bug 40799: Remove legacy locale support in tools/dmg2mar
- - - - -
3 changed files:
- projects/release/update_responses_config.yml
- tools/dmg2mar
- tools/update-responses/update_responses
Changes:
=====================================
projects/release/update_responses_config.yml
=====================================
@@ -51,10 +51,6 @@ versions:
- [% ver %]
[% END;
END -%]
- # for example, osx32: osx64
- migrate_archs:
- # for example, pt-PT: pt-BR
- migrate_langs:
# minSupportedOsVersion on macOS corresponds to the Darwin version ( https://en.wikipedia.org/wiki/Darwin_(operating_system) )
macos:
# macOS v10.15.0
=====================================
tools/dmg2mar
=====================================
@@ -102,7 +102,7 @@ sub get_dmg_files_from_sha256sums {
next unless $filename;
chomp $filename;
next unless $filename =~ m/^$appname_dmg-macos-(.+)\.dmg$/;
- push @files, { filename => $filename, version => $1, lang => 'ALL' };
+ push @files, { filename => $filename, version => $1 };
}
return @files;
}
@@ -116,11 +116,7 @@ sub convert_files {
print "Finished $_[2]\n";
});
foreach my $file (get_dmg_files_from_sha256sums) {
- # The 'ja' locale is a special case: it is called 'ja-JP-mac'
- # internally on OSX, but the dmg file still uses 'ja' to avoid
- # confusing users.
- my $mar_lang = $file->{lang} eq 'ja' ? 'ja-JP-mac' : $file->{lang};
- my $output = "$appname_mar-macos-$file->{version}_$mar_lang.mar";
+ my $output = "$appname_mar-macos-$file->{version}_ALL.mar";
my $step_name = "$file->{filename} -> $output";
print "Starting $step_name\n";
$pm->start($step_name) and next;
=====================================
tools/update-responses/update_responses
=====================================
@@ -113,9 +113,9 @@ sub get_version_files {
foreach my $file (readdir $d) {
next unless -f "$vdir/$file";
if ($file !~ m/incremental\.mar$/ &&
- $file =~ m/^$appname-(.+)-${version}_(.+)\.mar$/) {
- my ($os, $lang) = ($1, $2);
- $files->{$os}{$lang}{complete} = {
+ $file =~ m/^$appname-(.+)-${version}_ALL\.mar$/) {
+ my $os = $1;
+ $files->{$os}{complete} = {
type => 'complete',
URL => "$download_url/$file",
size => -s "$vdir/$file",
@@ -126,9 +126,9 @@ sub get_version_files {
};
next;
}
- if ($file =~ m/^$appname-(.+)--(.+)-${version}_(.+)\.incremental\.mar$/) {
- my ($os, $from_version, $lang) = ($1, $2, $3);
- $files->{$os}{$lang}{partial}{$from_version} = {
+ if ($file =~ m/^$appname-(.+)--(.+)-${version}_ALL\.incremental\.mar$/) {
+ my ($os, $from_version) = ($1, $2);
+ $files->{$os}{partial}{$from_version} = {
type => 'partial',
URL => "$download_url/$file",
size => -s "$vdir/$file",
@@ -235,14 +235,14 @@ sub extract_mar {
}
sub mar_filename {
- my ($config, $appname, $version, $os, $lang) = @_;
- version_dir($config, $version) . "/$appname-$os-${version}_$lang.mar";
+ my ($config, $appname, $version, $os) = @_;
+ version_dir($config, $version) . "/$appname-$os-${version}_ALL.mar";
}
sub create_incremental_mar {
- my ($config, $pm, $from_version, $new_version, $os, $lang, $channel) = @_;
+ my ($config, $pm, $from_version, $new_version, $os, $channel) = @_;
my $appname = $config->{appname_marfile};
- my $mar_file = "$appname-$os--${from_version}-${new_version}_$lang.incremental.mar";
+ my $mar_file = "$appname-$os--${from_version}-${new_version}_ALL.incremental.mar";
my $mar_file_path = version_dir($config, $new_version) . '/' . $mar_file;
if ($ENV{MAR_SKIP_EXISTING} && -f $mar_file_path) {
print "Skipping $mar_file\n";
@@ -253,7 +253,7 @@ sub create_incremental_mar {
my $finished_file = sub {
exit_error "Error creating $mar_file" unless $_[1] == 0;
print "Finished $mar_file\n";
- $config->{versions}{$new_version}{files}{$os}{$lang}{partial}{$from_version} = {
+ $config->{versions}{$new_version}{files}{$os}{partial}{$from_version} = {
type => 'partial',
URL => "$download_url/$mar_file",
size => -s $mar_file_path,
@@ -267,9 +267,9 @@ sub create_incremental_mar {
my $tmpdir = get_tmpdir($config);
my $mar_c_from = get_config($config, $from_version, $os, 'mar_compression');
my $mar_c_new = get_config($config, $new_version, $os, 'mar_compression');
- extract_mar(mar_filename($config, $appname, $from_version, $os, $lang),
+ extract_mar(mar_filename($config, $appname, $from_version, $os),
"$tmpdir/A", $mar_c_from);
- extract_mar(mar_filename($config, $appname, $new_version, $os, $lang),
+ extract_mar(mar_filename($config, $appname, $new_version, $os),
"$tmpdir/B", $mar_c_new);
# bug 26054: make sure previous macOS version is code signed
if (!$ENV{NO_CODESIGNATURE} && ($os eq 'macos')
@@ -306,10 +306,8 @@ sub create_incremental_mars_for_version {
get_version_files($config, $from_version);
my $from_v = $config->{versions}{$from_version};
foreach my $os (keys %{$v->{files}}) {
- foreach my $lang (keys %{$v->{files}{$os}}) {
- next unless defined $from_v->{files}{$os}{$lang}{complete};
- create_incremental_mar($config, $pm, $from_version, $version, $os, $lang, $channel);
- }
+ next unless defined $from_v->{files}{$os}{complete};
+ create_incremental_mar($config, $pm, $from_version, $version, $os, $channel);
}
}
$pm->wait_all_children;
@@ -333,31 +331,29 @@ sub get_buildinfos {
setup_martools;
my $files = $config->{versions}{$version}{files};
foreach my $os (keys %$files) {
- foreach my $lang (keys %{$files->{$os}}) {
- next unless $files->{$os}{$lang}{complete};
- my $tmpdir = get_tmpdir($config);
- my $mar_compression = get_config($config, $version, $os, 'mar_compression');
- extract_mar(
- mar_filename($config, $config->{appname_marfile}, $version, $os, $lang),
- "$tmpdir",
- $mar_compression);
- my $appfile = "$tmpdir/application.ini" if -f "$tmpdir/application.ini";
- $appfile = "$tmpdir/Contents/Resources/application.ini"
- if -f "$tmpdir/Contents/Resources/application.ini";
- exit_error "Could not find application.ini" unless $appfile;
- foreach my $line (read_file($appfile)) {
- if ($line =~ m/^BuildID=(.*)$/) {
- $config->{versions}{$version}{buildID} = $1;
- return;
- }
+ next unless $files->{$os}{complete};
+ my $tmpdir = get_tmpdir($config);
+ my $mar_compression = get_config($config, $version, $os, 'mar_compression');
+ extract_mar(
+ mar_filename($config, $config->{appname_marfile}, $version, $os),
+ "$tmpdir",
+ $mar_compression);
+ my $appfile = "$tmpdir/application.ini" if -f "$tmpdir/application.ini";
+ $appfile = "$tmpdir/Contents/Resources/application.ini"
+ if -f "$tmpdir/Contents/Resources/application.ini";
+ exit_error "Could not find application.ini" unless $appfile;
+ foreach my $line (read_file($appfile)) {
+ if ($line =~ m/^BuildID=(.*)$/) {
+ $config->{versions}{$version}{buildID} = $1;
+ return;
}
- exit_error "Could not extract buildID from application.ini";
}
+ exit_error "Could not extract buildID from application.ini";
}
}
sub get_response {
- my ($config, $versions, $os, $lang, $from_version) = @_;
+ my ($config, $versions, $os, $from_version) = @_;
my $res;
my $writer = XML::Writer->new(OUTPUT => \$res, ENCODING => 'UTF-8');
$writer->xmlDecl;
@@ -384,13 +380,13 @@ sub get_response {
defined $minversion ? ( minSupportedOSVersion => $minversion ) : (),
defined $mininstruc ? ( minSupportedInstructionSet => $mininstruc ) : (),
);
- if (my $patch = $config->{versions}{$version}{files}{$os}{$lang}{complete}) {
+ if (my $patch = $config->{versions}{$version}{files}{$os}{complete}) {
my @sorted_patch = map { $_ => $patch->{$_} } sort keys %$patch;
$writer->startTag('patch', @sorted_patch);
$writer->endTag('patch');
}
if ($from_version) {
- if (my $patch = $config->{versions}{$version}{files}{$os}{$lang}{partial}{$from_version}) {
+ if (my $patch = $config->{versions}{$version}{files}{$os}{partial}{$from_version}) {
my @sorted_patch = map { $_ => $patch->{$_} } sort keys %$patch;
$writer->startTag('patch', @sorted_patch);
$writer->endTag('patch');
@@ -407,38 +403,25 @@ sub get_response {
sub write_responses {
my ($config, $channel) = @_;
my $versions = as_array($config->{channels}{$channel});
- my (%oses, %langs, %from_versions);
+ my (%oses, %from_versions);
foreach my $version (@$versions) {
get_version_files($config, $version);
get_buildinfos($config, $version);
my $files = $config->{versions}{$version}{files};
- my $migrate_archs = $config->{versions}{$version}{migrate_archs} // {};
- foreach my $old_os (keys %$migrate_archs) {
- my $new_os = $migrate_archs->{$old_os};
- foreach my $lang (keys %{$files->{$new_os}}) {
- $files->{$old_os}{$lang}{complete} =
- $files->{$new_os}{$lang}{complete};
- }
- }
foreach my $os (keys %$files) {
$oses{$os} = 1;
- foreach my $lang (keys %{$files->{$os}}) {
- $langs{$lang} = 1;
- foreach my $from_version (keys %{$files->{$os}{$lang}{partial}}) {
- $from_versions{$from_version} = 1;
- }
+ foreach my $from_version (keys %{$files->{$os}{partial}}) {
+ $from_versions{$from_version} = 1;
}
}
}
my $versions_str = join('+', @$versions);
foreach my $os (keys %oses) {
- foreach my $lang (keys %langs) {
- my $resp = get_response($config, $versions, $os, $lang);
- write_htdocs($channel, "$versions_str-$os-$lang.xml", $resp);
- foreach my $from_version (keys %from_versions) {
- $resp = get_response($config, $versions, $os, $lang, $from_version);
- write_htdocs($channel, "$from_version-$versions_str-$os-$lang.xml", $resp);
- }
+ my $resp = get_response($config, $versions, $os);
+ write_htdocs($channel, "$versions_str-$os.xml", $resp);
+ foreach my $from_version (keys %from_versions) {
+ $resp = get_response($config, $versions, $os, $from_version);
+ write_htdocs($channel, "$from_version-$versions_str-$os.xml", $resp);
}
}
write_htdocs($channel, 'no-update.xml',
@@ -453,38 +436,26 @@ sub write_htaccess {
$htaccess .= $config->{htaccess_rewrite_rules}{$channel} // '';
my $versions = as_array($config->{channels}{$channel});
my $versions_str = join('+', @$versions);
- my (%oses, %langs, %from_versions);
- my $migrate_langs;
+ my (%oses, %from_versions);
foreach my $version (@$versions) {
- $migrate_langs = $config->{versions}{$version}{migrate_langs}
- if $config->{versions}{$version}{migrate_langs};
my $files = $config->{versions}{$version}{files};
foreach my $os (keys %$files) {
$oses{$os} = 1;
- foreach my $lang (keys %{$files->{$os}}) {
- $langs{$lang} = 1;
- foreach my $from_version (keys %{$files->{$os}{$lang}{partial}}) {
- $from_versions{$from_version} = 1;
- }
+ foreach my $from_version (keys %{$files->{$os}{partial}}) {
+ $from_versions{$from_version} = 1;
}
}
$htaccess .= "RewriteRule ^[^\/]+/$version/ no-update.xml $flags\n";
}
foreach my $os (sort keys %oses) {
foreach my $bt (build_targets_by_os($os)) {
- foreach my $lang (sort keys %langs) {
- foreach my $from_version (sort keys %from_versions) {
- $htaccess .= "RewriteRule ^$bt/$from_version/$lang "
- . "$from_version-$versions_str-$os-$lang.xml $flags\n";
- }
- $htaccess .= "RewriteRule ^$bt/[^\/]+/$lang "
- . "$versions_str-$os-$lang.xml $flags\n";
+ foreach my $from_version (sort keys %from_versions) {
+ $htaccess .= "RewriteRule ^$bt/$from_version/ALL "
+ . "$from_version-$versions_str-$os.xml $flags\n";
}
- foreach my $lang (sort keys %$migrate_langs) {
- $htaccess .= "RewriteRule ^$bt/[^\/]+/$lang "
- . "$versions_str-$os-$migrate_langs->{$lang}.xml $flags\n";
- }
- $htaccess .= "RewriteRule ^$bt/ $versions_str-$os-ALL.xml $flags\n";
+ $htaccess .= "RewriteRule ^$bt/[^\/]+/ALL "
+ . "$versions_str-$os.xml $flags\n";
+ $htaccess .= "RewriteRule ^$bt/ $versions_str-$os.xml $flags\n";
}
}
write_htdocs($channel, '.htaccess', $htaccess);
@@ -567,28 +538,26 @@ sub check_update_responses_channel {
my $channel_versions = as_array($config->{channels}{$channel});
my ($channel_version) = @$channel_versions;
foreach my $build_target (build_targets_list()) {
- foreach my $lang (qw(en-US de)) {
- my $url = "$base_url/$channel/$build_target/1.0/$lang";
- my $dom = get_remote_xml($url);
- if ($dom) {
- my $version = check_get_version($dom);
- log_step($url, 'version', $version eq $channel_version,
- "expected: $channel_version received: $version");
- }
- $url = "$base_url/$channel/$build_target/$channel_version/$lang";
+ my $url = "$base_url/$channel/$build_target/1.0/ALL";
+ my $dom = get_remote_xml($url);
+ if ($dom) {
+ my $version = check_get_version($dom);
+ log_step($url, 'version', $version eq $channel_version,
+ "expected: $channel_version received: $version");
+ }
+ $url = "$base_url/$channel/$build_target/$channel_version/ALL";
+ $dom = get_remote_xml($url);
+ log_step($url, 'no_update', check_no_update($dom)) if $dom;
+ my @inc = @{$config->{versions}{$channel_version}{incremental_from}}
+ if $config->{versions}{$channel_version}{incremental_from};
+ foreach my $inc_from (@inc) {
+ my $url = "$base_url/$channel/$build_target/$inc_from/ALL";
$dom = get_remote_xml($url);
- log_step($url, 'no_update', check_no_update($dom)) if $dom;
- my @inc = @{$config->{versions}{$channel_version}{incremental_from}}
- if $config->{versions}{$channel_version}{incremental_from};
- foreach my $inc_from (@inc) {
- my $url = "$base_url/$channel/$build_target/$inc_from/$lang";
- $dom = get_remote_xml($url);
- next unless $dom;
- my $version = check_get_version($dom);
- log_step($url, 'version', $version eq $channel_version,
- "expected: $channel_version received: $version");
- log_step($url, 'has_incremental', check_has_incremental($dom));
- }
+ next unless $dom;
+ my $version = check_get_version($dom);
+ log_step($url, 'version', $version eq $channel_version,
+ "expected: $channel_version received: $version");
+ log_step($url, 'has_incremental', check_has_incremental($dom));
}
}
}
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser-build/-/compare/…
--
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser-build/-/compare/…
You're receiving this email because of your account on gitlab.torproject.org.
1
0

[Git][tpo/applications/tor-browser-build][main] Bug 41372: Handle branding strings for tor-browser build.
by Pier Angelo Vendrame (@pierov) 18 Feb '25
by Pier Angelo Vendrame (@pierov) 18 Feb '25
18 Feb '25
Pier Angelo Vendrame pushed to branch main at The Tor Project / Applications / tor-browser-build
Commits:
858ee2ee by Henry Wilkes at 2025-02-18T11:35:44+00:00
Bug 41372: Handle branding strings for tor-browser build.
- - - - -
3 changed files:
- projects/firefox/build
- projects/firefox/config
- + projects/firefox/rename-branding-strings.py
Changes:
=====================================
projects/firefox/build
=====================================
@@ -136,15 +136,50 @@ branding_dir=browser/branding/[% c("var/branding_directory_prefix") %]-[% c("var
[% IF c("var/tor-browser") -%]
tar -C "$rootdir" -xf "$rootdir/[% c('input_files_by_name/translation-tor-browser') %]"
+
+ # For the purpose of Weblate, all releases share a single brand.ftl and
+ # brand.properties file per locale in the translations repository.
+ # See tor-browser-build#41372.
+ # In brand.ftl, both `-brand-short-name` and `-brand-full-name` should
+ # differ between releases. As such, they have additional entries in the
+ # translations repository file (Weblate):
+ # -brand-short-name for the stable release.
+ # -brand-short-name_alpha for the alpha release.
+ # -brand-short-name_nightly for the nightly release.
+ # And similarly for -brand-full-name.
+ # For the final build, we only want to keep the string that matches the
+ # built release, and remove its suffix if it has one. So for the stable
+ # release we want to keep -brand-short-name. For the alpha release we want
+ # to keep -brand-short-name_alpha instead, and rename it to be
+ # -brand-short-name.
+ #
+ # As such, we parse the brand.ftl file to rename these strings to keep the
+ # version we want using rename-branding-strings.py.
+ #
+ # We do a similar thing with brandShortName and brandFullName in
+ # brand.properties.
+
+ # Instructions for the script to perform the renames.
+ brand_ftl_renames='{
+ "suffix": "[% c("var/branding_string_suffix") %]",
+ "ids": ["-brand-short-name", "-brand-full-name"]
+ }'
+ brand_properties_renames='{
+ "suffix": "[% c("var/branding_string_suffix") %]",
+ "ids": ["brandShortName", "brandFullName"]
+ }'
+
pushd "$rootdir/translation-tor-browser"
ln -s ja ja-JP-mac
for lang in $supported_locales; do
mv $lang/tor-browser.ftl "$l10ncentral/$lang/toolkit/toolkit/global/"
- # Branding. Currently all releases use the same branding.
+ # Branding.
l10n_branding_dir="$l10ncentral/$lang/$branding_dir/"
mkdir -p "$l10n_branding_dir"
- mv $lang/branding/brand.ftl "$l10n_branding_dir"
- mv $lang/brand.properties "$l10n_branding_dir"
+ # Convert the translations repository branding files into files that work
+ # for this specific build.
+ python3 rename-branding-strings.py $lang/branding/brand.ftl "$brand_ftl_renames" > "$l10n_branding_dir/brand.ftl"
+ python3 rename-branding-strings.py $lang/brand.properties "$brand_properties_renames" > "$l10n_branding_dir/brand.properties"
done
popd
=====================================
projects/firefox/config
=====================================
@@ -54,6 +54,10 @@ var:
rm -Rf "$rezip_tmpdir"
l10n-changesets: '[% exec("git --no-pager show " _ c("git_hash") _ ":browser/locales/l10n-changesets.json", { exec_noco => 1 }) %]'
+ # The branding_string_suffix for the alpha and nightly should be
+ # '_alpha' and '_nightly', matching the "suffix" chosen in the
+ # tor-browser:update-translations.yml file.
+ branding_string_suffix: '_[% c("var/channel") %]'
steps:
src-tarballs:
@@ -94,6 +98,12 @@ targets:
var:
nightly_updates_publish_dir_prefix: basebrowser-
+ release:
+ var:
+ # For the stable release, the suffix is empty.
+ # I.e. we want to select `-brand-short-name` directly.
+ branding_string_suffix: ''
+
nightly:
git_hash: '[% c("var/project-name") %]-[% c("var/firefox_version") %]-[% c("var/browser_branch") %]'
tag_gpg_id: 0
@@ -183,6 +193,8 @@ input_files:
- project: binutils
name: binutils
enable: '[% c("var/linux") && ! c("var/linux-cross") %]'
+ - filename: rename-branding-strings.py
+ enable: '[% c("var/has_l10n") && c("var/tor-browser") %]'
- filename: fix-info-plist.py
enable: '[% c("var/macos") %]'
- filename: nsis-uninstall.patch
=====================================
projects/firefox/rename-branding-strings.py
=====================================
@@ -0,0 +1,96 @@
+import argparse
+import json
+import re
+
+arg_parser = argparse.ArgumentParser(
+ description="Filter a branding file to only include the expected strings"
+)
+arg_parser.add_argument("file", metavar="<file>", help="branding file to process")
+arg_parser.add_argument(
+ "details", metavar="<details>", help="JSON specification for renaming"
+)
+
+args = arg_parser.parse_args()
+details_dict = json.loads(args.details)
+# The suffix we want to search for or remove.
+# Can be empty if we want to select the IDs that have no suffix.
+suffix = details_dict["suffix"]
+# The string IDs we want to rename.
+rename_ids = details_dict["ids"]
+
+
+def parse_ids(string, pattern):
+ """
+ Extract the IDs found in a string.
+
+ :param string: The string to parse.
+ :param pattern: The pattern to capture IDs.
+
+ :yields: A tuple containing a chunk of string and whether the chunk
+ is an ID.
+ """
+ regex = re.compile(pattern, flags=re.MULTILINE + re.ASCII)
+ while True:
+ match = regex.search(string)
+ if not match:
+ yield string, False
+ return
+
+ yield string[: match.start("id")], False
+ yield match.group("id"), True
+ string = string[match.end("id") :]
+
+
+# We want to parse the file and rename the IDs we are interested in.
+# If the ID starts with one of the `rename_ids` but the suffix does
+# not match we append an "_UNUSED" suffix to the ID, to keep it in the output
+# but functionally unused in the final build.
+# Otherwise, if the ID starts with one of the `rename_ids` and the suffix
+# matches we will remove the suffix from the ID, so that it is used in the
+# final build.
+# Everything else found in the file, like entry values, comments and blank
+# lines, will be included in the output as it was.
+#
+# NOTE: This script is constructed to be *independent* of the order in which
+# strings are present in the file. Weblate does not guarantee the order of
+# translated files to use the same ordering as the original en-US file.
+#
+# NOTE: This script should work for all locales. In particular, for Fluent files
+# it needs to be able to handle Fluent Terms that are multi-valued (conditional)
+# and Terms with attributes. Therefore, whilst we could have written a script to
+# *remove* unwanted strings, the parsing logic would have been far more complex
+# to be able to handle all these cases. Hence why we only parse for the Fluent
+# IDs and rename them, which is much simpler.
+with open(args.file, "r") as file:
+ if file.name.endswith(".ftl"):
+ # A Fluent ID is the identifier for a Message or Term, which always
+ # starts on a newline, and will be followed by an "=" character.
+ id_pattern = r"^(?P<id>-?[a-zA-Z][a-zA-Z0-9_-]*) *="
+ elif file.name.endswith(".properties"):
+ # A properties ID can be preceded by whitespace, and can be any
+ # character other than whitespace, ":" or "=". The first character also
+ # cannot be "!" or "#" since this starts a comment. Technically the
+ # Java ".properties" spec allows a ID to include one of these characters
+ # if it is escaped by a "\", but we don't expect or care about such IDs.
+ # The Java spec also has a limited set of whitespace, which excludes
+ # "\v", but we do not expect Weblate or any other serialiser to
+ # insert whitespace beyond "\n", "\r", "\t" or " ".
+ id_pattern = r"^\s*(?P<id>[^!#:=\s][^:=\s]*)"
+ else:
+ raise ValueError(f"Unknown file type {file.name}")
+
+ for part, is_id in parse_ids(file.read(), id_pattern):
+ if is_id:
+ for string_id in rename_ids:
+ if part.startswith(string_id):
+ if part == string_id + suffix:
+ # This string matches the suffix, so we want to use its
+ # value. We adjust the ID to remove the suffix before
+ # printing.
+ part = string_id
+ else:
+ # Keep this entry in the output, but make it unused by
+ # appending to the ID.
+ part += "_UNUSED"
+ break
+ print(part, end="")
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser-build/-/commit/8…
--
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser-build/-/commit/8…
You're receiving this email because of your account on gitlab.torproject.org.
1
0

[Git][tpo/applications/tor-browser][tor-browser-128.7.0esr-14.5-1] 3 commits: fixup! Add CI for Tor Browser
by Pier Angelo Vendrame (@pierov) 18 Feb '25
by Pier Angelo Vendrame (@pierov) 18 Feb '25
18 Feb '25
Pier Angelo Vendrame pushed to branch tor-browser-128.7.0esr-14.5-1 at The Tor Project / Applications / Tor Browser
Commits:
d9fe34de by Henry Wilkes at 2025-02-18T10:08:15+00:00
fixup! Add CI for Tor Browser
TB 43446: Include alpha and nightly branding in the translation CI.
- - - - -
34838694 by Henry Wilkes at 2025-02-18T10:10:32+00:00
fixup! BB 42305: Add script to combine translation files across versions.
TB 43446: Allow the combine translation script to select some branding
strings from different files.
- - - - -
6fa642ea by Henry Wilkes at 2025-02-18T10:10:33+00:00
fixup! TB 2176: Rebrand Firefox to TorBrowser
TB 43446: Change the branding name for the alpha and nightly releases.
- - - - -
13 changed files:
- .gitlab/ci/jobs/update-translations.yml
- browser/branding/tb-alpha/locales/en-US/brand.ftl
- browser/branding/tb-alpha/locales/en-US/brand.properties
- browser/branding/tb-nightly/locales/en-US/brand.ftl
- browser/branding/tb-nightly/locales/en-US/brand.properties
- browser/branding/tb-release/locales/en-US/brand.ftl
- browser/branding/tb-release/locales/en-US/brand.properties
- tools/base-browser/l10n/combine-translation-versions.py
- tools/base-browser/l10n/combine/combine.py
- tools/base-browser/l10n/combine/tests/test_android.py
- tools/base-browser/l10n/combine/tests/test_dtd.py
- tools/base-browser/l10n/combine/tests/test_fluent.py
- tools/base-browser/l10n/combine/tests/test_properties.py
Changes:
=====================================
.gitlab/ci/jobs/update-translations.yml
=====================================
@@ -17,12 +17,48 @@
{
"name": "brand.ftl",
"where": ["browser/branding/tb-release", "toolkit/torbutton"],
+ "branding": {
+ "versions": [
+ {
+ "name": "Alpha",
+ "suffix": "_alpha",
+ "where": ["browser/branding/tb-alpha"]
+ },
+ {
+ "name": "Nightly",
+ "suffix": "_nightly",
+ "where": ["browser/branding/tb-nightly"]
+ }
+ ],
+ "ids": [
+ "-brand-short-name",
+ "-brand-full-name"
+ ]
+ },
"branch": "tor-browser",
"directory": "branding"
},
{
"name": "brand.properties",
"where": ["browser/branding/tb-release", "toolkit/torbutton"],
+ "branding": {
+ "versions": [
+ {
+ "name": "Alpha",
+ "suffix": "_alpha",
+ "where": ["browser/branding/tb-alpha"]
+ },
+ {
+ "name": "Nightly",
+ "suffix": "_nightly",
+ "where": ["browser/branding/tb-nightly"]
+ }
+ ],
+ "ids": [
+ "brandShortName",
+ "brandFullName"
+ ]
+ },
"branch": "tor-browser"
},
{ "name": "tor-browser.ftl", "branch": "tor-browser" },
=====================================
browser/branding/tb-alpha/locales/en-US/brand.ftl
=====================================
@@ -2,12 +2,16 @@
# that is used by Firefox) to avoid picking up the -brand-short-name values
# that Mozilla includes in the Firefox language packs.
+# The shortened application name for Tor Browser. Shared between versions.
-brand-shorter-name = Tor Browser
--brand-short-name = Tor Browser
--brand-full-name = Tor Browser
+# The default application name for the "alpha" release.
+-brand-short-name = Tor Browser Alpha
+# The full application name for the "alpha" release.
+-brand-full-name = Tor Browser Alpha
# This brand name can be used in messages where the product name needs to
# remain unchanged across different versions (Nightly, Beta, etc.).
-brand-product-name = Tor Browser
+# The name of the Tor Project organisation.
-vendor-short-name = Tor Project
# "Tor" is a trademark names, so should not be translated (not including the quote marks, which can be localized).
# "The Tor Project, Inc." is an organisation name.
=====================================
browser/branding/tb-alpha/locales/en-US/brand.properties
=====================================
@@ -3,6 +3,9 @@
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
+# The shortened application name for Tor Browser. Shared between versions.
brandShorterName=Tor Browser
-brandShortName=Tor Browser
-brandFullName=Tor Browser
+# The default application name for the "alpha" release.
+brandShortName=Tor Browser Alpha
+# The full application name for the "alpha" release.
+brandFullName=Tor Browser Alpha
=====================================
browser/branding/tb-nightly/locales/en-US/brand.ftl
=====================================
@@ -2,12 +2,16 @@
# that is used by Firefox) to avoid picking up the -brand-short-name values
# that Mozilla includes in the Firefox language packs.
+# The shortened application name for Tor Browser. Shared between versions.
-brand-shorter-name = Tor Browser
--brand-short-name = Tor Browser
--brand-full-name = Tor Browser
+# The default application name for the "nightly" release.
+-brand-short-name = Tor Browser Nightly
+# The full application name for the "nightly" release.
+-brand-full-name = Tor Browser Nightly
# This brand name can be used in messages where the product name needs to
# remain unchanged across different versions (Nightly, Beta, etc.).
-brand-product-name = Tor Browser
+# The name of the Tor Project organisation.
-vendor-short-name = Tor Project
# "Tor" is a trademark names, so should not be translated (not including the quote marks, which can be localized).
# "The Tor Project, Inc." is an organisation name.
=====================================
browser/branding/tb-nightly/locales/en-US/brand.properties
=====================================
@@ -3,6 +3,9 @@
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
+# The shortened application name for Tor Browser. Shared between versions.
brandShorterName=Tor Browser
-brandShortName=Tor Browser
-brandFullName=Tor Browser
+# The default application name for the "nightly" release.
+brandShortName=Tor Browser Nightly
+# The full application name for the "nightly" release.
+brandFullName=Tor Browser Nightly
=====================================
browser/branding/tb-release/locales/en-US/brand.ftl
=====================================
@@ -2,12 +2,16 @@
# that is used by Firefox) to avoid picking up the -brand-short-name values
# that Mozilla includes in the Firefox language packs.
+# The shortened application name for Tor Browser. Shared between versions.
-brand-shorter-name = Tor Browser
+# The default application name for the stable release.
-brand-short-name = Tor Browser
+# The full application name for the stable release.
-brand-full-name = Tor Browser
# This brand name can be used in messages where the product name needs to
# remain unchanged across different versions (Nightly, Beta, etc.).
-brand-product-name = Tor Browser
+# The name of the Tor Project organisation.
-vendor-short-name = Tor Project
# "Tor" is a trademark names, so should not be translated (not including the quote marks, which can be localized).
# "The Tor Project, Inc." is an organisation name.
=====================================
browser/branding/tb-release/locales/en-US/brand.properties
=====================================
@@ -3,6 +3,9 @@
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
+# The shortened application name for Tor Browser. Shared between versions.
brandShorterName=Tor Browser
+# The default application name for the stable release.
brandShortName=Tor Browser
+# The full application name for the stable release.
brandFullName=Tor Browser
=====================================
tools/base-browser/l10n/combine-translation-versions.py
=====================================
@@ -306,9 +306,34 @@ for file_dict in json.loads(args.files):
f"{current_file.path} : {stable_file.path}"
)
+ content = None if current_file is None else current_file.content
+
+ # If we have a branding file, we want to also include strings from the other
+ # branding directories that differ from the stable release.
+ # The strings that *differ* per release should be specified in
+ # file_dict["branding"]["ids"]. These strings will be copied from the other
+ # release's branding directory, with an addition suffix added to their ID,
+ # as specified in the version_dict["suffix"].
+ branding = file_dict.get("branding", None)
+ if branding:
+ include_ids = branding["ids"]
+ for version_dict in branding["versions"]:
+ branding_dirs = version_dict.get("where", None)
+ branding_file = current_branch.get_file(name, branding_dirs)
+ if branding_file is None:
+ raise Exception(f"{name} does not exist in {branding_dirs}")
+ content = combine_files(
+ name,
+ content,
+ branding_file.content,
+ f'{version_dict["name"]} Release.',
+ include_ids,
+ version_dict["suffix"],
+ )
+
content = combine_files(
name,
- None if current_file is None else current_file.content,
+ content,
None if stable_file is None else stable_file.content,
f"Will be unused in {current_branch.browser_version_name}!",
)
=====================================
tools/base-browser/l10n/combine/combine.py
=====================================
@@ -14,26 +14,32 @@ if TYPE_CHECKING:
def combine_files(
filename: str,
- new_content: str | None,
- old_content: str | None,
+ primary_content: str | None,
+ alternative_content: str | None,
comment_prefix: str,
+ include_ids: list[str] | None = None,
+ alternative_suffix: str = "",
) -> str | None:
"""Combine two translation files into one to include all strings from both.
- The new content is presented first, and any strings only found in the old
- content are placed at the end with an additional comment.
+ The primary content is presented first, followed by the alternative content
+ at the end with an additional comment.
:param filename: The filename for the file, determines the format.
- :param new_content: The new content for the file, or None if it has been
- deleted.
- :param old_content: The old content for the file, or None if it did not
- exist before.
- :comment_prefix: A comment to include for any strings that are only found in
- the old content. This will be placed before any other comments for the
- string.
+ :param primary_content: The primary content for the file, or None if it does
+ not exist.
+ :param alternative_content: The alternative content for the file, or None if
+ it does not exist.
+ :param comment_prefix: A comment to include for any strings that are
+ appended to the content. This will be placed before any other comments for
+ the string.
+ :param include_ids: String IDs from `alternative_content` we want to
+ include. If this is `None` then we include all strings that do not already
+ have a matching ID in `primary_content`.
+ :param duplicate_suffix: The suffix to apply to the alternative IDs.
:returns: The combined content, or None if both given contents are None.
"""
- if new_content is None and old_content is None:
+ if primary_content is None and alternative_content is None:
return None
# getParser from compare_locale returns the same instance for the same file
@@ -41,7 +47,7 @@ def combine_files(
parser = getParser(filename)
is_android = filename.endswith(".xml")
- if new_content is None:
+ if primary_content is None:
if is_android:
# File was deleted, add some document parts.
content_start = (
@@ -54,7 +60,7 @@ def combine_files(
content_end = ""
existing_keys = []
else:
- parser.readUnicode(new_content)
+ parser.readUnicode(primary_content)
# Start with the same content as the current file.
# For android strings, we want to keep the final "</resources>" until after.
@@ -96,8 +102,8 @@ def combine_files(
entry_iter: Iterable[Any] = ()
# If the file does not exist in the old branch, don't make any additions.
- if old_content is not None:
- parser.readUnicode(old_content)
+ if alternative_content is not None:
+ parser.readUnicode(alternative_content)
entry_iter = parser.walk(only_localizable=False)
for entry in entry_iter:
if isinstance(entry, Junk):
@@ -134,13 +140,19 @@ def combine_files(
if not isinstance(entry, Entity):
raise ValueError(f"Unexpected type: {entry.__class__.__name__}")
- if entry.key in existing_keys:
- # Already included this string in the new translation file.
+ if include_ids is None:
+ # We include the entry if it is not already included.
+ include_entry = entry.key not in existing_keys
+ else:
+ # We include the entry if it is in our list.
+ include_entry = entry.key in include_ids
+ if not include_entry:
# Drop the gathered comments for this Entity.
stacked_comments.clear()
continue
if isinstance(entry, FluentEntity):
+ id_regex = rf"^({re.escape(entry.key)})( *=)"
if fluent_group_comment is not None:
# We have a found GroupComment which has not been included yet.
# All following Entity's will be under its scope, until the next
@@ -149,12 +161,15 @@ def combine_files(
# Added GroupComment, so don't need to add again.
fluent_group_comment = None
elif isinstance(entry, DTDEntity):
+ id_regex = rf"^(\s*<!ENTITY\s*{re.escape(entry.key)})(\s)"
# Include our additional comment before we print the rest for this
# Entity.
additions.append(f"<!-- LOCALIZATION NOTE: {comment_prefix} -->")
elif isinstance(entry, PropertiesEntity):
+ id_regex = rf"^({re.escape(entry.key)})( *=)"
additions.append(f"# {comment_prefix}")
elif isinstance(entry, AndroidEntity):
+ id_regex = rf'^(\s*<string\s[^>]*name="{re.escape(entry.key)})(")'
additions.append(f"<!-- {comment_prefix} -->")
else:
raise ValueError(f"Unexpected Entity type: {entry.__class__.__name__}")
@@ -162,7 +177,17 @@ def combine_files(
# Add any other comment lines that came directly before this Entity.
additions.extend(stacked_comments)
stacked_comments.clear()
- additions.append(entry.all)
+ entry_content = entry.all
+ if alternative_suffix:
+ # NOTE: compare_locales does not allow us to set the entry.key
+ # value. Instead we use a regular expression to append the suffix to
+ # the expected key.
+ entry_content, count = re.subn(
+ id_regex, rf"\1{alternative_suffix}\2", entry_content, flags=re.M
+ )
+ if count != 1:
+ raise ValueError(f"Failed to substitute the ID for {entry.key}")
+ additions.append(entry_content)
content_middle = ""
=====================================
tools/base-browser/l10n/combine/tests/test_android.py
=====================================
@@ -24,6 +24,20 @@ def assert_result(new_content, old_content, expect):
)
+def assert_alternative(content, alternative_content, alternative_ids, expect):
+ content = wrap_in_xml(content)
+ alternative_content = wrap_in_xml(alternative_content)
+ expect = wrap_in_xml(expect)
+ assert expect == combine_files(
+ "test_strings.xml",
+ content,
+ alternative_content,
+ "ALTERNATIVE STRING",
+ alternative_ids,
+ "_alt",
+ )
+
+
def test_combine_empty():
assert_result(None, None, None)
@@ -328,3 +342,74 @@ def test_removed_string_with_comment():
<string name="removed_4">Fourth removed</string>
""",
)
+
+
+def test_alternatives():
+ assert_alternative(
+ """\
+ <string name="string_1">First string</string>
+ """,
+ """\
+ <string name="string_1">Alternative string</string>
+ """,
+ ["string_1"],
+ """\
+ <string name="string_1">First string</string>
+
+ <!-- ALTERNATIVE STRING -->
+ <string name="string_1_alt">Alternative string</string>
+ """,
+ )
+ assert_alternative(
+ """\
+ <!-- Comment 1 -->
+ <string name="string_1">First string</string>
+ <!-- Comment 2 -->
+ <string name="string_2">Second string</string>
+ <string name="string_3">Third string</string>
+ """,
+ """\
+ <string name="string_1">First string</string>
+ <!-- Alt comment -->
+ <string name="string_2">Alternative string</string>
+ <string name="string_3">Third string different</string>
+ <string name="string_4">Other string</string>
+ """,
+ ["string_2"],
+ """\
+ <!-- Comment 1 -->
+ <string name="string_1">First string</string>
+ <!-- Comment 2 -->
+ <string name="string_2">Second string</string>
+ <string name="string_3">Third string</string>
+
+ <!-- ALTERNATIVE STRING -->
+ <!-- Alt comment -->
+ <string name="string_2_alt">Alternative string</string>
+ """,
+ )
+ assert_alternative(
+ """\
+ <string name="string_1">First string</string>
+ <string name="string_2">Second string</string>
+ <string name="string_3">Third string</string>
+ """,
+ """\
+ <string name="string_1">Alternative string</string>
+ <string name="string_3">Third string</string>
+ <!-- comment -->
+ <string name="string_4">Other string</string>
+ """,
+ ["string_1", "string_4"],
+ """\
+ <string name="string_1">First string</string>
+ <string name="string_2">Second string</string>
+ <string name="string_3">Third string</string>
+
+ <!-- ALTERNATIVE STRING -->
+ <string name="string_1_alt">Alternative string</string>
+ <!-- ALTERNATIVE STRING -->
+ <!-- comment -->
+ <string name="string_4_alt">Other string</string>
+ """,
+ )
=====================================
tools/base-browser/l10n/combine/tests/test_dtd.py
=====================================
@@ -16,6 +16,23 @@ def assert_result(new_content, old_content, expect):
)
+def assert_alternative(content, alternative_content, alternative_ids, expect):
+ if content is not None:
+ content = textwrap.dedent(content)
+ if alternative_content is not None:
+ alternative_content = textwrap.dedent(alternative_content)
+ if expect is not None:
+ expect = textwrap.dedent(expect)
+ assert expect == combine_files(
+ "test.dtd",
+ content,
+ alternative_content,
+ "ALTERNATIVE STRING",
+ alternative_ids,
+ ".alt",
+ )
+
+
def test_combine_empty():
assert_result(None, None, None)
@@ -323,3 +340,74 @@ def test_removed_string_with_comment():
<!ENTITY removed.4 "Fourth removed">
""",
)
+
+
+def test_alternatives():
+ assert_alternative(
+ """\
+ <!ENTITY string.1 "First string">
+ """,
+ """\
+ <!ENTITY string.1 "Alternative string">
+ """,
+ ["string.1"],
+ """\
+ <!ENTITY string.1 "First string">
+
+ <!-- LOCALIZATION NOTE: ALTERNATIVE STRING -->
+ <!ENTITY string.1.alt "Alternative string">
+ """,
+ )
+ assert_alternative(
+ """\
+ <!-- LOCALIZATION NOTE: Comment 1 -->
+ <!ENTITY string.1 "First string">
+ <!-- LOCALIZATION NOTE: Comment 2 -->
+ <!ENTITY string.2 "Second string">
+ <!ENTITY string.3 "Third string">
+ """,
+ """\
+ <!ENTITY string.1 "First string">
+ <!-- LOCALIZATION NOTE: Alt comment -->
+ <!ENTITY string.2 "Alternative string">
+ <!ENTITY string.3 "Third string different">
+ <!ENTITY string.4 "Other string">
+ """,
+ ["string.2"],
+ """\
+ <!-- LOCALIZATION NOTE: Comment 1 -->
+ <!ENTITY string.1 "First string">
+ <!-- LOCALIZATION NOTE: Comment 2 -->
+ <!ENTITY string.2 "Second string">
+ <!ENTITY string.3 "Third string">
+
+ <!-- LOCALIZATION NOTE: ALTERNATIVE STRING -->
+ <!-- LOCALIZATION NOTE: Alt comment -->
+ <!ENTITY string.2.alt "Alternative string">
+ """,
+ )
+ assert_alternative(
+ """\
+ <!ENTITY string.1 "First string">
+ <!ENTITY string.2 "Second string">
+ <!ENTITY string.3 "Third string">
+ """,
+ """\
+ <!ENTITY string.1 "Alternative string">
+ <!ENTITY string.3 "Third string">
+ <!-- LOCALIZATION NOTE: comment -->
+ <!ENTITY string.4 "Other string">
+ """,
+ ["string.1", "string.4"],
+ """\
+ <!ENTITY string.1 "First string">
+ <!ENTITY string.2 "Second string">
+ <!ENTITY string.3 "Third string">
+
+ <!-- LOCALIZATION NOTE: ALTERNATIVE STRING -->
+ <!ENTITY string.1.alt "Alternative string">
+ <!-- LOCALIZATION NOTE: ALTERNATIVE STRING -->
+ <!-- LOCALIZATION NOTE: comment -->
+ <!ENTITY string.4.alt "Other string">
+ """,
+ )
=====================================
tools/base-browser/l10n/combine/tests/test_fluent.py
=====================================
@@ -16,6 +16,23 @@ def assert_result(new_content, old_content, expect):
)
+def assert_alternative(content, alternative_content, alternative_ids, expect):
+ if content is not None:
+ content = textwrap.dedent(content)
+ if alternative_content is not None:
+ alternative_content = textwrap.dedent(alternative_content)
+ if expect is not None:
+ expect = textwrap.dedent(expect)
+ assert expect == combine_files(
+ "test.ftl",
+ content,
+ alternative_content,
+ "ALTERNATIVE STRING",
+ alternative_ids,
+ "-alt",
+ )
+
+
def test_combine_empty():
assert_result(None, None, None)
@@ -342,3 +359,119 @@ def test_removed_string_with_comment():
removed-4 = Fourth removed
""",
)
+
+
+def test_alternatives():
+ assert_alternative(
+ """\
+ string-1 = First string
+ .title = hello
+ """,
+ """\
+ string-1 = Alternative string
+ .title = different
+ """,
+ ["string-1"],
+ """\
+ string-1 = First string
+ .title = hello
+
+
+ ## ALTERNATIVE STRING
+
+ string-1-alt = Alternative string
+ .title = different
+ """,
+ )
+ assert_alternative(
+ """\
+ string-1 = First string
+ .title = hello
+ """,
+ """\
+ string-1 = Alternative string
+ """,
+ ["string-1"],
+ """\
+ string-1 = First string
+ .title = hello
+
+
+ ## ALTERNATIVE STRING
+
+ string-1-alt = Alternative string
+ """,
+ )
+ assert_alternative(
+ """\
+ -term-1 = First string
+ """,
+ """\
+ -term-1 = Alternative string
+ """,
+ ["-term-1"],
+ """\
+ -term-1 = First string
+
+
+ ## ALTERNATIVE STRING
+
+ -term-1-alt = Alternative string
+ """,
+ )
+ assert_alternative(
+ """\
+ # Comment 1
+ string-1 = First string
+ # Comment 2
+ string-2 = Second string
+ string-3 = Third string
+ """,
+ """\
+ string-1 = First string
+ # Alt comment
+ string-2 = Alternative string
+ string-3 = Third string different
+ string-4 = Other string
+ """,
+ ["string-2"],
+ """\
+ # Comment 1
+ string-1 = First string
+ # Comment 2
+ string-2 = Second string
+ string-3 = Third string
+
+
+ ## ALTERNATIVE STRING
+
+ # Alt comment
+ string-2-alt = Alternative string
+ """,
+ )
+ assert_alternative(
+ """\
+ string-1 = First string
+ string-2 = Second string
+ string-3 = Third string
+ """,
+ """\
+ string-1 = Alternative string
+ string-3 = Third string
+ # comment
+ -string-4 = Other string
+ """,
+ ["string-1", "-string-4"],
+ """\
+ string-1 = First string
+ string-2 = Second string
+ string-3 = Third string
+
+
+ ## ALTERNATIVE STRING
+
+ string-1-alt = Alternative string
+ # comment
+ -string-4-alt = Other string
+ """,
+ )
=====================================
tools/base-browser/l10n/combine/tests/test_properties.py
=====================================
@@ -16,6 +16,23 @@ def assert_result(new_content, old_content, expect):
)
+def assert_alternative(content, alternative_content, alternative_ids, expect):
+ if content is not None:
+ content = textwrap.dedent(content)
+ if alternative_content is not None:
+ alternative_content = textwrap.dedent(alternative_content)
+ if expect is not None:
+ expect = textwrap.dedent(expect)
+ assert expect == combine_files(
+ "test.properties",
+ content,
+ alternative_content,
+ "ALTERNATIVE STRING",
+ alternative_ids,
+ ".alt",
+ )
+
+
def test_combine_empty():
assert_result(None, None, None)
@@ -320,3 +337,74 @@ def test_removed_string_with_comment():
removed.4 = Fourth removed
""",
)
+
+
+def test_alternatives():
+ assert_alternative(
+ """\
+ string.1 = First string
+ """,
+ """\
+ string.1 = Alternative string
+ """,
+ ["string.1"],
+ """\
+ string.1 = First string
+
+ # ALTERNATIVE STRING
+ string.1.alt = Alternative string
+ """,
+ )
+ assert_alternative(
+ """\
+ # Comment 1
+ string.1 = First string
+ # Comment 2
+ string.2 = Second string
+ string.3 = Third string
+ """,
+ """\
+ string.1 = First string
+ # Alt comment
+ string.2 = Alternative string
+ string.3 = Third string different
+ string.4 = Other string
+ """,
+ ["string.2"],
+ """\
+ # Comment 1
+ string.1 = First string
+ # Comment 2
+ string.2 = Second string
+ string.3 = Third string
+
+ # ALTERNATIVE STRING
+ # Alt comment
+ string.2.alt = Alternative string
+ """,
+ )
+ assert_alternative(
+ """\
+ string.1 = First string
+ string.2 = Second string
+ string.3 = Third string
+ """,
+ """\
+ string.1 = Alternative string
+ string.3 = Third string
+ # comment
+ string.4 = Other string
+ """,
+ ["string.1", "string.4"],
+ """\
+ string.1 = First string
+ string.2 = Second string
+ string.3 = Third string
+
+ # ALTERNATIVE STRING
+ string.1.alt = Alternative string
+ # ALTERNATIVE STRING
+ # comment
+ string.4.alt = Other string
+ """,
+ )
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/compare/d94603…
--
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/compare/d94603…
You're receiving this email because of your account on gitlab.torproject.org.
1
0

[Git][tpo/applications/tor-browser-build][maint-14.0] MB 394: Fix package dependency for Debian Trixie
by boklm (@boklm) 18 Feb '25
by boklm (@boklm) 18 Feb '25
18 Feb '25
boklm pushed to branch maint-14.0 at The Tor Project / Applications / tor-browser-build
Commits:
119ce448 by Nicolas Vigier at 2025-02-18T12:01:51+01:00
MB 394: Fix package dependency for Debian Trixie
The libgdk-pixbuf2.0-0 package has been removed from Debian Trixie.
We update the symbols file to depend on both libgdk-pixbuf2.0-0 and
libgdk-pixbuf-2.0-0.
https://bugzilla.mozilla.org/show_bug.cgi?id=1933835
- - - - -
1 changed file:
- projects/linux-packages/config
Changes:
=====================================
projects/linux-packages/config
=====================================
@@ -31,6 +31,11 @@ targets:
# some :i386 packages fail to install when /var/lib/dpkg/available
# does not exist, so create it as an empty file
echo > /var/lib/dpkg/available
+ post_pkginst: |
+ # Alter the symbols file for libgdk-pixbuf to handle the transition to libgdk-pixbuf-2.0-0
+ # This is only necessary until we upgrade to something newer than buster.
+ # See mullvad-browser#394 and https://bugzilla.mozilla.org/show_bug.cgi?id=1933835
+ find /var/lib/dpkg/info/ -name libgdk-pixbuf2.0-0*symbols | xargs sed -i "/libgdk-pixbuf2.0-0/s/libgdk-pixbuf2.0-0/libgdk-pixbuf2.0-0 #MINVER# | libgdk-pixbuf-2.0-0/"
arch_deps:
# Packages needed to build the deb package
- dpkg-dev
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser-build/-/commit/1…
--
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser-build/-/commit/1…
You're receiving this email because of your account on gitlab.torproject.org.
1
0