Mirror of the thorium GitHub repo, any changes of the GitHub repo will be applied here too.
Find a file
Alexander David Frick 1e44f99e87
Update build_dmg.sh
2022-06-17 08:10:02 -07:00
ash/resources/vector_icons Add files via upload 2022-05-10 04:31:14 -05:00
base/win Delete shortcut.cc 2022-06-08 11:11:50 -07:00
build Update BUILD.gn 2022-06-17 07:31:37 -07:00
chrome Update generated_resources.grd 2022-06-17 07:54:41 -07:00
chrome-devtools Add files via upload 2022-04-20 14:00:49 -07:00
components Update extension.icon 2022-06-16 03:20:09 -07:00
content Update BUILD.gn 2022-06-17 07:29:21 -07:00
content_shell Update README.md 2022-06-06 20:49:35 -07:00
depot_tools Update README.md 2022-06-08 02:05:50 -07:00
extensions/browser fix bracket 2022-05-20 09:25:07 +02:00
game Add files via upload 2022-06-10 11:09:59 -05:00
infra Add files via upload 2022-06-14 02:12:00 -05:00
logos Update build_icns.sh 2022-06-17 08:02:25 -07:00
media Update media_switches.cc 2022-06-17 07:31:05 -07:00
net Update x509_util.cc 2022-06-17 07:27:22 -07:00
pak_src Update and add new pak logo 2022-05-19 14:19:24 -05:00
portable Add files via upload 2022-05-27 15:28:55 -05:00
sandbox Add files via upload 2022-01-25 12:58:36 -08:00
third_party Update features.cc 2022-06-17 07:21:13 -07:00
tools Add polly 2022-05-17 00:50:38 -05:00
ui Update extension.svg 2022-06-16 03:24:26 -07:00
v8/src Update parser-base.h 2022-05-15 03:14:22 -05:00
win_scripts Update README.md 2022-05-28 00:32:16 -07:00
.gclient Add win deps 2022-04-18 14:35:11 -05:00
args.gn Update args.gn 2022-06-10 11:16:36 -07:00
BUGS.md Update BUGS.md 2022-05-28 19:45:06 -07:00
BUILD.gn Update BUILD.gn 2022-06-17 07:30:17 -07:00
build.sh Update build.sh 2022-06-14 01:27:04 -07:00
build_dmg.sh Update build_dmg.sh 2022-06-17 08:10:02 -07:00
build_mac.sh Add files via upload 2022-06-14 00:16:58 -05:00
build_win.sh Update build_win.sh 2022-06-13 22:14:31 -07:00
check_avx.sh Update check_avx.sh 2022-06-06 15:57:25 -07:00
clean.sh Update clean.sh 2022-06-06 15:57:02 -07:00
CODE_OF_CONDUCT.md Update CODE_OF_CONDUCT.md 2022-05-26 14:51:39 -05:00
LICENSE Initial commit 2021-10-18 01:46:35 -05:00
make_zip.bat Update make_zip.bat 2022-06-06 15:55:04 -07:00
PATCHES.md Update PATCHES.md 2022-06-04 01:35:13 -07:00
PKGBUILD PKGBUILD improvements 2022-05-27 13:22:17 -06:00
README.md Update README.md 2022-06-11 20:53:25 -07:00
set_exec.sh Add files via upload 2022-06-14 00:29:06 -05:00
setup.sh Update setup.sh 2022-06-13 22:09:35 -07:00
setup_mac.sh Add files via upload 2022-06-14 00:16:58 -05:00
thordeb.sh Update thordeb.sh 2022-06-08 01:51:59 -07:00
trunk.sh Update trunk.sh 2022-06-14 05:55:05 -07:00

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

Thorium

Chromium fork for linux named after radioactive element No. 90. Windows/MacOS/RasPi/Other builds see below.

  • 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.
  • Includes Widevine, All Codecs, Chrome Plugins, as well as thinLTO, CFlag, LDFlag, LLVM Loop, and PGO compiler optimizations. It is built with SSE4, AVX, and AES, 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, some of which are SSE4. (See below.)

Other Builds        

 – I also build for Windows > Thorium Win You can also find SSE4 builds for Windows here.
 – AVX2 Builds for Windows and Linux > Thorium AVX2 (source files for AVX2 are in that repo.)
 – MacOS (M1 and X64) and Raspberry Pi (arm64) Builds, as well as Special and Experimental builds, sometimes for other CPUs (read the Readme), are located at > Thorium Special You can also find builds for Piledriver/Steamroller/Excavator CPUS, Haswell CPUs, as well as SSE4 Linux builds.
 – NEW: Thorium Website with deb repo for auto-updating on Linux > https://thorium.rocks/
 – NEW: Tigerlake (11th Gen) builds by @midzer in Thorium Special

FEATURES & DIFFERENCES BETWEEN CHROMIUM AND THORIUM

  • Various compiler flags that improve performance and target AVX CPU's (read PATCHES.md)
  • Experimental MPEG-DASH.
  • JPEG XL Image File Format support.
  • Enable Live Caption (SODA) on all builds.
  • 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 annoying Google API Key Infobar warning (you can still use API Keys to enable sync) from Ungoogled Chromium.
  • Disable annoying Default Browser Infobar warning.
  • 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')
  • Home button and Chrome Labs shown by Default.
  • Prefetch settings updated to respect privacy.
  • Patches for GN and chrome_sandbox when building.
  • Remove the addition of the Chrome APT sources.list during installation.
  • Widevine CDM Patch for Linux.
  • Enable Parallel Downloading by Default.
  • Inclusion of pak (linux) and pak_mingw (windows), a utility for packing and unpacking the *.pak files in Thorium and any other Chromium based browser.
  • 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 (thorium_shell), with a .desktop file being provided for content_shell (named thorium-shell.desktop and shows in desktop environments as Thorium Content Shell). These are also included in the Windows releases, but it doesn't make a shorcut, although a .png and .ico is in the install directory for you to make your own shortcut with an icon. 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 or chromedriver.exe onWwindows. Also, patches for abseil library and mini_installer when building with AVX on Windows.
  • Right clicking the launcher after install gives three additional desktop actions, one to open thorium-shell, another to open in Safe Mode which disables any flags one has set in chrome://flags until the next launch, and lastly to open in Dark Mode which appends the --force-dark-mode flag.

  – UPDATE: Thorium now has API Keys baked in but the instructions below are the same if you are building it yourself as I will not include the keys here. | 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.)

Building

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

  • UPDATE: For Windows and Windows AVX2, I made new dedicated instructions. If you are building on Windows use > WIN_INSTRUCTIONS.txt and if you are building for Windows on Linux, use > WIN_CROSS_BUILD_INSTRUCTIONS.txt
  • In general we 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
  • Make sure dependencies are installed by running ./chromium/src/build/install-build-deps.sh.
  • 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 for all platforms. 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 gn args out/thorium and the contents of 'args.gn' in the root of this repo should be copy/pasted into the editor. Note that for Windows, Mac, ChromiumOS, or Android there are seperate *_args.gn files for those platforms. --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'
  • For more info about args.gn, read the ABOUT_GN_ARGS.md file.
  • 'infra/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 ./build.sh (--help for help). For Windows, use build_win.sh or autoninja -C out\thorium chrome chromedriver thorium_shell setup mini_installer -j8 The -j# can be changed to limit or increase the number of jobs (generally should be the number of CPU cores on your machine)
  • 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/thorium_shell, or chromedriver with ~/bin/thorium/chromedriver.
  • Proper Install: To install with a .deb, dont copy the contents of out/thorium; instead run
    ./thordeb.sh (--help for help). 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/. For Windows, just run the mini_installer.exe.
       NOTE: To get back to "Trunk", i.e. to revert all changes in order to build vanilla Chromium or to update your checkout, just run ./trunk.sh again.
       NOTE: To compile without AVX, simply go to //chromium/src/build/config/compiler/BUILD.gn, search for avx, and replace avx with sse3 or sse4.

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 Thorium/ThoriumOS.
I also build ChromiumOS (now called ThoriumOS) with Thorium, Codecs, Widevine, linux-firmware/modules, and extra packages at > https://github.com/Alex313031/ChromiumOS/

Thanks to https://github.com/robrich999/ for some info and fixes 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, https://github.com/GrapheneOS/Vanadium, and https://github.com/iridium-browser/iridium-browser for patch code.
The pak_src dir, and the binaries in pack_src/bin are credited to @freeer https://github.com/myfreeer/chrome-pak-customizer/

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

Thanks for using Thorium!