diff options
Diffstat (limited to 'browser/linux/binary_tarball')
6 files changed, 115 insertions, 0 deletions
diff --git a/browser/linux/binary_tarball/content/launch_librewolf.sh b/browser/linux/binary_tarball/content/launch_librewolf.sh new file mode 100755 index 0000000..f8b099d --- /dev/null +++ b/browser/linux/binary_tarball/content/launch_librewolf.sh @@ -0,0 +1,30 @@ +#!/usr/bin/env bash + +INSTALL_FOLDER=$(realpath $(dirname $0)); +INSTALL_SETTINGS_FOLDER=$INSTALL_FOLDER/settings; +PROFILE_SETTINGS_FOLDER=$HOME/.librewolf/settings; + +# Adds option to install settings if argument is passed +if [ "$1" = "--install-settings" ]; then + mkdir -p $PROFILE_SETTINGS_FOLDER; + cp $INSTALL_SETTINGS_FOLDER/defaults/pref/local-settings.js $PROFILE_SETTINGS_FOLDER/local-settings.js; + cp $INSTALL_SETTINGS_FOLDER/distribution/policies.json $PROFILE_SETTINGS_FOLDER/policies.json; + cp $INSTALL_SETTINGS_FOLDER/librewolf.cfg $PROFILE_SETTINGS_FOLDER/librewolf.cfg; + cp $INSTALL_SETTINGS_FOLDER/toggle-settings.sh $PROFILE_SETTINGS_FOLDER/toggle-settings.sh; +fi + +# Sets up settings links +ln -s $PROFILE_SETTINGS_FOLDER/local-settings.js $INSTALL_FOLDER/defaults/pref/local-settings.js; +ln -s $PROFILE_SETTINGS_FOLDER/policies.json $INSTALL_FOLDER/distribution/policies.json; +ln -s $PROFILE_SETTINGS_FOLDER/librewolf.cfg $INSTALL_FOLDER/librewolf.cfg; + +# Sets env variables to disable dedicated profiles (which breaks some packaging methods) +export MOZ_LEGACY_PROFILES=1; +export SNAP_NAME="firefox"; + +# Launches librewolf +chmod +x $INSTALL_FOLDER/librewolf; +$INSTALL_FOLDER/librewolf "$@"; + + + diff --git a/browser/linux/binary_tarball/scripts/1_Install_Dependencies.sh b/browser/linux/binary_tarball/scripts/1_Install_Dependencies.sh new file mode 100755 index 0000000..9519b22 --- /dev/null +++ b/browser/linux/binary_tarball/scripts/1_Install_Dependencies.sh @@ -0,0 +1,12 @@ +#!/bin/sh + +printf "\n\n-------------------------------------- DEPENDENCY INSTALLATION ---------------------------------------------\n"; +printf "\nInstalling dependencies\n"; +apt update && apt install -y python python3 wget; +wget https://hg.mozilla.org/mozilla-central/raw-file/default/python/mozboot/bin/bootstrap.py; +python ./bootstrap.py --application-choice=browser --no-interactive || true +rm -f ./bootstrap.py; + +# adds the new rust install to PATH +# printf "\nAdding new rust install to PATH\n"; +#. $HOME/.cargo/env; diff --git a/browser/linux/binary_tarball/scripts/2_Download_Source_Code.sh b/browser/linux/binary_tarball/scripts/2_Download_Source_Code.sh new file mode 100755 index 0000000..c973038 --- /dev/null +++ b/browser/linux/binary_tarball/scripts/2_Download_Source_Code.sh @@ -0,0 +1,9 @@ +#!/bin/sh + +COMPILE_FOLDER=$1 + +printf "\n\n--------------------------------- SOURCE CODE DOWNLOAD --------------------------------------\n"; +# Clones the firefox source code for compiling +printf "\nCloning Firefox Source Code\n"; +hg clone https://hg.mozilla.org/releases/mozilla-release $COMPILE_FOLDER; + diff --git a/browser/linux/binary_tarball/scripts/3_Configure_Source_Code.sh b/browser/linux/binary_tarball/scripts/3_Configure_Source_Code.sh new file mode 100644 index 0000000..e4e3a9a --- /dev/null +++ b/browser/linux/binary_tarball/scripts/3_Configure_Source_Code.sh @@ -0,0 +1,15 @@ +#!/bin/sh + +SOURCE_CODE_FOLDER=$1 +FOLDER_TO_ADD=$2 + +printf "\n\n------------------------------ FINAL PREBUILD CONFIGURATION ---------------------------------\n"; + +# Copies our custom source code changes (mostly branding) to the source code +printf "\nCopying custom files to firefox source code\n"; +cp -r $FOLDER_TO_ADD/* $SOURCE_CODE_FOLDER/; + +# Disables pocket +printf "\nDisabling Pocket\n"; +sed -i "s/'pocket'/#'pocket'/g" $SOURCE_CODE_FOLDER/browser/components/moz.build; + diff --git a/browser/linux/binary_tarball/scripts/4_Build_Binary_Tarball.sh b/browser/linux/binary_tarball/scripts/4_Build_Binary_Tarball.sh new file mode 100644 index 0000000..6cf3866 --- /dev/null +++ b/browser/linux/binary_tarball/scripts/4_Build_Binary_Tarball.sh @@ -0,0 +1,25 @@ +#!/bin/sh + +SOURCE_FOLDER=$1; +OUTPUT_TARBALL=$2; + +printf "\n\n--------------------------------------- BUILD -----------------------------------------------\n"; + +# Bootstraps librewolf again (using the ./mach script inside the source code) +# printf "\nRunning bootstrapper to install build dependencies (using ./mach script within source code)\n"; +# ./mach bootstrap --application-choice=browser --no-interactive; + +cd $SOURCE_FOLDER; + +printf "\nBuilding LibreWolf\n"; +./mach build; + +printf "\nPackaging LibreWolf\n"; +./mach package; + +printf "\nMoving Binary Tarball to output location\n"; +mv ./obj*/dist/librewolf*.tar.bz2 $OUTPUT_TARBALL; + +printf "\nDeleting the compile_folder\n"; +rm -rf ./; + diff --git a/browser/linux/binary_tarball/scripts/5_Configure_Binary_Tarball.sh b/browser/linux/binary_tarball/scripts/5_Configure_Binary_Tarball.sh new file mode 100644 index 0000000..346f702 --- /dev/null +++ b/browser/linux/binary_tarball/scripts/5_Configure_Binary_Tarball.sh @@ -0,0 +1,24 @@ +#!/bin/sh + +PACKAGE_FILE=$1 +SETTINGS_FOLDER_TO_ADD=$2 #$REPOSITORY_FOLDER/settings +LAUNCHER_SCRIPT=$3 #$SCRIPT_FOLDER/resources/launch_librewolf.sh + +printf "\n\n--------------------------------- SETTINGS INTEGRATION --------------------------------------\n"; + +# Extracts the binary tarball +printf "\nExtracting librewolf binary tarball\n"; +tar -xvf ./$PACKAGE_FILE; + +# Adds the librefox config files to the packaged tarball +printf "\nCopying librewolf settings to extracted binary tarball\n"; +cp -r $SETTINGS_FOLDER_TO_ADD ./librewolf/settings; +cp $LAUNCHER_SCRIPT ./librewolf/launch_librewolf.sh +mkdir -p ./librewolf/defaults/pref/; +mkdir -p ./librewolf/distribution/; + +# Repacks the binary tarball +printf "\nRecompressing binary tarball\n"; +tar -jcvf ./$PACKAGE_FILE librewolf; + + |