优化代码
This commit is contained in:
parent
990d01c510
commit
a735dc95dd
|
@ -5,21 +5,17 @@
|
|||
GET_INFO() {
|
||||
Diy_Core
|
||||
Home="${GITHUB_WORKSPACE}/openwrt"
|
||||
[ -f "${GITHUB_WORKSPACE}/Openwrt.info" ] && source ${GITHUB_WORKSPACE}/Openwrt.info
|
||||
[[ "${Short_Firmware_Date}" == true ]] && Compile_Date="$(echo ${Compile_Date} | cut -c1-8)"
|
||||
[[ -f ${GITHUB_WORKSPACE}/Openwrt.info ]] && source ${GITHUB_WORKSPACE}/Openwrt.info
|
||||
[[ ${Short_Firmware_Date} == true ]] && Compile_Date="$(echo ${Compile_Date} | cut -c1-8)"
|
||||
User_Repo="$(grep "https://github.com/[a-zA-Z0-9]" ${GITHUB_WORKSPACE}/.git/config | cut -c8-100 | sed 's/^[ \t]*//g')"
|
||||
[[ -z "${Author}" ]] && {
|
||||
Author="$(echo "${User_Repo}" | cut -d "/" -f4)"
|
||||
}
|
||||
[[ -z ${Author} ]] && Author="$(echo "${User_Repo}" | cut -d "/" -f4)"
|
||||
Openwrt_Author="$(echo "${Openwrt_Repo}" | cut -d "/" -f4)"
|
||||
Openwrt_Repo_Name="$(echo "${Openwrt_Repo}" | cut -d "/" -f5)"
|
||||
Openwrt_Branch="$(GET_BRANCH)"
|
||||
[[ ! ${Openwrt_Branch} == master ]] && {
|
||||
Openwrt_Branch="$(echo ${Openwrt_Branch} | egrep -o "[0-9]+.[0-9]+")"
|
||||
Openwrt_Version_="R${Openwrt_Branch}-"
|
||||
} || {
|
||||
Openwrt_Version_="R$(date +%y.%m)-"
|
||||
}
|
||||
} || Openwrt_Version_="R$(date +%y.%m)-"
|
||||
case "${Openwrt_Author}" in
|
||||
coolsnowwolf)
|
||||
Version_File=package/lean/default-settings/files/zzz-default-settings
|
||||
|
@ -34,26 +30,21 @@ GET_INFO() {
|
|||
CURRENT_Version="${Openwrt_Version_}${Compile_Date}"
|
||||
;;
|
||||
esac
|
||||
while [[ -z "${x86_Test}" ]]
|
||||
do
|
||||
while [[ -z ${x86_Test} ]];do
|
||||
x86_Test="$(egrep -o "CONFIG_TARGET.*DEVICE.*=y" .config | sed -r 's/CONFIG_TARGET_(.*)_DEVICE_(.*)=y/\1/')"
|
||||
[[ -n "${x86_Test}" ]] && break
|
||||
[[ -n ${x86_Test} ]] && break
|
||||
x86_Test="$(egrep -o "CONFIG_TARGET.*Generic=y" .config | sed -r 's/CONFIG_TARGET_(.*)_Generic=y/\1/')"
|
||||
[[ -z "${x86_Test}" ]] && TIME "[ERROR] Can not obtain the TARGET_PROFILE !" && exit 1
|
||||
[[ -z ${x86_Test} ]] && TIME "[ERROR] Can not obtain the TARGET_PROFILE !" && exit 1
|
||||
done
|
||||
[[ "${x86_Test}" == x86_64 ]] && {
|
||||
[[ ${x86_Test} == x86_64 ]] && {
|
||||
TARGET_PROFILE=x86_64
|
||||
} || {
|
||||
TARGET_PROFILE="$(egrep -o "CONFIG_TARGET.*DEVICE.*=y" .config | sed -r 's/.*DEVICE_(.*)=y/\1/')"
|
||||
}
|
||||
[[ -z "${TARGET_PROFILE}" ]] && TARGET_PROFILE="${Default_Device}"
|
||||
[[ -z "${Default_Device}" ]] && Default_Device="${TARGET_PROFILE}"
|
||||
[[ "${TARGET_PROFILE}" == x86_64 ]] && {
|
||||
[[ "$(cat ${Home}/.config)" =~ "CONFIG_TARGET_IMAGES_GZIP=y" ]] && {
|
||||
Firmware_Type=img.gz
|
||||
} || {
|
||||
Firmware_Type=img
|
||||
}
|
||||
[[ -z ${TARGET_PROFILE} ]] && TARGET_PROFILE="${Default_Device}"
|
||||
[[ -z ${Default_Device} ]] && Default_Device="${TARGET_PROFILE}"
|
||||
[[ ${TARGET_PROFILE} == x86_64 ]] && {
|
||||
[[ $(cat ${Home}/.config) =~ CONFIG_TARGET_IMAGES_GZIP=y ]] && Firmware_Type=img.gz || Firmware_Type=img
|
||||
}
|
||||
TARGET_BOARD="$(awk -F '[="]+' '/TARGET_BOARD/{print $2}' .config)"
|
||||
case "${TARGET_BOARD}" in
|
||||
|
@ -128,7 +119,6 @@ EOF
|
|||
INCLUDE_Obsolete_PKG_Compatible=${INCLUDE_Obsolete_PKG_Compatible}
|
||||
Home=${Home}
|
||||
Firmware_Path=${Firmware_Path}
|
||||
Firmware_Head=${Firmware_Head}
|
||||
EOF
|
||||
|
||||
case "${TARGET_PROFILE}" in
|
||||
|
@ -156,18 +146,17 @@ Firmware-Diy_Base() {
|
|||
mkdir -p package/base-files/files/etc/AutoBuild
|
||||
[ -f VARIABLE_FILE_Main ] && cp VARIABLE_FILE_Main package/base-files/files/etc/AutoBuild/Default_Variable
|
||||
Replace_File CustomFiles/Depends/Custom_Variable package/base-files/files/etc/AutoBuild
|
||||
Auto_AddPackage
|
||||
AddPackage_List ${GITHUB_WORKSPACE}/CustomPackages/Common
|
||||
AddPackage_List ${GITHUB_WORKSPACE}/CustomPackages/${TARGET_PROFILE}
|
||||
chmod +x -R ${GITHUB_WORKSPACE}/Scripts
|
||||
chmod 777 -R ${GITHUB_WORKSPACE}/CustomFiles
|
||||
chmod 777 -R ${GITHUB_WORKSPACE}/CustomPackages
|
||||
[[ "${INCLUDE_AutoBuild_Tools}" == true ]] && {
|
||||
[[ ${INCLUDE_AutoBuild_Features} == true ]] && {
|
||||
Replace_File Scripts/AutoBuild_Tools.sh package/base-files/files/bin
|
||||
}
|
||||
[[ "${INCLUDE_AutoUpdate}" == true ]] && {
|
||||
AddPackage git lean luci-app-autoupdate Hyy2001X main
|
||||
Replace_File Scripts/AutoUpdate.sh package/base-files/files/bin
|
||||
}
|
||||
[[ "${INCLUDE_Theme_Argon}" == true ]] && {
|
||||
[[ ${INCLUDE_Argon} == true ]] && {
|
||||
case "${Openwrt_Author}" in
|
||||
coolsnowwolf)
|
||||
AddPackage git lean luci-theme-argon jerrykuku 18.06
|
||||
|
@ -189,16 +178,17 @@ Firmware-Diy_Base() {
|
|||
esac
|
||||
;;
|
||||
esac
|
||||
AddPackage git other luci-app-argon-config jerrykuku
|
||||
}
|
||||
New_IP_Address="${Default_IP_Address}"
|
||||
if [[ -n "${Defined_IP_Address}" ]];then
|
||||
[[ -n ${Defined_IP_Address} ]] && {
|
||||
TIME "Using defined IP Address [${Defined_IP_Address}] ..."
|
||||
New_IP_Address="${Defined_IP_Address}"
|
||||
fi
|
||||
[[ -n "${New_IP_Address}" ]] && [[ "${New_IP_Address}" != false ]] && {
|
||||
if [[ "${New_IP_Address}" =~ ^[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}$ ]];then
|
||||
}
|
||||
[[ -n ${New_IP_Address} && ${New_IP_Address} != false ]] && {
|
||||
if [[ ${New_IP_Address} =~ ^[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}$ ]];then
|
||||
Old_IP_Address=$(awk -F '[="]+' '/ipaddr:-/{print $3}' package/base-files/files/bin/config_generate | awk 'NR==1')
|
||||
if [[ ! "${New_IP_Address}" == "${Old_IP_Address}" ]];then
|
||||
if [[ ! ${New_IP_Address} == ${Old_IP_Address} ]];then
|
||||
TIME "Setting default IP Address to ${New_IP_Address} ..."
|
||||
sed -i "s/${Old_IP_Address}/${New_IP_Address}/g" package/base-files/files/bin/config_generate
|
||||
a=$(echo ${Old_IP_Address} | egrep -o "[0-9]+.[0-9]+." | awk 'NR==1')
|
||||
|
@ -225,14 +215,14 @@ Firmware-Diy_Base() {
|
|||
sed -i 's/143/143,8080/' $(PKG_Finder d package luci-app-ssr-plus)/root/etc/init.d/shadowsocksr
|
||||
sed -i "s?iptables?#iptables?g" ${Version_File}
|
||||
sed -i "s?${Old_Version}?${Old_Version} @ ${Author} [${Display_Date}]?g" ${Version_File}
|
||||
# [[ "${INCLUDE_DRM_I915}" == true ]] && Replace_File CustomFiles/Depends/i915-5.4 target/linux/x86 config-5.4
|
||||
# [[ ${INCLUDE_DRM_I915} == true ]] && Replace_File CustomFiles/Depends/i915-5.4 target/linux/x86 config-5.4
|
||||
;;
|
||||
immortalwrt)
|
||||
Replace_File CustomFiles/Depends/coremark_ImmortalWrt.sh package/base-files/files/etc coremark.sh
|
||||
Replace_File CustomFiles/Depends/ImmortalWrt package/base-files/files/etc openwrt_release
|
||||
Replace_File CustomFiles/Depends/cpuinfo_x86 package/lean/autocore/files/x86/sbin cpuinfo
|
||||
sed -i "s?Template?Compiled by ${Author} [${Display_Date}]?g" ${Version_File}
|
||||
# [[ "${INCLUDE_DRM_I915}" == true ]] && Replace_File CustomFiles/Depends/i915-4.19 target/linux/x86 config-4.19
|
||||
# [[ ${INCLUDE_DRM_I915} == true ]] && Replace_File CustomFiles/Depends/i915-4.19 target/linux/x86 config-4.19
|
||||
;;
|
||||
esac
|
||||
case "${Openwrt_Author}" in
|
||||
|
@ -264,9 +254,9 @@ Other_Scripts() {
|
|||
INCLUDE_Obsolete_PKG_Compatible=true
|
||||
;;
|
||||
esac
|
||||
if [[ "${INCLUDE_Obsolete_PKG_Compatible}" == true ]];then
|
||||
if [[ ${INCLUDE_Obsolete_PKG_Compatible} == true ]];then
|
||||
TIME "Start to run Obsolete_Package_Compatible Scripts ..."
|
||||
if [[ ${Openwrt_Author} == openwrt ]] || [[ "${Force_mode}" == 1 ]];then
|
||||
if [[ ${Openwrt_Author} == openwrt || ${Force_mode} == 1 ]];then
|
||||
case "${Openwrt_Branch}" in
|
||||
19.07 | 21.02)
|
||||
Replace_File CustomFiles/Patches/0003-upx-ucl-${Openwrt_Branch}.patch ./
|
||||
|
@ -284,35 +274,34 @@ Other_Scripts() {
|
|||
TIME "Current source: [${Openwrt_Author}] is not supported,skip..."
|
||||
fi
|
||||
fi
|
||||
if [ -s $GITHUB_WORKSPACE/Configs/Common ];then
|
||||
[[ -s $GITHUB_WORKSPACE/Configs/Common ]] && {
|
||||
TIME "Merging Common_Config to .config ..."
|
||||
echo -e "\n$(cat $GITHUB_WORKSPACE/Configs/Common)" >> .config
|
||||
fi
|
||||
}
|
||||
}
|
||||
|
||||
PS_Firmware() {
|
||||
source ./VARIABLE_FILE_Sec
|
||||
rm -rf ${Firmware_Path}/packages
|
||||
mkdir -p bin/Firmware
|
||||
cd ${Firmware_Path}
|
||||
case "${TARGET_PROFILE}" in
|
||||
x86_64)
|
||||
if [ -f "${Default_Legacy_Firmware}" ];then
|
||||
[[ -f ${Default_Legacy_Firmware} ]] && {
|
||||
cp ${Default_Legacy_Firmware} $(EVAL_FW x86_64 Legacy ${Home}/VARIABLE_FILE_Sec)
|
||||
TIME "Legacy Firmware: [${Default_Legacy_Firmware}] is detected !"
|
||||
fi
|
||||
if [ -f "${Default_UEFI_Firmware}" ];then
|
||||
}
|
||||
[[ -f ${Default_UEFI_Firmware} ]] && {
|
||||
cp ${Default_UEFI_Firmware} $(EVAL_FW x86_64 UEFI ${Home}/VARIABLE_FILE_Sec)
|
||||
TIME "UEFI Firmware: [${Default_UEFI_Firmware}] is detected !"
|
||||
fi
|
||||
}
|
||||
;;
|
||||
*)
|
||||
if [ -f "${Default_Firmware}" ];then
|
||||
[[ -f ${Default_Firmware} ]] && {
|
||||
cp ${Default_Firmware} $(EVAL_FW common ${Home}/VARIABLE_FILE_Sec)
|
||||
TIME "Firmware: [${Default_Firmware}] is detected !"
|
||||
else
|
||||
} || {
|
||||
TIME "[ERROR] Firmware is not detected !"
|
||||
fi
|
||||
}
|
||||
;;
|
||||
esac
|
||||
mv -f AutoBuild-* ${Home}/bin/Firmware
|
||||
|
@ -324,11 +313,11 @@ EVAL_FW() {
|
|||
case "$1" in
|
||||
x86_64)
|
||||
x86_64_Boot=$2
|
||||
SHA5BIT=$(GET_SHA5BIT $(GET_VARIABLE Default_$2_Firmware= $3))
|
||||
SHA5BIT=$(GET_SHA5BIT $(GET_VARIABLE Default_$2_Firmware= $3) 5)
|
||||
EVAL_VARIABLE $(GET_VARIABLE AutoBuild_Firmware= $3)
|
||||
;;
|
||||
common)
|
||||
SHA5BIT=$(GET_SHA5BIT $(GET_VARIABLE Default_Firmware= $2))
|
||||
SHA5BIT=$(GET_SHA5BIT $(GET_VARIABLE Default_Firmware= $2) 5)
|
||||
EVAL_VARIABLE $(GET_VARIABLE AutoBuild_Firmware= $2)
|
||||
;;
|
||||
esac
|
||||
|
@ -336,16 +325,16 @@ EVAL_FW() {
|
|||
|
||||
EVAL_VARIABLE() {
|
||||
eval OUTPUT=$1
|
||||
echo -e "${OUTPUT}"
|
||||
echo "${OUTPUT}"
|
||||
}
|
||||
|
||||
GET_SHA5BIT() {
|
||||
grep "$1" sha256sums | cut -c1-5
|
||||
grep "$1" sha256sums | cut -c1-$2
|
||||
}
|
||||
|
||||
GET_BRANCH() {
|
||||
Folder="$(pwd)"
|
||||
[ -n "$1" ] && Folder="$1"
|
||||
[[ -n $1 ]] && Folder="$1"
|
||||
git -C "${Folder}" rev-parse --abbrev-ref HEAD | grep -v HEAD || \
|
||||
git -C "${Folder}" describe --exact-match HEAD || \
|
||||
git -C "${Folder}" rev-parse HEAD
|
||||
|
@ -356,7 +345,7 @@ GET_VARIABLE() {
|
|||
}
|
||||
|
||||
TIME() {
|
||||
echo "[$(date "+%H:%M:%S")] ${*}"
|
||||
echo "[$(date "+%H:%M:%S")] $*"
|
||||
}
|
||||
|
||||
PKG_Finder() {
|
||||
|
@ -367,22 +356,17 @@ PKG_Finder() {
|
|||
find $2 -name $3 -type $1 -depth -exec echo {} \;
|
||||
}
|
||||
|
||||
Auto_AddPackage() {
|
||||
Auto_AddPackage_mod ${GITHUB_WORKSPACE}/CustomPackages/Common
|
||||
Auto_AddPackage_mod ${GITHUB_WORKSPACE}/CustomPackages/${TARGET_PROFILE}
|
||||
}
|
||||
|
||||
Auto_AddPackage_mod() {
|
||||
AddPackage_List() {
|
||||
[[ $# != 1 ]] && {
|
||||
TIME "[ERROR] Error options: [$#] [$*] !"
|
||||
return 0
|
||||
}
|
||||
echo "" >> $1
|
||||
[ -s "$1" ] && {
|
||||
[[ -s $1 ]] && {
|
||||
TIME "Loading Custom Packages list: [$1]..."
|
||||
cat $1 | sed '/^$/d' | while read X
|
||||
do
|
||||
[[ -n "${X}" ]] && AddPackage ${X}
|
||||
[[ -n ${X} && ! $* =~ "#" ]] && AddPackage ${X}
|
||||
done
|
||||
}
|
||||
}
|
||||
|
@ -392,14 +376,15 @@ AddPackage() {
|
|||
TIME "[ERROR] Error options: [$#] [$*] !"
|
||||
return 0
|
||||
}
|
||||
[[ $* =~ "#" ]] && return 0
|
||||
PKG_PROTO="$1"
|
||||
PKG_DIR="$2"
|
||||
PKG_NAME="$3"
|
||||
REPO_URL="https://github.com/${4}"
|
||||
[[ -z "$5" ]] && REPO_BRANCH=master || REPO_BRANCH="$5"
|
||||
REPO_URL="https://github.com/$4"
|
||||
[[ -z $5 ]] && REPO_BRANCH=master || REPO_BRANCH="$5"
|
||||
|
||||
mkdir -p package/${PKG_DIR}
|
||||
[ -d "package/${PKG_DIR}/${PKG_NAME}" ] && {
|
||||
[[ -d package/${PKG_DIR}/${PKG_NAME} ]] && {
|
||||
TIME "Removing old package: [${PKG_NAME}] ..."
|
||||
rm -rf package/${PKG_DIR}/${PKG_NAME}
|
||||
}
|
||||
|
@ -414,12 +399,9 @@ AddPackage() {
|
|||
svn checkout ${REPO_URL}/${PKG_NAME} ${PKG_NAME} > /dev/null 2>&1
|
||||
;;
|
||||
esac
|
||||
[ -f ${PKG_NAME}/Makefile ] || [ -f ${PKG_NAME}/README* ] || [[ -n "$(ls -A ${PKG_NAME})" ]] && {
|
||||
[[ -f ${PKG_NAME}/Makefile || -f ${PKG_NAME}/README* || -n $(ls -A ${PKG_NAME}) ]] && {
|
||||
mv -f "${PKG_NAME}" "package/${PKG_DIR}"
|
||||
} || {
|
||||
TIME "[ERROR] Package [${PKG_NAME}] is not detected!"
|
||||
}
|
||||
unset PKG_PROTO PKG_DIR PKG_NAME REPO_URL REPO_BRANCH
|
||||
} || TIME "[ERROR] Package [${PKG_NAME}] is not detected!"
|
||||
}
|
||||
|
||||
Replace_File() {
|
||||
|
@ -432,16 +414,13 @@ Replace_File() {
|
|||
FILE_RENAME=$3
|
||||
|
||||
mkdir -p ${PATCH_DIR}
|
||||
[ -f "${GITHUB_WORKSPACE}/${FILE_NAME}" ] && _TYPE1="f" && _TYPE2="File"
|
||||
[ -d "${GITHUB_WORKSPACE}/${FILE_NAME}" ] && _TYPE1="d" && _TYPE2="Folder"
|
||||
[[ -f ${GITHUB_WORKSPACE}/${FILE_NAME} ]] && _TYPE1=f && _TYPE2=File
|
||||
[[ -d ${GITHUB_WORKSPACE}/${FILE_NAME} ]] && _TYPE1=d && _TYPE2=Folder
|
||||
[ -${_TYPE1} "${GITHUB_WORKSPACE}/${FILE_NAME}" ] && {
|
||||
[[ -n "${FILE_RENAME}" ]] && _RENAME="${FILE_RENAME}" || _RENAME=""
|
||||
[[ -n ${FILE_RENAME} ]] && _RENAME="${FILE_RENAME}" || _RENAME=""
|
||||
[ -${_TYPE1} "${GITHUB_WORKSPACE}/${FILE_NAME}" ] && {
|
||||
TIME "Moving [${_TYPE2}] ${FILE_NAME} to $2/${FILE_RENAME} ..."
|
||||
mv -f "${GITHUB_WORKSPACE}/${FILE_NAME}" "${PATCH_DIR}/${_RENAME}"
|
||||
} || {
|
||||
TIME "CustomFiles ${_TYPE2} [${FILE_NAME}] is not detected !"
|
||||
}
|
||||
} || TIME "CustomFiles ${_TYPE2} [${FILE_NAME}] is not detected !"
|
||||
}
|
||||
unset FILE_NAME PATCH_DIR FILE_RENAME
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue