aboutsummaryrefslogtreecommitdiff
path: root/browser/linux
diff options
context:
space:
mode:
Diffstat (limited to 'browser/linux')
-rw-r--r--browser/linux/appimage/build_appimage.sh40
l---------browser/linux/appimage/content/.DirIcon1
-rwxr-xr-xbrowser/linux/appimage/content/AppRun (renamed from browser/linux/resources/appimage/AppRun)0
-rw-r--r--browser/linux/appimage/content/librewolf.desktop (renamed from browser/linux/resources/appimage/librewolf.desktop)0
-rw-r--r--browser/linux/appimage/content/librewolf.svg90
-rwxr-xr-xbrowser/linux/binary_tarball/content/launch_librewolf.sh (renamed from browser/linux/resources/launch_librewolf.sh)0
-rwxr-xr-xbrowser/linux/binary_tarball/scripts/1_Install_Dependencies.sh12
-rwxr-xr-xbrowser/linux/binary_tarball/scripts/2_Download_Source_Code.sh9
-rw-r--r--browser/linux/binary_tarball/scripts/3_Configure_Source_Code.sh15
-rw-r--r--browser/linux/binary_tarball/scripts/4_Build_Binary_Tarball.sh25
-rw-r--r--browser/linux/binary_tarball/scripts/5_Configure_Binary_Tarball.sh24
-rwxr-xr-xbrowser/linux/build.sh211
-rw-r--r--browser/linux/build_output/.gitignore2
-rw-r--r--browser/linux/flatpak/build_flatpak.sh44
-rw-r--r--browser/linux/flatpak/content/io.gitlab.LibreWolf.json (renamed from browser/linux/resources/flatpak/io.gitlab.LibreWolf.json)0
-rw-r--r--browser/linux/resources/appimage/.gitignore2
16 files changed, 273 insertions, 202 deletions
diff --git a/browser/linux/appimage/build_appimage.sh b/browser/linux/appimage/build_appimage.sh
new file mode 100644
index 0000000..3efa9e8
--- /dev/null
+++ b/browser/linux/appimage/build_appimage.sh
@@ -0,0 +1,40 @@
+#!/bin/sh
+
+APPIMAGE_CONTENT_FOLDER=$1 #$SCRIPT_FOLDER/resources/appimage;
+BINARY_TARBALL=$2
+OUTPUT_FOLDER=$3
+
+_LIBREWOLF_EXTRACTED_FOLDER=./librewolf;
+_LIBREWOLF_FINAL_APPIMAGE=./LibreWolf*.AppImage;
+_APPIMAGETOOL_DOWNLOAD_URL=https://github.com/AppImage/AppImageKit/releases/latest/download/appimagetool-x86_64.AppImage;
+_APPIMAGETOOL_FILE=./appimagetool;
+
+printf "\n\n------------------------------------ APPIMAGE BUILD -----------------------------------------\n";
+
+printf "APPIMAGE_RESOURCE_FOLDER: $APPIMAGE_CONTENT_FOLDER\n";
+
+# Copy and generate icons
+# printf "\nGenerating AppImage Icons\n";
+# cp $ICON_FOLDER/icon.svg $APPIMAGE_CONTENT_FOLDER/librewolf.svg;
+# ln -rs $APPIMAGE_CONTENT_FOLDER/librewolf.svg $SCRIPT_FOLDER/resources/appimage/.DirIcon;
+
+# Copy appimage resources to main tarball
+printf "Copying AppImage resources to binary tarball folder\n";
+cp -vrT $APPIMAGE_CONTENT_FOLDER $_LIBREWOLF_EXTRACTED_FOLDER;
+
+# Downloads appimage tool
+printf "\nDownloading AppImage Tool\n";
+wget $_APPIMAGETOOL_DOWNLOAD_URL -O $_APPIMAGETOOL_FILE;
+chmod +x $_APPIMAGETOOL_FILE;
+$_APPIMAGETOOL_FILE --appimage-extract;
+rm -f $_APPIMAGETOOL_FILE;
+
+# Generate AppImage
+printf "\nGenerating AppImage\n";
+./squashfs-root/AppRun $_LIBREWOLF_EXTRACTED_FOLDER;
+rm -rf ./squashfs-root;
+chmod +x $_LIBREWOLF_FINAL_APPIMAGE;
+
+# Move AppImage to build_output folder
+printf "\nMoving AppImage to build_output folder\n";
+mv $_LIBREWOLF_FINAL_APPIMAGE $OUTPUT_FOLDER;
diff --git a/browser/linux/appimage/content/.DirIcon b/browser/linux/appimage/content/.DirIcon
new file mode 120000
index 0000000..2653ffb
--- /dev/null
+++ b/browser/linux/appimage/content/.DirIcon
@@ -0,0 +1 @@
+librewolf.svg \ No newline at end of file
diff --git a/browser/linux/resources/appimage/AppRun b/browser/linux/appimage/content/AppRun
index e347dcd..e347dcd 100755
--- a/browser/linux/resources/appimage/AppRun
+++ b/browser/linux/appimage/content/AppRun
diff --git a/browser/linux/resources/appimage/librewolf.desktop b/browser/linux/appimage/content/librewolf.desktop
index 3e36765..3e36765 100644
--- a/browser/linux/resources/appimage/librewolf.desktop
+++ b/browser/linux/appimage/content/librewolf.desktop
diff --git a/browser/linux/appimage/content/librewolf.svg b/browser/linux/appimage/content/librewolf.svg
new file mode 100644
index 0000000..2c6262a
--- /dev/null
+++ b/browser/linux/appimage/content/librewolf.svg
@@ -0,0 +1,90 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!-- Created with Inkscape (http://www.inkscape.org/) -->
+
+<svg
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:cc="http://creativecommons.org/ns#"
+ xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
+ xmlns:svg="http://www.w3.org/2000/svg"
+ xmlns="http://www.w3.org/2000/svg"
+ xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
+ xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
+ width="67.733337mm"
+ height="67.733337mm"
+ viewBox="0 0 67.733337 67.733337"
+ version="1.1"
+ id="svg8"
+ inkscape:version="0.92.4 5da689c313, 2019-01-14"
+ sodipodi:docname="LibreWolf.svg">
+ <defs
+ id="defs2" />
+ <sodipodi:namedview
+ id="base"
+ pagecolor="#ffffff"
+ bordercolor="#666666"
+ borderopacity="1.0"
+ inkscape:pageopacity="0.0"
+ inkscape:pageshadow="2"
+ inkscape:zoom="0.9899495"
+ inkscape:cx="-15.106575"
+ inkscape:cy="110.91343"
+ inkscape:document-units="mm"
+ inkscape:current-layer="layer1"
+ showgrid="false"
+ inkscape:window-width="1366"
+ inkscape:window-height="711"
+ inkscape:window-x="0"
+ inkscape:window-y="30"
+ inkscape:window-maximized="1"
+ inkscape:showpageshadow="false"
+ units="px"
+ fit-margin-top="0"
+ fit-margin-left="0"
+ fit-margin-right="0"
+ fit-margin-bottom="0" />
+ <metadata
+ id="metadata5">
+ <rdf:RDF>
+ <cc:Work
+ rdf:about="">
+ <dc:format>image/svg+xml</dc:format>
+ <dc:type
+ rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
+ <dc:title />
+ </cc:Work>
+ </rdf:RDF>
+ </metadata>
+ <g
+ inkscape:label="Layer 1"
+ inkscape:groupmode="layer"
+ id="layer1"
+ transform="translate(-42.106554,-153.8982)">
+ <circle
+ style="fill:#00acff;fill-opacity:1;stroke:none;stroke-width:0.53545821;stroke-miterlimit:4;stroke-dasharray:none"
+ id="path875"
+ cx="75.973221"
+ cy="187.76486"
+ r="33.866669" />
+ <path
+ style="fill:#ffffff;stroke-width:0.13229167"
+ d="m 72.543594,214.67719 c -4.744093,-0.60875 -9.281981,-2.49991 -13.241953,-5.51858 -1.29157,-0.98455 -3.714943,-3.42363 -4.772834,-4.80375 -2.96241,-3.86476 -4.804479,-8.2508 -5.41218,-12.88661 -0.260164,-1.98464 -0.258719,-5.63349 0.0029,-7.44738 1.308078,-9.0677 7.01463,-16.8454 15.20915,-20.72918 3.811512,-1.80647 7.300266,-2.57114 11.730683,-2.57114 7.165903,0 13.5265,2.56749 18.680882,7.54063 2.483054,2.39575 4.148141,4.66808 5.573968,7.60677 1.92868,3.9751 2.70979,7.43276 2.70979,11.99526 0,6.00619 -1.7345,11.24407 -5.336957,16.11672 -1.070527,1.44797 -3.161747,3.64749 -4.549468,4.78507 -3.806562,3.12041 -8.658642,5.23183 -13.473174,5.86296 -1.663528,0.21807 -5.593318,0.24524 -7.120854,0.0492 z m 10.041381,-4.86547 c 2.898391,-0.91366 5.260364,-2.14146 7.540624,-3.91979 1.212494,-0.9456 3.308223,-3.06144 4.186916,-4.22711 2.38328,-3.16162 4.004927,-7.12196 4.482067,-10.94597 0.229814,-1.84182 0.09634,-5.73827 -0.2545,-7.4296 -0.9294,-4.48046 -2.931647,-8.26499 -6.086007,-11.50342 -1.966575,-2.01898 -3.756882,-3.34972 -6.060203,-4.50458 -3.495001,-1.75236 -6.489835,-2.46043 -10.423481,-2.46442 -4.164073,-0.004 -7.815325,0.95024 -11.429055,2.98766 -3.289753,1.85476 -6.690628,5.25952 -8.553227,8.563 -1.371786,2.43299 -2.37583,5.32029 -2.767595,7.95869 -0.256867,1.72991 -0.261933,5.16508 -0.01006,6.82145 0.504067,3.31489 1.761474,6.59111 3.584314,9.33904 0.995409,1.50058 0.964154,1.48393 1.842248,0.98153 1.570774,-0.8987 1.980396,-1.33342 2.836087,-3.00984 1.000624,-1.96036 2.070459,-3.6735 3.037094,-4.86332 1.115822,-1.37347 1.269228,-1.61793 1.828988,-2.9147 0.281654,-0.65249 0.786977,-1.61074 1.122938,-2.12943 l 0.61084,-0.94309 -0.79023,-0.77671 c -1.049647,-1.03168 -1.922751,-2.2016 -2.087012,-2.79651 -0.167761,-0.60758 0.03021,-0.9466 0.818744,-1.40207 0.797354,-0.46057 1.367585,-0.5929 3.498657,-0.81193 1.037629,-0.10665 2.164153,-0.30199 2.518962,-0.43681 0.353024,-0.13414 1.407825,-0.70824 2.344001,-1.27579 2.702947,-1.63863 2.931619,-1.72344 4.552111,-1.68831 1.368686,0.0297 1.371262,0.0291 2.182813,-0.46143 1.700674,-1.02802 4.14305,-2.88289 7.357044,-5.58733 0.61632,-0.5186 1.21002,-0.92569 1.31934,-0.90464 0.45462,0.0876 1.289567,2.13636 1.416407,3.47562 0.07693,0.81225 -0.08023,1.6155 -0.562014,2.87261 -0.13146,0.34301 -0.19208,0.67043 -0.134706,0.7276 0.13774,0.13726 0.610706,-0.4535 0.610706,-0.76279 0,-0.39435 0.261127,-0.43936 0.616327,-0.10623 0.258235,0.24218 0.480842,0.31151 1.000202,0.31151 0.567073,0 0.707447,0.0526 0.928773,0.3479 0.375574,0.50112 0.463647,1.86688 0.176201,2.73231 -0.279641,0.84191 -1.124801,1.81287 -1.891829,2.17341 -0.686334,0.32262 -2.075841,1.67928 -2.726081,2.66164 -0.248906,0.37604 -0.715586,1.15995 -1.037066,1.74204 -0.321487,0.58208 -0.86074,1.46154 -1.19834,1.95436 -0.664294,0.96972 -1.233147,2.3224 -1.782214,4.23798 -0.322553,1.1253 -0.34962,1.41826 -0.362953,3.92797 -0.01613,3.0317 -0.172894,3.77561 -0.9925,4.7091 -0.931805,1.06126 -1.861937,3.39186 -1.940127,4.8613 -0.04935,0.92751 -0.192246,1.83164 -0.395304,2.50122 -0.08942,0.29484 0.07752,0.2914 1.072102,-0.0221 z"
+ id="path847"
+ inkscape:connector-curvature="0" />
+ <path
+ sodipodi:type="star"
+ style="fill:#00acff;fill-opacity:1;stroke:none;stroke-width:1.5;stroke-miterlimit:4;stroke-dasharray:none"
+ id="path814"
+ sodipodi:sides="4"
+ sodipodi:cx="18.854025"
+ sodipodi:cy="172.98837"
+ sodipodi:r1="1.6036172"
+ sodipodi:r2="1.1339285"
+ sodipodi:arg1="1.5707963"
+ sodipodi:arg2="2.3561945"
+ inkscape:flatsided="true"
+ inkscape:rounded="0"
+ inkscape:randomized="0"
+ d="m 18.854025,174.59199 -1.603617,-1.60362 1.603617,-1.60361 1.603617,1.60361 z"
+ transform="matrix(0.23203125,0.40188991,-0.99392962,0.57384553,246.21921,73.888081)" />
+ </g>
+</svg>
diff --git a/browser/linux/resources/launch_librewolf.sh b/browser/linux/binary_tarball/content/launch_librewolf.sh
index f8b099d..f8b099d 100755
--- a/browser/linux/resources/launch_librewolf.sh
+++ b/browser/linux/binary_tarball/content/launch_librewolf.sh
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;
+
+
diff --git a/browser/linux/build.sh b/browser/linux/build.sh
index 75ee988..cd0b650 100755
--- a/browser/linux/build.sh
+++ b/browser/linux/build.sh
@@ -1,207 +1,22 @@
-#!/bin/bash
+#!/bin/sh
printf "\n------------------------------------- SCRIPT SETUP ------------------------------------------\n";
# Prevents build from breaking in CI/CD environments
-export SHELL=/bin/bash;
-printf "SHELL=$SHELL\n";
+#export SHELL=/bin/bash;
+#printf "SHELL=$SHELL\n";
# Aborts the script upon any faliure
set -e;
# Sets up internal script variables
printf "\nSetting up script variables\n";
-SCRIPT_FOLDER=$(realpath $(dirname $0));
-REPOSITORY_FOLDER=$(realpath $SCRIPT_FOLDER/../../);
-SOURCE_FOLDER=$REPOSITORY_FOLDER/browser/common/source_files/
-BRANDING_FOLDER=$SOURCE_FOLDER/browser/branding/librewolf;
-ICON_FOLDER=$REPOSITORY_FOLDER/branding/icon/;
-PACKAGE_FILE="librewolf*.tar.bz2";
-printf "SCRIPT_FOLDER: $SCRIPT_FOLDER\n";
-printf "REPOSITORY_FOLDER: $REPOSITORY_FOLDER\n";
-printf "SOURCE_FOLDER: $SOURCE_FOLDER\n";
-printf "BRANDING_FOLDER: $BRANDING_FOLDER\n";
-printf "ICON_FOLDER: $ICON_FOLDER\n";
-printf "PACKAGE_FILE: $PACKAGE_FILE\n";
-
-
-printf "\n\n-------------------------------------- PREBUILD ---------------------------------------------\n";
-
-# Installs some needed dependencies
-printf "\nInstalling script dependencies\n";
-apt update;
-apt install gnupg2 -y;
-echo 'deb http://ppa.launchpad.net/alexlarsson/flatpak/ubuntu bionic main' >> /etc/apt/source.list;
-apt-key adv --keyserver keyserver.ubuntu.com --recv-keys FA577F07;
-apt update;
-apt install python python3 inkscape icnsutils wget flatpak flatpak-builder -y;
-
-# Downloads and runs bootstrapper to install more dependencies.
-printf "\nRunning bootstrapper to install build dependencies\n";
-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;
-
-printf "\n\n---------------------------------- ICON GENERATION ------------------------------------------\n";
-# Generates Icons for branding
-printf "\nGenerating icons from $ICON_FOLDER and moving to $BRANDING_FOLDER\n";
-
-# Generates Linux Icons
-printf "\nGenerating Linux Icons\n";
-inkscape -z -f $ICON_FOLDER/icon.svg -e $BRANDING_FOLDER/default16.png -w 16 -h 16;
-inkscape -z -f $ICON_FOLDER/icon.svg -e $BRANDING_FOLDER/default32.png -w 32 -h 32;
-inkscape -z -f $ICON_FOLDER/icon.svg -e $BRANDING_FOLDER/default48.png -w 48 -h 48;
-inkscape -z -f $ICON_FOLDER/icon.svg -e $BRANDING_FOLDER/default64.png -w 64 -h 64;
-inkscape -z -f $ICON_FOLDER/icon.svg -e $BRANDING_FOLDER/default128.png -w 128 -h 128;
-
-# Generates Windows Icons
-printf "\nGenerating Windows Icons\n";
-inkscape -z -f $ICON_FOLDER/icon.svg -e $BRANDING_FOLDER/VisualElements_70.png -w 70 -h70;
-inkscape -z -f $ICON_FOLDER/icon.svg -e $BRANDING_FOLDER/VisualElements_150.png -w 150 -h150;
-
-# Generates Apple Icons
-printf "\nGenerating Apple Icons\n";
-png2icns $BRANDING_FOLDER/firefox.icns $BRANDING_FOLDER/default128.png;
-inkscape -z -f $ICON_FOLDER/document-icon.svg -e $BRANDING_FOLDER/document-icon.png -w 128 -h 128;
-png2icns $BRANDING_FOLDER/document.icns $BRANDING_FOLDER/document-icon.png;
-rm -r $BRANDING_FOLDER/document-icon.png
-
-printf "\n\n--------------------------------- SOURCE CODE DOWNLOAD --------------------------------------\n";
-
-# Creates and enters the folder where compiling will take place
-printf "\nCreating compile folder\n";
-mkdir -p compile_folder;
-cd compile_folder;
-
-# Clones the firefox source code for compiling
-printf "\nCloning Firefox Source Code\n";
-hg clone https://hg.mozilla.org/releases/mozilla-release;
-cd mozilla-release;
-
-printf "\n\n------------------------------ FINAL PREBUILD CONFIGURATION ---------------------------------\n";
-
-# Copies our branding to the source code, changing it from firefox to librewolf
-printf "\nCopying branding to firefox source code\n";
-cp -r $SOURCE_FOLDER/* ./;
-
-# Disables pocket
-printf "\nDisabling Pocket\n";
-sed -i "s/'pocket'/#'pocket'/g" ./browser/components/moz.build;
-
-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;
-
-# Builds librewolf
-printf "\nBuilding LibreWolf\n";
-./mach build;
-
-# Packages LibreWolf
-printf "\nPackaging LibreWolf\n";
-./mach package;
-
-# moves the packaged tarball to the script folder
-printf "\nRelocating binary tarball to script folder\n";
-cp ./obj*/dist/librewolf*.tar.bz2 $SCRIPT_FOLDER;
-
-# Remove the compile folder
-printf "\nDeleting the compile_folder\n";
-cd $SCRIPT_FOLDER;
-rm -rf ./compile_folder;
-
-
-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 $REPOSITORY_FOLDER/settings ./librewolf/settings;
-cp $SCRIPT_FOLDER/resources/launch_librewolf.sh ./librewolf/launch_librewolf.sh
-mkdir -p $INSTALL_FOLDER/defaults/pref/;
-mkdir -p $INSTALL_FOLDER/distribution/;
-
-printf "\n\n--------------------------------- BINARY TARBALL RECREATION --------------------------------------\n";
-
-# Repacks the binary tarball
-printf "\nRecompressing binary tarball\n";
-tar -jcvf ./$PACKAGE_FILE librewolf;
-
-# Moves the final binary tarball to build_output
-printf "\nMoving binary tarball to build_output folder\n";
-mv $PACKAGE_FILE $SCRIPT_FOLDER/build_output/;
-
-printf "\n\n------------------------------------ APPIMAGE BUILD -----------------------------------------\n";
-
-APPIMAGE_RESOURCE_FOLDER=$SCRIPT_FOLDER/resources/appimage;
-printf "APPIMAGE_RESOURCE_FOLDER: $APPIMAGE_RESOURCE_FOLDER\n";
-
-# Copy and generate icons
-printf "\nGenerating AppImage Icons\n";
-cp $ICON_FOLDER/icon.svg $APPIMAGE_RESOURCE_FOLDER/librewolf.svg;
-ln -rs $APPIMAGE_RESOURCE_FOLDER/librewolf.svg $SCRIPT_FOLDER/resources/appimage/.DirIcon;
-
-# Copy appimage resources to main tarball
-printf "Copying AppImage resources to binary tarball folder\n";
-cp -vrT $APPIMAGE_RESOURCE_FOLDER ./librewolf;
-
-# Downloads appimage tool
-printf "\nDownloading AppImage Tool\n";
-wget https://github.com/AppImage/AppImageKit/releases/latest/download/appimagetool-x86_64.AppImage -O appimagetool;
-chmod +x ./appimagetool;
-./appimagetool --appimage-extract;
-
-# Generate AppImage
-printf "\nGenerating AppImage\n";
-./squashfs-root/AppRun ./librewolf;
-chmod +x ./LibreWolf*.AppImage;
-
-# Move AppImage to build_output folder
-printf "\nMoving AppImage to build_output folder\n";
-mv ./LibreWolf*.AppImage ./build_output;
-
-# Delete the appimage tool
-printf "\nRemoving AppImage tool\n";
-rm -f ./appimagetool;
-rm -rf ./squashfs-root;
-
-
-printf "\n\n---------------------------------------- FLATPAK BUILD --------------------------------------------\n";
-
-# Install build dependencies
-printf "\nInstalling flatpak build dependencies\n";
-flatpak remote-add --if-not-exists flathub https://flathub.org/repo/flathub.flatpakrepo;
-flatpak install -y org.gnome.Platform/x86_64/3.32 org.gnome.Sdk/x86_64/3.32;
-
-# Prepare for flatpak build
-printf "\nPreparing files for flatpak build\n";
-mkdir "source";
-cp -r ./librewolf ./source/librewolf;
-cp $SCRIPT_FOLDER/resources/flatpak/io.gitlab.LibreWolf.json ./io.gitlab.LibreWolf.json;
-
-# Build Repo and standalone bundle
-printf "\nBuilding flatpak repository and bundle\n";
-flatpak-builder --repo=librewolf-flatpak-repo build-dir io.gitlab.LibreWolf.json;
-flatpak build-bundle librewolf-flatpak-repo LibreWolf.flatpak io.gitlab.LibreWolf master;
-
-# move repo and bundle to build output here
-printf "\nMoving repository and bundle to build output folder\n";
-mv libreWolf-flatpak-repo build_output;
-mv LibreWolf.flatpak build_output;
-
-# Clean up flatpak files
-printf "\nCleaning up flatpak related files\n";
-rm -rf ./build-dir;
-rm -rf ./source;
-rm -rf ./.flatpak-builder;
-
-# Delete the extracted binary tarball folder
-printf "\nDeleting extracted binary tarball folder\n";
-rm -rf ./librewolf;
+SCRIPT_FOLDER=$(realpath $(dirname $0)) && printf "SCRIPT_FOLDER: $SCRIPT_FOLDER\n";
+REPOSITORY_FOLDER=$(realpath $SCRIPT_FOLDER/../../) && printf "REPOSITORY_FOLDER: $REPOSITORY_FOLDER\n";
+SOURCE_FOLDER=$SCRIPT_FOLDER/compile && printf "SOURCE_FOLDER: $SOURCE_FOLDER\n";
+SOURCE_CONTENT_FOLDER=$REPOSITORY_FOLDER/browser/common/source_files/ && printf "SOURCE_CONTENT_FOLDER: $SOURCE_CONTENT_FOLDER\n";
+BINARY_TARBALL=$SCRIPT_FOLDER/LibreWolf.tar.bz2 && printf "BINARY_TARBALL: $BINARY_TARBALL\n";
+
+$SCRIPT_FOLDER/binary_tarball/scripts/1_Install_Dependencies.sh;
+$SCRIPT_FOLDER/binary_tarball/scripts/2_Download_Source_Code.sh $SOURCE_FOLDER;
+$SCRIPT_FOLDER/binary_tarball/scripts/3_Configure_Source_Code.sh $SOURCE_FOLDER $SOURCE_CONTENT_FOLDER;
+$SCRIPT_FOLDER/binary_tarball/scripts/4_Build_Binary_Tarball.sh $SOURCE_FOLDER $BINARY_TARBALL;
diff --git a/browser/linux/build_output/.gitignore b/browser/linux/build_output/.gitignore
deleted file mode 100644
index d6b7ef3..0000000
--- a/browser/linux/build_output/.gitignore
+++ /dev/null
@@ -1,2 +0,0 @@
-*
-!.gitignore
diff --git a/browser/linux/flatpak/build_flatpak.sh b/browser/linux/flatpak/build_flatpak.sh
new file mode 100644
index 0000000..c2f487d
--- /dev/null
+++ b/browser/linux/flatpak/build_flatpak.sh
@@ -0,0 +1,44 @@
+
+printf "\n\n---------------------------------------- FLATPAK BUILD --------------------------------------------\n";
+
+# Install flatpak
+# Installs some needed dependencies
+printf "\nInstalling script dependencies\n";
+apt update;
+apt install -y gnupg2;
+
+echo 'deb http://ppa.launchpad.net/alexlarsson/flatpak/ubuntu bionic main' >> /etc/apt/source.list;
+apt-key adv --keyserver keyserver.ubuntu.com --recv-keys FA577F07;
+apt update;
+apt install -y flatpak flatpak-builder;
+
+# Install build dependencies
+printf "\nInstalling flatpak build dependencies\n";
+flatpak remote-add --if-not-exists flathub https://flathub.org/repo/flathub.flatpakrepo;
+flatpak install -y org.gnome.Platform/x86_64/3.32 org.gnome.Sdk/x86_64/3.32;
+
+# Prepare for flatpak build
+printf "\nPreparing files for flatpak build\n";
+mkdir "source";
+cp -r ./librewolf ./source/librewolf;
+cp $SCRIPT_FOLDER/resources/flatpak/io.gitlab.LibreWolf.json ./io.gitlab.LibreWolf.json;
+
+# Build Repo and standalone bundle
+printf "\nBuilding flatpak repository and bundle\n";
+flatpak-builder --repo=librewolf-flatpak-repo build-dir io.gitlab.LibreWolf.json;
+flatpak build-bundle librewolf-flatpak-repo LibreWolf.flatpak io.gitlab.LibreWolf master;
+
+# move repo and bundle to build output here
+printf "\nMoving repository and bundle to build output folder\n";
+mv libreWolf-flatpak-repo build_output;
+mv LibreWolf.flatpak build_output;
+
+# Clean up flatpak files
+printf "\nCleaning up flatpak related files\n";
+rm -rf ./build-dir;
+rm -rf ./source;
+rm -rf ./.flatpak-builder;
+
+# Delete the extracted binary tarball folder
+printf "\nDeleting extracted binary tarball folder\n";
+rm -rf ./librewolf;
diff --git a/browser/linux/resources/flatpak/io.gitlab.LibreWolf.json b/browser/linux/flatpak/content/io.gitlab.LibreWolf.json
index 0e2b549..0e2b549 100644
--- a/browser/linux/resources/flatpak/io.gitlab.LibreWolf.json
+++ b/browser/linux/flatpak/content/io.gitlab.LibreWolf.json
diff --git a/browser/linux/resources/appimage/.gitignore b/browser/linux/resources/appimage/.gitignore
deleted file mode 100644
index 9f0e081..0000000
--- a/browser/linux/resources/appimage/.gitignore
+++ /dev/null
@@ -1,2 +0,0 @@
-.DirIcon
-librewolf.svg
bgstack15