优化路径、变量调用
This commit is contained in:
parent
3904c207ee
commit
a16d3f1dc1
|
@ -16,15 +16,30 @@ Diy_Core() {
|
|||
}
|
||||
|
||||
Firmware-Diy() {
|
||||
# 部分可调用变量如下
|
||||
# OP_Maintainer 源码作者
|
||||
# OP_REPO_NAME 仓库名称
|
||||
# OP_BRANCH 源码分支
|
||||
# TARGET_PROFILE 设备名称
|
||||
# TARGET_BOARD 设备架构
|
||||
# CustomFiles 仓库 /CustomFiles 路径
|
||||
# Scripts 仓库 /Scripts 路径
|
||||
# Home 源码存放位置,等同 ${GITHUB_WORKSPACE}/openwrt
|
||||
# feeds_luci 等同 ${GITHUB_WORKSPACE}/openwrt/package/feeds/luci
|
||||
# feeds_pkgs 等同 ${GITHUB_WORKSPACE}/openwrt/package/feeds/packages
|
||||
# base_files 等同 ${GITHUB_WORKSPACE}/openwrt/package/base-files/files
|
||||
|
||||
case "${TARGET_PROFILE}" in
|
||||
d-team_newifi-d2)
|
||||
Copy CustomFiles/mac80211.sh package/kernel/mac80211/files/lib/wifi
|
||||
Copy CustomFiles/system_${TARGET_PROFILE} package/base-files/files/etc/config system
|
||||
patch -i ${CustomFiles}/mac80211_d-team_newifi-d2.patch package/kernel/mac80211/files/lib/wifi/mac80211.sh
|
||||
Copy ${CustomFiles}/system_d-team_newifi-d2 ${base_files}/etc/config system
|
||||
;;
|
||||
esac
|
||||
case "${OP_Maintainer}/${OP_REPO_NAME}:${OP_BRANCH}" in
|
||||
coolsnowwolf/lede:master)
|
||||
sed -i "s?/bin/login?/usr/libexec/login.sh?g" package/feeds/packages/ttyd/files/ttyd.config
|
||||
sed -i "s?/bin/login?/usr/libexec/login.sh?g" ${feeds_pkgs}/ttyd/files/ttyd.config
|
||||
sed -i "/dns_caching_dns/d" $(PKG_Finder d package luci-app-turboacc)/root/etc/config/turboacc
|
||||
echo " option dns_caching_dns '223.5.5.5,114.114.114.114'" >> $(PKG_Finder d package luci-app-turboacc)/root/etc/config/turboacc
|
||||
;;
|
||||
esac
|
||||
}
|
|
@ -26,7 +26,7 @@ Firmware-Diy_Before() {
|
|||
CURRENT_Version="${zzz_Default_Version}-${Compile_Date}"
|
||||
;;
|
||||
immortalwrt)
|
||||
Version_File=package/base-files/files/etc/openwrt_release
|
||||
Version_File=${base_files}/etc/openwrt_release
|
||||
CURRENT_Version="${Openwrt_Version_Head}${Compile_Date}"
|
||||
;;
|
||||
*)
|
||||
|
@ -67,7 +67,7 @@ Firmware-Diy_Before() {
|
|||
REGEX_Firmware='AutoBuild-${OP_REPO_NAME}-${TARGET_PROFILE}-R[0-9.]+-[0-9]+-[0-9a-z]+.${Firmware_Type}'
|
||||
;;
|
||||
esac
|
||||
cat >> VARIABLE_Main <<EOF
|
||||
cat >> ${Home}/VARIABLE_Main <<EOF
|
||||
Author=${Author}
|
||||
Github=${Author_Repository}
|
||||
TARGET_PROFILE=${TARGET_PROFILE}
|
||||
|
@ -80,34 +80,40 @@ OP_BRANCH=${OP_BRANCH}
|
|||
OP_REPO_NAME=${OP_REPO_NAME}
|
||||
REGEX_Firmware=${REGEX_Firmware}
|
||||
EOF
|
||||
cat >> VARIABLE_FILE <<EOF
|
||||
cat >> ${Home}/VARIABLE_FILE <<EOF
|
||||
Home=${Home}
|
||||
PKG_Compatible=${INCLUDE_Obsolete_PKG_Compatible}
|
||||
Checkout_Virtual_Images=${Checkout_Virtual_Images}
|
||||
Firmware_Path=${Home}/bin/targets/${TARGET_BOARD}/${TARGET_SUBTARGET}
|
||||
AutoBuild_Firmware=${AutoBuild_Firmware}
|
||||
CustomFiles=${GITHUB_WORKSPACE}/CustomFiles
|
||||
Scripts=${GITHUB_WORKSPACE}/Scripts
|
||||
feeds_luci=${GITHUB_WORKSPACE}/openwrt/package/feeds/luci
|
||||
feeds_pkgs=${GITHUB_WORKSPACE}/openwrt/package/feeds/packages
|
||||
base_files=${GITHUB_WORKSPACE}/openwrt/package/base-files/files
|
||||
EOF
|
||||
echo "$(cat VARIABLE_Main)" >> VARIABLE_FILE
|
||||
echo -e "### SYS-VARIABLE LIST ###\n$(cat VARIABLE_FILE)\n"
|
||||
echo "$(cat ${Home}/VARIABLE_Main)" >> ${Home}/VARIABLE_FILE
|
||||
echo -e "### SYS-VARIABLE LIST ###\n$(cat ${Home}/VARIABLE_FILE)\n"
|
||||
}
|
||||
|
||||
Firmware-Diy_Main() {
|
||||
Firmware-Diy_Before
|
||||
TIME "[Firmware-Diy_Main]"
|
||||
mkdir -p package/base-files/files/etc/AutoBuild
|
||||
[ -f VARIABLE_Main ] && cp VARIABLE_Main package/base-files/files/etc/AutoBuild/Default_Variable
|
||||
Copy CustomFiles/Depends/Custom_Variable package/base-files/files/etc/AutoBuild
|
||||
chmod +x -R ${GITHUB_WORKSPACE}/Scripts
|
||||
chmod 777 -R ${GITHUB_WORKSPACE}/CustomFiles
|
||||
source ${GITHUB_WORKSPACE}/openwrt/VARIABLE_FILE
|
||||
mkdir -p ${base_files}/etc/AutoBuild
|
||||
[ -f ${GITHUB_WORKSPACE}/openwrt/VARIABLE_Main ] && cp VARIABLE_Main ${base_files}/etc/AutoBuild/Default_Variable
|
||||
Copy ${CustomFiles}/Depends/Custom_Variable ${base_files}/etc/AutoBuild
|
||||
chmod +x -R ${Scripts}
|
||||
chmod 777 -R ${CustomFiles}
|
||||
[[ ${Load_CustomPackages_List} == true ]] && {
|
||||
bash -n ${GITHUB_WORKSPACE}/Scripts/AutoBuild_ExtraPackages.sh
|
||||
bash -n ${Scripts}/AutoBuild_ExtraPackages.sh
|
||||
[[ ! $? == 0 ]] && TIME "AutoBuild_ExtraPackages.sh syntax error,skip ..." || {
|
||||
. ${GITHUB_WORKSPACE}/Scripts/AutoBuild_ExtraPackages.sh
|
||||
. ${Scripts}/AutoBuild_ExtraPackages.sh
|
||||
}
|
||||
}
|
||||
[[ ${INCLUDE_AutoBuild_Features} == true ]] && {
|
||||
Copy Scripts/AutoBuild_Tools.sh package/base-files/files/bin
|
||||
Copy Scripts/AutoUpdate.sh package/base-files/files/bin
|
||||
Copy ${Scripts}/AutoBuild_Tools.sh ${base_files}/bin
|
||||
Copy ${Scripts}/AutoUpdate.sh ${base_files}/bin
|
||||
AddPackage git lean luci-app-autoupdate Hyy2001X main
|
||||
}
|
||||
[[ ${INCLUDE_Argon} == true ]] && {
|
||||
|
@ -141,27 +147,25 @@ Firmware-Diy_Main() {
|
|||
}
|
||||
[[ -n ${Before_IP_Address} ]] && Default_LAN_IP="${Before_IP_Address}"
|
||||
[[ -n ${Default_LAN_IP} && ${Default_LAN_IP} =~ ^[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}$ ]] && {
|
||||
Old_IP_Address=$(awk -F '[="]+' '/ipaddr:-/{print $3}' package/base-files/files/bin/config_generate | awk 'NR==1')
|
||||
Old_IP_Address=$(awk -F '[="]+' '/ipaddr:-/{print $3}' ${base_files}/bin/config_generate | awk 'NR==1')
|
||||
if [[ ! ${Default_LAN_IP} == ${Old_IP_Address} ]];then
|
||||
TIME "Setting default IP Address to ${Default_LAN_IP} ..."
|
||||
sed -i "s/${Old_IP_Address}/${Default_LAN_IP}/g" package/base-files/files/bin/config_generate
|
||||
sed -i "s/${Old_IP_Address}/${Default_LAN_IP}/g" ${base_files}/bin/config_generate
|
||||
fi
|
||||
}
|
||||
[[ ${INCLUDE_DRM_I915} == true && ${TARGET_BOARD} == x86 ]] && {
|
||||
Copy CustomFiles/Depends/DRM-I915 target/linux/x86
|
||||
Copy ${CustomFiles}/Depends/DRM-I915 target/linux/x86
|
||||
for X in $(ls -1 target/linux/x86 | grep "config-"); do echo -e "\n$(cat target/linux/x86/DRM-I915)" >> target/linux/x86/${X}; done
|
||||
}
|
||||
[ -f package/base-files/files/bin/AutoUpdate.sh ] && {
|
||||
AutoUpdate_Version=$(egrep -o "V[0-9].+" package/base-files/files/bin/AutoUpdate.sh | awk 'END{print}')
|
||||
[ -f ${base_files}/bin/AutoUpdate.sh ] && {
|
||||
AutoUpdate_Version=$(egrep -o "V[0-9].+" ${base_files}/bin/AutoUpdate.sh | awk 'END{print}')
|
||||
} || AutoUpdate_Version=OFF
|
||||
Copy CustomFiles/Depends/profile package/base-files/files/etc
|
||||
Copy CustomFiles/Depends/base-files-essential package/base-files/files/lib/upgrade/keep.d
|
||||
Copy ${CustomFiles}/Depends/profile ${base_files}/etc
|
||||
Copy ${CustomFiles}/Depends/base-files-essential ${base_files}/lib/upgrade/keep.d
|
||||
case "${OP_Maintainer}" in
|
||||
coolsnowwolf)
|
||||
sed -i "/dns_caching_dns/d" $(PKG_Finder d package luci-app-turboacc)/root/etc/config/turboacc
|
||||
echo " option dns_caching_dns '223.5.5.5,114.114.114.114'" >> $(PKG_Finder d package luci-app-turboacc)/root/etc/config/turboacc
|
||||
Copy CustomFiles/Depends/coremark.sh $(PKG_Finder d "package feeds" coremark)
|
||||
Copy CustomFiles/Depends/cpuinfo_x86 $(PKG_Finder d package autocore | awk 'NR==1')/files/x86/sbin cpuinfo
|
||||
Copy ${CustomFiles}/Depends/coremark.sh $(PKG_Finder d "package feeds" coremark)
|
||||
Copy ${CustomFiles}/Depends/cpuinfo_x86 $(PKG_Finder d package autocore | awk 'NR==1')/files/x86/sbin cpuinfo
|
||||
AddPackage git other helloworld fw876 master
|
||||
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}
|
||||
|
@ -170,21 +174,21 @@ Firmware-Diy_Main() {
|
|||
immortalwrt)
|
||||
sed -i "/dns_caching_dns/d" $(PKG_Finder d "package feeds" luci-app-turboacc)/root/etc/config/turboacc
|
||||
echo " option dns_caching_dns '223.5.5.5,114.114.114.114'" >> $(PKG_Finder d "package feeds" luci-app-turboacc)/root/etc/config/turboacc
|
||||
Copy CustomFiles/Depends/openwrt_release_${OP_Maintainer} package/base-files/files/etc openwrt_release
|
||||
Copy CustomFiles/Depends/cpuinfo_x86 $(PKG_Finder d package autocore | awk 'NR==1')/files/x86/sbin cpuinfo
|
||||
Copy ${CustomFiles}/Depends/openwrt_release_${OP_Maintainer} ${base_files}/etc openwrt_release
|
||||
Copy ${CustomFiles}/Depends/cpuinfo_x86 $(PKG_Finder d package autocore | awk 'NR==1')/files/x86/sbin cpuinfo
|
||||
sed -i "s?ImmortalWrt?ImmortalWrt @ ${Author} [${Display_Date}]?g" ${Version_File}
|
||||
;;
|
||||
esac
|
||||
case "${OP_Maintainer}" in
|
||||
immortalwrt)
|
||||
Copy CustomFiles/Depends/banner $(PKG_Finder d package default-settings)/files openwrt_banner
|
||||
Copy ${CustomFiles}/Depends/banner $(PKG_Finder d package default-settings)/files openwrt_banner
|
||||
sed -i "s?By?By ${Author}?g" $(PKG_Finder d package default-settings)/files/openwrt_banner
|
||||
sed -i "s?Openwrt?Openwrt ${CURRENT_Version} / AutoUpdate ${AutoUpdate_Version}?g" $(PKG_Finder d package default-settings)/files/openwrt_banner
|
||||
;;
|
||||
*)
|
||||
Copy CustomFiles/Depends/banner package/base-files/files/etc
|
||||
sed -i "s?By?By ${Author}?g" package/base-files/files/etc/banner
|
||||
sed -i "s?Openwrt?Openwrt ${CURRENT_Version} / AutoUpdate ${AutoUpdate_Version}?g" package/base-files/files/etc/banner
|
||||
Copy ${CustomFiles}/Depends/banner ${base_files}/etc
|
||||
sed -i "s?By?By ${Author}?g" ${base_files}/etc/banner
|
||||
sed -i "s?Openwrt?Openwrt ${CURRENT_Version} / AutoUpdate ${AutoUpdate_Version}?g" ${base_files}/etc/banner
|
||||
;;
|
||||
esac
|
||||
TIME "[Firmware-Diy_Main] All done !"
|
||||
|
@ -192,7 +196,7 @@ Firmware-Diy_Main() {
|
|||
|
||||
Firmware-Diy_Other() {
|
||||
TIME "[Firmware-Diy_Other]"
|
||||
source ./VARIABLE_FILE
|
||||
source ${GITHUB_WORKSPACE}/openwrt/VARIABLE_FILE
|
||||
case "${PKG_Compatible}" in
|
||||
19.07)
|
||||
OP_BRANCH=19.07
|
||||
|
@ -211,12 +215,11 @@ Firmware-Diy_Other() {
|
|||
case "${OP_BRANCH}" in
|
||||
19.07 | 21.02 | main)
|
||||
[[ ${OP_BRANCH} == main ]] && OP_BRANCH=21.02
|
||||
Copy CustomFiles/Patches/0003-upx-ucl-${OP_BRANCH}.patch ./
|
||||
Copy ${CustomFiles}/Patches/0003-upx-ucl-${OP_BRANCH}.patch ./
|
||||
cat 0003-upx-ucl-${OP_BRANCH}.patch | patch -p1 > /dev/null 2>&1
|
||||
# AddPackage svn feeds/packages golang coolsnowwolf/packages/trunk/lang
|
||||
TIME "Starting to convert zh-cn translation files to zh_Hans ..."
|
||||
Copy Scripts/Convert_Translation.sh package
|
||||
cd ./package && bash ./Convert_Translation.sh && cd ..
|
||||
cd package && ${Scripts}/Convert_Translation.sh && cd -
|
||||
;;
|
||||
*)
|
||||
TIME "Current branch: [${OP_BRANCH}] is not supported,skip..."
|
||||
|
@ -238,7 +241,7 @@ Firmware-Diy_Other() {
|
|||
|
||||
Firmware-Diy_End() {
|
||||
TIME "[Firmware-Diy_End]"
|
||||
source ./VARIABLE_FILE
|
||||
source ${GITHUB_WORKSPACE}/openwrt/VARIABLE_FILE
|
||||
mkdir -p bin/Firmware
|
||||
sha256sums="${Firmware_Path}/sha256sums"
|
||||
cd ${Firmware_Path}
|
||||
|
@ -317,15 +320,13 @@ Get_sha256() {
|
|||
}
|
||||
|
||||
Get_Variable() {
|
||||
grep "$1" ${Home}/VARIABLE_FILE | cut -c$(echo $1 | wc -c)-200 | cut -d ":" -f2
|
||||
grep "$1" ${GITHUB_WORKSPACE}/openwrt/VARIABLE_FILE | cut -c$(echo $1 | wc -c)-200 | cut -d ":" -f2
|
||||
}
|
||||
|
||||
Get_Branches() {
|
||||
Folder="$(pwd)"
|
||||
[[ -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
|
||||
git -C $(pwd) rev-parse --abbrev-ref HEAD | grep -v HEAD || \
|
||||
git -C $(pwd) describe --exact-match HEAD || \
|
||||
git -C $(pwd) rev-parse HEAD
|
||||
}
|
||||
|
||||
TIME() {
|
||||
|
@ -357,20 +358,21 @@ AddPackage() {
|
|||
;;
|
||||
esac
|
||||
PKG_DIR=$2
|
||||
[[ ! ${PKG_DIR} =~ ${GITHUB_WORKSPACE} ]] && PKG_DIR=package/${PKG_DIR}
|
||||
PKG_NAME=$3
|
||||
REPO_URL="https://github.com/$4"
|
||||
REPO_BRANCH=$5
|
||||
[[ ${REPO_URL} =~ "${OP_Maintainer}/${OP_REPO_NAME}" ]] && return 0
|
||||
|
||||
mkdir -p package/${PKG_DIR} || {
|
||||
TIME "Can't create download dir: [package/${PKG_DIR}]"
|
||||
mkdir -p ${PKG_DIR} || {
|
||||
TIME "Can't create download dir: [${PKG_DIR}] ..."
|
||||
return 0
|
||||
}
|
||||
[[ -d package/${PKG_DIR}/${PKG_NAME} ]] && {
|
||||
[[ -d ${PKG_DIR}/${PKG_NAME} ]] && {
|
||||
TIME "Removing old package: [${PKG_NAME}] ..."
|
||||
rm -rf package/${PKG_DIR}/${PKG_NAME}
|
||||
rm -rf ${PKG_DIR}/${PKG_NAME}
|
||||
}
|
||||
TIME "Checking out package [${PKG_NAME}] to package/${PKG_DIR} ..."
|
||||
TIME "Checking out package [${PKG_NAME}] to ${PKG_DIR} ..."
|
||||
case "${PKG_PROTO}" in
|
||||
git)
|
||||
[[ -z ${REPO_BRANCH} ]] && {
|
||||
|
@ -385,21 +387,26 @@ AddPackage() {
|
|||
;;
|
||||
esac
|
||||
[[ -f ${PKG_NAME}/Makefile || -n $(ls -A ${PKG_NAME}) ]] && {
|
||||
mv -f "${PKG_NAME}" "package/${PKG_DIR}"
|
||||
} || TIME "Package: ${PKG_NAME} failed to download"
|
||||
mv -f "${PKG_NAME}" "${PKG_DIR}"
|
||||
} || TIME "Failed to download package ${PKG_NAME} ..."
|
||||
}
|
||||
|
||||
Copy() {
|
||||
[[ $# -lt 2 ]] && {
|
||||
TIME "Error options: [$#] [$*] !"
|
||||
[[ ! $# =~ [23] ]] && {
|
||||
TIME "Error options: [$#] [$*]"
|
||||
return 0
|
||||
}
|
||||
[[ ! -f ${GITHUB_WORKSPACE}/$1 ]] && [[ ! -d ${GITHUB_WORKSPACE}/$1 ]] && {
|
||||
TIME "Unable to access CustomFiles/$1,skip ..."
|
||||
[[ ! -f $1 ]] && [[ ! -d $1 ]] && {
|
||||
TIME "$1: No such file or directory ..."
|
||||
return 0
|
||||
}
|
||||
[[ ! -d ${GITHUB_WORKSPACE}/openwrt/$2 ]] && mkdir -p "${GITHUB_WORKSPACE}/openwrt/$2"
|
||||
[[ -n $3 ]] && RENAME="$3" || RENAME=""
|
||||
TIME "Copying $1 to $2 ${RENAME} ..."
|
||||
cp -a "${GITHUB_WORKSPACE}/$1" "${GITHUB_WORKSPACE}/openwrt/$2/${RENAME}"
|
||||
[[ ! -d ${GITHUB_WORKSPACE}/openwrt/$2 ]] && mkdir -p ${GITHUB_WORKSPACE}/openwrt/$2
|
||||
|
||||
if [[ -z $3 ]];then
|
||||
TIME "Copying $1 to $2 ..."
|
||||
cp -a $1 ${GITHUB_WORKSPACE}/openwrt/$2
|
||||
else
|
||||
TIME "Copy and renaming $1 to $2/$3 ..."
|
||||
cp -a $1 ${GITHUB_WORKSPACE}/openwrt/$2/$3
|
||||
fi
|
||||
}
|
Loading…
Reference in New Issue