install.sh: add git mirror and code cleanup (#192)

Closes #181
This commit is contained in:
Adel Kara Slimane 2021-03-09 16:58:59 +01:00 committed by GitHub
parent 93e728b93c
commit 9e81e3bd1d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 53 additions and 32 deletions

View File

@ -17,6 +17,9 @@ _EXT_CONFIG_PATH=~/.config/frogminer/linux-tkg.cfg
# Default is "true". # Default is "true".
_NUKR="true" _NUKR="true"
# [install.sh specific] Git mirror to use to get the kernel sources, possible values are "googlesource.com" and "kernel.org"
_git_mirror="kernel.org"
# Custom compiler root dirs - Leave empty to use system compilers # Custom compiler root dirs - Leave empty to use system compilers
# Example: CUSTOM_GCC_PATH="/home/frog/PKGBUILDS/mostlyportable-gcc/gcc-mostlyportable-9.2.0" # Example: CUSTOM_GCC_PATH="/home/frog/PKGBUILDS/mostlyportable-gcc/gcc-mostlyportable-9.2.0"
CUSTOM_GCC_PATH="" CUSTOM_GCC_PATH=""

View File

@ -73,21 +73,49 @@ _linux_git_branch_checkout() {
cd "$_where" cd "$_where"
if [[ -z $_git_mirror || ! $_git_mirror =~ ^(kernel\.org|googlesource\.com)$ ]]; then
while true; do
echo "Which git repository would you like to clone the linux sources from ?"
echo " 0) kernel.org (official)"
echo " 1) googlesource.com (faster mirror)"
read -p "[0-1]: " _git_repo_index
if [ "$_git_repo_index" = "0" ]; then
_git_mirror="kernel.org"
break
elif [ "$_git_repo_index" = "1" ]; then
_git_mirror="googlesource.com"
break
else
echo "Wrong index."
fi
done
fi
if ! [ -d linux-src-git ]; then if ! [ -d linux-src-git ]; then
msg2 "First initialization of the linux source code git folder" msg2 "First initialization of the linux source code git folder"
mkdir linux-src-git mkdir linux-src-git
cd linux-src-git cd linux-src-git
git init git init
git remote add origin https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
git remote add kernel.org https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
git remote add googlesource.com https://kernel.googlesource.com/pub/scm/linux/kernel/git/stable/linux-stable
else else
cd linux-src-git cd linux-src-git
if ! git remote -v | grep "kernel.org" ; then
git remote add kernel.org https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
fi
if ! git remote -v | grep "googlesource.com" ; then
git remote add googlesource.com https://kernel.googlesource.com/pub/scm/linux/kernel/git/stable/linux-stable
fi
msg2 "Current branch: $(git branch | grep "\*")" msg2 "Current branch: $(git branch | grep "\*")"
msg2 "Reseting files to their original state" msg2 "Reseting files to their original state"
git reset --hard HEAD git reset --hard HEAD
git clean -f -d -x git clean -f -d -x
fi fi
_clone_start_date=$(date -d "$(date +"%Y/%m/%d") - 21 day" +"%Y/%m/%d") _clone_start_date=$(date -d "$(date +"%Y/%m/%d") - 21 day" +"%Y/%m/%d")
@ -96,50 +124,40 @@ _linux_git_branch_checkout() {
if ! git branch --list | grep "master" ; then if ! git branch --list | grep "master" ; then
msg2 "master branch doesn't locally exist, shallow cloning..." msg2 "master branch doesn't locally exist, shallow cloning..."
git remote set-branches --add origin master git remote set-branches --add $_git_mirror master
git fetch origin master --shallow-since=$_clone_start_date git fetch $_git_mirror master --shallow-since=$_clone_start_date
git checkout -b master origin/master git checkout -b master ${_git_mirror}/master
else else
msg2 "master branch exists locally, updating..." msg2 "master branch exists locally, updating..."
git checkout master git checkout master
git fetch origin master --shallow-since=$_clone_start_date git fetch $_git_mirror master --shallow-since=$_clone_start_date
git reset --hard origin/master git reset --hard ${_git_mirror}/master
fi fi
msg2 "Checking out latest RC tag: v${_basekernel}-${_sub}" msg2 "Checking out latest RC tag: v${_basekernel}-${_sub}"
git fetch origin tag "v${_basekernel}-${_sub}" git fetch $_git_mirror tag "v${_basekernel}-${_sub}"
git checkout "v${_basekernel}-${_sub}" git checkout "v${_basekernel}-${_sub}"
elif [ "$_sub" = "0" ]; then
msg2 "Switching to linux-${_basekernel}.y"
if ! git branch --list | grep "linux-${_basekernel}.y" ; then
msg2 "${_basekernel}.y branch doesn't locally exist, shallow cloning..."
git remote set-branches --add origin linux-${_basekernel}.y
git fetch origin linux-${_basekernel}.y --shallow-since=$_clone_start_date
git checkout -b linux-${_basekernel}.y origin/linux-${_basekernel}.y
else
msg2 "${_basekernel}.y branch exists locally, updating..."
git checkout linux-${_basekernel}.y
git fetch origin linux-${_basekernel}.y --shallow-since=$_clone_start_date
git reset --hard origin/linux-${_basekernel}.y
fi
msg2 "Checking out latest release: v${_basekernel}"
git fetch origin tag "v${_basekernel}"
git checkout "v${_basekernel}"
else else
# define kernel tag so we treat the 0 subver properly
_kernel_tag="v${_basekernel}.${_sub}"
if [ "$_sub" = "0" ];then
_kernel_tag="v${_basekernel}"
fi
msg2 "Switching to linux-${_basekernel}.y" msg2 "Switching to linux-${_basekernel}.y"
if ! git branch --list | grep "linux-${_basekernel}.y" ; then if ! git branch --list | grep "linux-${_basekernel}.y" ; then
msg2 "${_basekernel}.y branch doesn't locally exist, shallow cloning..." msg2 "${_basekernel}.y branch doesn't locally exist, shallow cloning..."
git remote set-branches --add origin linux-${_basekernel}.y git remote set-branches --add $_git_mirror linux-${_basekernel}.y
git fetch origin linux-${_basekernel}.y --shallow-since=$_clone_start_date git fetch $_git_mirror linux-${_basekernel}.y --shallow-since=$_clone_start_date
git checkout -b linux-${_basekernel}.y origin/linux-${_basekernel}.y git checkout -b linux-${_basekernel}.y ${_git_mirror}/linux-${_basekernel}.y
else else
msg2 "${_basekernel}.y branch exists locally, updating..." msg2 "${_basekernel}.y branch exists locally, updating..."
git checkout linux-${_basekernel}.y git checkout linux-${_basekernel}.y
git fetch origin linux-${_basekernel}.y --shallow-since=$_clone_start_date git fetch $_git_mirror linux-${_basekernel}.y --shallow-since=$_clone_start_date
git reset --hard origin/linux-${_basekernel}.y git reset --hard ${_git_mirror}/linux-${_basekernel}.y
fi fi
msg2 "Checking out latest release: v${_basekernel}.${_sub}" msg2 "Checking out latest release: ${_kernel_tag}"
git fetch origin tag "v${_basekernel}.${_sub}" git fetch $_git_mirror tag "${_kernel_tag}"
git checkout "v${_basekernel}.${_sub}" git checkout "${_kernel_tag}"
fi fi
} }