2022-04-13 14:27:39 +00:00
# LibreWolf Source Repository
2022-05-12 17:06:44 +00:00
This repository contains all the patches and theming that make up LibreWolf, as well as scripts and a Makefile to build LibreWolf. There also is the [Settings repository ](https://gitlab.com/librewolf-community/settings ), which contains the LibreWolf preferences.
## LibreWolf overview
2023-06-25 11:36:43 +00:00
```mermaid
graph LR
FFSRC(Firefox Source)
FFSRC--Tarball--->Source
subgraph librewolf-community/
Settings(Settings)--"librewolf.cfg< br > policies.json"-->Source
Website(Website< br > < br > - Documentation< br > - FAQ)
subgraph browser/
Source(Source< br > < br > - Patches< br > - Theming< br > - Build scripts)
bsys6(bsys6< br > < br > New Docker building< br > repository)
bsys5(bsys5< br > < br > Old Docker building< br > repository)
AppImage
Arch
end
end
Website-->librewolf.net
Source--"Source tarball"-->bsys6 & bsys5
AppImage--".appimage"-->librewolf.net
bsys6--"Windows setup.exe"--->librewolf.net
bsys6--"Windows portable.zip"--->librewolf.net
bsys6--"Windows .msix"--->MS("Microsoft Store")
bsys6--"Windows .nupkg"--->Chocolatey
bsys6--"Linux binary tarball"--->Flathub
bsys6--"Linux binary tarball"--> AppImage
bsys6--"Linux binary tarball for `librewolf-bin` "--> Arch
Source--"Source tarball for `librewolf` "-->Arch
Arch-->AUR
bsys5--"Linux .deb"--->deb.librewolf.net
bsys5--"Linux .rpm"--->rpm.librewolf.net
```
2022-04-13 14:27:39 +00:00
2022-03-08 14:37:52 +01:00
## Active repositories and projects
List of browser build sub projects. These are the locations where people have their repositories and build artifacts.
Currently active build repositories:
2022-05-12 17:06:44 +00:00
2022-03-09 13:16:06 +01:00
* [Arch ](https://gitlab.com/librewolf-community/browser/arch ): Arch Linux
2022-05-04 13:39:18 +02:00
* [Bsys5 ](https://gitlab.com/librewolf-community/browser/bsys5 ): .deb/.rpm for Mint, Fedora, Ubuntu; .dmg for MacOS.
2022-03-09 13:16:06 +01:00
* [Debian ](https://gitlab.com/librewolf-community/browser/debian ): bgstack15 version
* [Fedora ](https://gitlab.com/librewolf-community/browser/fedora ): bgstack15 version
* [Flatpak ](https://gitlab.com/librewolf-community/browser/flatpak ): Flatpak
* [Gentoo ](https://gitlab.com/librewolf-community/browser/gentoo ): Gentoo
* [Linux ](https://gitlab.com/librewolf-community/browser/linux ): Flatpak, AppImage, Arch and other Linux builds of the LibreWolf browser.
* [MacOS ](https://gitlab.com/librewolf-community/browser/macos ): The macOS build of LibreWolf.
* [OpenBSD ](https://librewolf.net/installation/openbsd/ ): OpenBSD page
* [Windows ](https://gitlab.com/librewolf-community/browser/windows ): LibreWolf builds for Windows.
2022-03-08 14:37:52 +01:00
2022-05-12 17:06:44 +00:00
Currently active (and known) forks:
2022-03-13 17:22:37 +04:00
* Cachy-Browser: https://github.com/cachyos/cachyos-browser-settings
2024-02-16 18:58:41 +00:00
Previous forks:
2022-03-08 14:37:52 +01:00
* FireDragon: https://github.com/dr460nf1r3/firedragon-browser
2022-02-03 10:58:11 +01:00
## LibreWolf build instructions
2022-02-03 10:57:05 +01:00
2022-05-04 13:39:18 +02:00
There are two ways to build LibreWolf. You can either use the source tarball or compile directly with this repository.
2022-04-13 14:27:39 +00:00
### Building from the Tarball
2022-05-04 14:29:37 +00:00
First, let's ** [download the latest tarball ](https://gitlab.com/librewolf-community/browser/source/-/releases )**. This tarball is the latest produced by the [CI ](https://gitlab.com/librewolf-community/browser/source/-/jobs ). You can also check the sha256sum of the tarball there.
2022-02-09 13:10:41 +01:00
2023-10-08 07:20:34 +00:00
```bash
2022-02-03 10:57:05 +01:00
tar xf < tarball >
cd < folder >
```
2022-04-13 14:27:39 +00:00
Then, you have to bootstrap your system to be able to build LibreWolf. You only have to do this one time. It is done by running the following commands:
2023-10-08 07:20:34 +00:00
```bash
2022-04-13 14:27:39 +00:00
./mach --no-interactive bootstrap --application-choice=browser
./lw/setup-wasi-linux.sh
```
Finally you can build LibreWolf and then package or run it with the following commands:
2023-10-08 07:20:34 +00:00
```bash
2022-04-13 14:27:39 +00:00
./mach build
./mach package
# OR
./mach run
2022-02-03 10:57:05 +01:00
```
2022-04-13 14:27:39 +00:00
### Building with this Repository
First, clone this repository with Git:
2022-02-03 10:17:35 +01:00
2023-10-08 07:20:34 +00:00
```bash
2022-04-13 14:27:39 +00:00
git clone --recursive https://gitlab.com/librewolf-community/browser/source.git librewolf-source
cd librewolf-source
2022-02-03 10:17:35 +01:00
```
2022-04-13 14:27:39 +00:00
Next, build the LibreWolf source code with the following command:
2023-10-08 07:20:34 +00:00
```bash
2022-04-13 14:27:39 +00:00
make dir
2022-02-03 10:17:35 +01:00
```
2022-04-13 14:27:39 +00:00
After that, you have to bootstrap your system to be able to build LibreWolf. You only have to do this one time. It is done by running the following command:
2023-10-08 07:20:34 +00:00
```bash
2022-02-03 10:17:35 +01:00
make bootstrap
```
2022-04-13 14:27:39 +00:00
Finally you can build LibreWolf and then package or run it with the following commands:
2023-10-08 07:20:34 +00:00
```bash
2022-04-13 14:27:39 +00:00
make build
2022-02-03 10:27:29 +01:00
make package
2022-04-13 14:27:39 +00:00
# OR
2022-02-03 10:27:29 +01:00
make run
```
2022-04-13 14:27:39 +00:00
## Development Notes
### How to make a patch
The easiest way to make patches is to go to the LibreWolf source folder:
2023-10-08 07:20:34 +00:00
```bash
2022-04-13 14:27:39 +00:00
cd librewolf-$(cat version)
git init
git add < path_to_file_you_changed >
git commit -am initial-commit
git diff > ../mypatch.patch
```
We have Gitter / Matrix rooms, and on the website we have links to the various issue trackers.
2022-04-27 11:36:30 +02:00
### How to work on an existing patch
The easiest way to make patches is to go to the LibreWolf source folder:
2023-10-08 07:20:34 +00:00
```bash
2022-04-27 11:36:30 +02:00
make fetch # get the firefox tarball
./scripts/git-patchtree.sh patches/sed-patches/disable-pocket.patch
```
Now change the source tree the way you want, keeping in mind to `git add` new files. When done, you can create the new patch with:
2023-10-08 07:20:34 +00:00
```bash
2022-04-27 11:36:30 +02:00
cd firefox-< version >
git diff 4b825dc642cb6eb9a060e54bf8d69288fbee4904 HEAD > ../my-patch-name.patch
```
2022-05-04 13:39:18 +02:00
This ID is the hash value of the first commit, which is called `initial` . Dont forget to commit changes before doing this diff, or the patch will be incomplete.
2022-04-27 11:36:30 +02:00
2022-04-13 14:27:39 +00:00
### How to create a patch for problems in Mozilla's [Bugzilla](https://bugzilla.mozilla.org/).
2022-02-03 11:20:10 +01:00
Well, first of all:
* [Create an account ](https://bugzilla.mozilla.org/createaccount.cgi ).
* Handy link: [Bugs Filed Today ](https://bugzilla.mozilla.org/buglist.cgi?cmdtype=dorem&remaction=run&namedcmd=Bugs%20Filed%20Today&sharer_id=1&list_id=15939480 ).
* The essential: [Firefox Source Tree Documentation ](https://firefox-source-docs.mozilla.org/ ).
2022-02-03 11:54:09 +01:00
Now that you have a patch in LibreWolf, that's not enough to upload to Mozilla. See, Mozilla only accepts patches against Nightly. So here is how to do that:
2022-04-08 21:24:30 +02:00
If you have not done already, create the `mozilla-unified` folder and build Firefox with it:
2023-10-08 07:20:34 +00:00
```bash
2022-02-03 11:20:10 +01:00
hg clone https://hg.mozilla.org/mozilla-unified
cd mozilla-unified
hg update
MOZBUILD_STATE_PATH=$HOME/.mozbuild ./mach --no-interactive bootstrap --application-choice=browser
./mach build
./mach run
```
2022-04-08 21:24:30 +02:00
If you skipped the previous step, you could ensure that you're up to date with:
2023-10-08 07:20:34 +00:00
```bash
2022-04-08 21:24:30 +02:00
cd mozilla-unified
hg pull
hg update
```
2022-02-03 11:20:10 +01:00
Now you can apply your patch to Nightly:
2023-10-08 07:20:34 +00:00
```bash
2022-02-03 11:20:10 +01:00
patch -p1 -i ../mypatch.patch
```
Now you let Mercurial create the patch:
2023-10-08 07:20:34 +00:00
```bash
2022-02-03 11:20:10 +01:00
hg diff > ../my-nightly-patch.patch
```
2022-02-03 11:54:09 +01:00
And it can be uploaded to Bugzilla.
2022-02-03 11:25:54 +01:00
2022-05-04 13:39:18 +02:00
##### *(excerpt from the Mozilla readme)* Now the fun starts
2022-02-03 11:25:54 +01:00
Time to start hacking! You should join us on [Matrix ](https://chat.mozilla.org/ ), say hello in the [Introduction channel ](https://chat.mozilla.org/#/room/#introduction:mozilla.org ), and [find a bug to start working on ](https://codetribute.mozilla.org/ ). See the [Firefox Contributors’ Quick Reference ](https://firefox-source-docs.mozilla.org/contributing/contribution_quickref.html#firefox-contributors-quick-reference ) to learn how to test your changes, send patches to Mozilla, update your source code locally, and more.
2022-02-03 12:34:45 +01:00
2022-11-02 10:55:12 +01:00
## Hey, I'm using MacOS or Windows..
2022-05-04 13:39:18 +02:00
We understand, life isn't always fair 😺. The same steps as above do apply, you'll just have to walk through the beginning part of the guides for:
* [MacOS ](https://firefox-source-docs.mozilla.org/setup/macos_build.html ): The cross-compiled Mac .dmg files are somewhat new. They should work, perhaps with the exception of the `make setup-wasi` step.
* [Windows ](https://firefox-source-docs.mozilla.org/setup/windows_build.html ): Building on Windows is not very well tested.
2022-05-04 14:29:37 +00:00
Help with testing these targets is always welcome.