Thorium Archive at 2023.12.15. With releases, pull requests and issues at the date
Find a file
Alexander David Frick df72c5edf5
Update README.md
2022-01-25 14:53:35 -06:00
build/config Update BUILD.gn 2022-01-24 10:13:21 -06:00
chrome Update chrome.release 2022-01-24 09:38:35 -06:00
chrome-devtools Add files via upload 2022-01-22 04:09:53 -06:00
components Update privacy_sandbox_prefs.cc 2022-01-20 09:26:38 -06:00
content/gpu Update BUILD.gn 2021-11-11 11:14:06 -06:00
content_shell Add content_shell .ico for win 2022-01-24 07:37:46 -08:00
logos Add files via upload 2022-01-13 04:09:37 -08:00
media Add thread safety for gallium 2022-01-19 09:35:20 -06:00
net Update url_request_http_job.cc 2022-01-21 23:13:55 -06:00
portable Update CONTENT_SHELL.BAT 2022-01-24 13:10:28 -06:00
sandbox/policy/linux Add audio sandbox patch for pulseaudio 2021-11-11 19:57:18 -06:00
third_party Fix error in cflags. 2021-12-01 22:55:08 -06:00
ui/base/x Update x11_util.cc 2022-01-22 03:24:46 -06:00
v8/src/objects Update js-display-names.cc 2021-11-22 23:20:14 -06:00
.gclient Add files via upload 2021-10-19 04:31:13 -05:00
android_args.gn Add args for Android builds. 2021-12-13 01:57:06 -06:00
args.gn Update args.gn 2022-01-15 02:32:43 -06:00
args.list Update args.list 2021-12-02 03:29:57 -06:00
BRANDING Update BRANDING 2021-12-02 03:34:24 -06:00
BUGS.md Update BUGS.md 2022-01-02 10:40:18 -06:00
build_dmg.sh replace Chromium -> Throrium 2022-01-07 11:18:45 +01:00
clean.sh Rename clean to clean.sh 2021-10-28 08:50:43 -05:00
cros_args.gn Remove API keys that were accidentally in there. 2021-12-09 23:44:45 -06:00
gn_args.list gn_args.list for list with thorium flags included 2021-12-02 03:36:51 -06:00
libpepflashplayer.so Add files via upload 2021-10-22 12:09:16 -05:00
LICENSE Initial commit 2021-10-18 01:46:35 -05:00
PATCHES.md Update PATCHES.md 2022-01-13 15:14:30 -06:00
README.md Update README.md 2022-01-25 14:53:35 -06:00
setup.sh Add third_party dir 2021-11-30 14:04:46 -06:00
thorium_strings.grd Update thorium_strings.grd 2022-01-11 02:12:16 -06:00
trunk.sh Add flags to gclient sync 2021-11-13 19:15:39 -06:00
vdpau-va-driver_0.7.4-7_amd64.deb Add vdpau-va-driver for VDPAU acceleration 2021-12-04 20:11:02 -06:00
VERSION Update VERSION 2022-01-24 09:39:15 -06:00
win_args.list Args for windows builds. 2021-12-13 20:09:05 -06:00
windows_args.gn Update windows_args.gn 2022-01-02 09:41:53 -06:00

GitHub tag (latest SemVer)  GitHub  GitHub commit activity  Subreddit subscribers

Thorium

Chromium fork for linux named after radioactive element No. 90. Windows/MacOS/Android/Other builds see below. NEW: New builds for different architectures in Thorium-Special! Also Google Sync is now enabled with baked in API Keys!

  • Always built with the latest x64 tip-o-tree "Trunk" build of Chromium.
  • Intended to behave like and have the featureset of Google Chrome, with differences/patches/enhancements listed below.
     – I also build for windows less frequently > https://github.com/Alex313031/Thorium-Win
     – Special and Experimental builds, sometimes for other CPUs (read the readme), and MacOS/Raspi/Android are located at > https://github.com/Alex313031/Thorium-Special You can find builds for Piledriver/Steamroller/Excavator CPUS, Haswell CPUs, as well as SSE4, SSE4.2, and pure AVX builds. NEW: Tigerlake (11th Gen) builds by @midzer
     – NEW: Thorium Special now also has experimental Android ARM32 & ARM64 builds.
     – NEW: Thorium Special now also has new ARM32 & ARM64 builds for things like the Raspberry Pi.
     – NEW: Thorium Special now also has ARM64 and x64 builds for MacOS.

  – Includes Widevine, FFmpeg, Chrome Plugins, as well as thinLTO, CFlag, LLVM Loop, and PGO compiler optimizations. It is built with SSE4, and AVX, so it won't launch on CPU's below 2nd gen Core or AMD FX, but benefits from Advanced Vector EXtensions. You can disable this and use regular SSE3 like Chromium and Chrome, or builds from Thorium special of which some are SSE4 or SSE4.2. (See below.)

EXPERIMENTAL FEATURES/DIFFERENCES BETWEEN CHROMIUM AND THORIUM

  • Various compiler flags that improve performance and target AVX CPU's (read patches.md)
  • Experimental MPEG-DASH.
  • Experimental PDF annotation support (called "Ink" on ChromiumOS). # DISABLED FOR NOW BECAUSE OF CRASHES.
  • Patches from Debian including font rendering patch, VAAPI Patch, Intel HD support patch, native notifications patch, title bar patch, and... the VDPAU Patch!! (Rejoice Nvidia users)
  • Audio Sandbox patch.
  • DoH (DNS over HTTPS) patches from Bromite.
  • Enable Do Not Track by default patch from Vanadium.
  • Show full URLs including trailing slashes in address bar by default.
  • Disable FLOC patch.
  • Disable Google API Key warning (you can still use API Keys to enable sync) from Ungoogled Chromium.
  • Adds DuckDuckGo, Ecosia, Ask.com, and Yandex.com in US and other locales, along with the normal search engines.
  • Always use the local NTP (New Tab Page) regardless of search engine.
  • Fix icons when distilling page content in reader mode.
  • Enable new menu UI when right clicking the reload button. (Adds 'Normal Reload', 'Hard Reload', and 'Clear Cache and Hard Reload')
  • Prefetch settings updated to respect privacy.
  • Patches for GN and chrome_sandbox.
  • Remove the addition of the Chrome apt sources.list during installation.
  • Logo and Branding/Naming changed to the Thorium logo, Thorium name, and "Alex313031" being appended to "The Chromium Authors" in credits, etc.
  • .desktop file includes useful cmdline flags that enable experimental or useful features. (read PATCHES.md)
  • Includes installer patches and files to include ChromeDriver and content_shell, with a .desktop file being provided for content_shell (named thorium-shell.desktop and shows in desktop environments as Thorium Content Shell). You can also run content_shell with the command thorium-shell (custom wrapper for it, located in /usr/bin/). You can run ChromeDriver at /usr/bin/chromedriver. Also, patches for abseil library and mini_installer when building for AVX on Windows.
  • Right clicking the launcher after install gives two additional desktop actions, one to open content-shell, and another to open in safe mode which disables any flags one has set in chrome://flags until the next launch.
  • For more info, read the PATCHES.md file.
  • Known bugs are in the BUGS.md file.

  – args.gn exclude API Keys (you can get them yourself) and the pgo profile path is different for each chromium version (only needed when building). (See below.) UPDATE: Thorium now has API Keys baked in but the instructions are the same if you are building it yourself as I will not include the keys here.

  In general follow build instructions at https://chromium.googlesource.com/chromium/src/+/refs/heads/main/docs/linux/build_instructions.md and API Keys (if desired) at https://www.chromium.org/developers/how-tos/api-keys

Building

The scripts assume the Chromium source is at $HOME/chromiums/src/. You may have to 'sudo chmod +x' the scripts to make them executable.

  • After initial download of Chromium source code, run (from where you cloned this repo) ./trunk.sh. This will update and sync the sources and at the end it will download the PGO profile for chromium. The file will be downloaded to //chromium/src/chrome/build/pgo_profiles/*.profdata with the actual file name looking something like 'chrome-linux-main-1632505958-ddbb37bcdfa7dbd7b10cf3a9b6a5bc45e7a958a6.profdata', which should be added to the end of args.gn as per below.
  • Then, (from where you cloned this repo) run ./setup.sh. This will copy all the files and patches to the needed locations and drop you to //chromium/src.
  • Run export EDITOR=nano & export VISUAL=nano # You can substitute a cmdline editor like vim here, but many GUI editors cause it to try and parse the args.gn file before it is even saved.
  • Run gn args out/thorium and the contents of 'args.gn' in this repo should be copy/pasted into the editor. --Include your api keys here at the top or leave blank, and edit the last line to point to the actual path and file name of '*.profdata'
  • 'args.list' contains an alphabetical list with descriptions of all possible build arguments; gn_args.list gives a similar list but with the flags in args.gn added.
  • To build, run autoninja -j8 -C out/thorium chrome chrome_sandbox content_shell -d stats The -j# can be changed to limit or increase the number of jobs (generally should be the number of CPU cores on your machine), and the -d stats at the end just shows better verbose stats during compiling. You could also append chromedriver (the releases have chromedriver) after content_shell to build chromedriver, the selenium compatible browser fuzzing library.
  • To install, copy/paste the contents of your out/thorium dir to a good location, i.e. $HOME/bin/thorium. RECOMMENDED - Copy and run clean.sh within this dir to clean up build artifacts. Then you can just run the browser with ~/bin/thorium/chrome, the content_shell with ~/bin/thorium/content_shell, or chromedriver with ~/bin/thorium/chromedriver.
  • Proper Install: To install with a .deb, dont copy the contents of out/thorium; instead run
    autoninja -C out/thorium/ "chrome/installer/linux:unstable_deb" A nice .deb file will now be in out/thorium and you can install it with sudo dpkg -i *.deb It will be called 'thorium-browser-unstable_$VERSIONNUMBER_amd64.deb', and will be installed to /opt/chromium.org/thorium-unstable/.
       NOTE: To get back to "Trunk", i.e. to revert all changes in order to build vanilla chromium, just run ./trunk.sh again.
       NOTE: To compile without AVX, simply go to //chromium/src/build/config/compiler/BUILD.gn, search for mavx (there's only two
       lines), and replace mavx with msse3, then remove the lines right under both of those that contain "-ffp-contract=fast",

https://www.reddit.com/r/ChromiumBrowser/ is a subreddit I made for Thorium and general Chromium discussion and https://alex313031.blogspot.com/ is a blog I made relating to Chromium/ChromiumOS. I also build ChromiumOS with codecs, linux-firmware/modules, and added packages at > https://github.com/Alex313031/ChromiumOS/

Thanks to https://github.com/robrich999/ for some info that went into this project.
Thanks to https://github.com/midzer/ for support and helping with builds.
Also thanks to https://github.com/bromite/bromite, https://github.com/saiarcot895/chromium-ubuntu-build, https://github.com/Eloston/ungoogled-chromium, and https://github.com/GrapheneOS/Vanadium for patch code.

   NOTE: libpepflashplayer.so is included for posterity and can be used to enable Adobe Flash on older Chromium releases. ʘ‿ʘ