130 lines
4.5 KiB
Bash
130 lines
4.5 KiB
Bash
#!/usr/bin/zsh
|
|
|
|
# 路径名称: 公共/函数.zsh
|
|
# 脚本作用: 通用zsh函数合集 方便zsh脚本快速调用
|
|
# 第一作者: 寻觅(xunmiemail@vip.qq.com)
|
|
# 创建时间: 2024年2月4日23:24:12
|
|
# 使用方法: 在言灵根目录下使用`. 公共/函数.zsh`
|
|
|
|
|
|
# 启动言灵公共函数模块的标识符
|
|
言灵一函数=1
|
|
|
|
###############################################################################
|
|
# 终端配色 #
|
|
###############################################################################
|
|
|
|
# 色彩配置
|
|
readonly 色彩重置='\e[0m'
|
|
readonly 色彩=(
|
|
'\e[92m' # 1: 亮绿
|
|
'\e[90m' # 2: 亮灰
|
|
'\e[31m' # 3: 暗红
|
|
'\e[32m' # 4: 暗绿
|
|
'\e[33m' # 5: 暗黄
|
|
'\e[95m' # 6: 亮紫
|
|
)
|
|
|
|
# 用于规范输出的工具
|
|
# 例: `输出 0 "执行成功"`; `输出 3 "请及时更新依赖"`
|
|
# *-* 一 -> 整数 <- 1: 成功(亮绿); 2: 失败(暗红); 3: 信息(绿色); 4: 通知(黄色); 5: 异常(紫色)
|
|
# *-* 二 -> 字符 <- 在命令行输出的字符串
|
|
输出() {
|
|
echo -n "($(date +"%Y-%m-%d %H:%M:%S"))"
|
|
if (($1 == 0)); then
|
|
echo -e "${色彩[2]}[${色彩重置}${色彩[1]} 成功 ${色彩重置}${色彩[2]}]${色彩重置} $2"
|
|
elif (($1 == 1)); then
|
|
echo -e "${色彩[2]}[${色彩重置}${色彩[3]} 失败 ${色彩重置}${色彩[2]}]${色彩重置} $2"
|
|
exit 1
|
|
elif (($1 == 2)); then
|
|
echo -e "${色彩[2]}[${色彩重置}${色彩[4]} 信息 ${色彩重置}${色彩[2]}]${色彩重置} $2"
|
|
elif (($1 == 3)); then
|
|
echo -e "${色彩[2]}[${色彩重置}${色彩[5]} 通知 ${色彩重置}${色彩[2]}]${色彩重置} $2"
|
|
elif (($1 == 4)); then
|
|
echo -e "${色彩[2]}[${色彩重置}${色彩[6]} 异常 ${色彩重置}${色彩[2]}]${色彩重置} $2"
|
|
return 1
|
|
fi
|
|
}
|
|
|
|
# 灰色信息(处理一些无关紧要的信息, 调用后在没有清除颜色之前会一直使用灰色输出)
|
|
色彩一灰色() {
|
|
echo -e "${色彩[2]}\c"
|
|
}
|
|
|
|
# 清除颜色(一般和灰色信息连用)
|
|
色彩一清除() {
|
|
echo -e "${色彩重置}\c"
|
|
}
|
|
|
|
###############################################################################
|
|
# 通用函数 #
|
|
###############################################################################
|
|
|
|
# 更具用户输入判断是否需要继续
|
|
# *-* 一 -> 字符 <- 用于提示用户选择时候的提示语
|
|
# -*- 返回值: 如果 输入`是/Y/y/yes` 返会0, 其他情况返会1
|
|
是否() {
|
|
输出 3 "$1((是/否 Yes/No))"
|
|
read r
|
|
if echo "$r" | grep -Eq "^[是Yy][Ee]?[Ss]?$";then
|
|
return 0
|
|
fi
|
|
return 1
|
|
}
|
|
|
|
# 用于判断两个版本号之间的大小
|
|
# 备注: 版本格式实例 1.0.0, v8.8, go1.20.8
|
|
# 例: `版本对比 "$1" "$2" && echo "1: $1" || echo "2: $2"`
|
|
# *-* 一 -> 字符(版本1) <- 建议为本地版本
|
|
# *-* 二 -> 字符(版本2) <- 建议为需要对比的版本
|
|
# -*- 返回值: 如果 版本1 >= 版本2 则返会1, 否者返会0, 根据建议填写参数效果则是本地如果是最新版则不会进入if判断
|
|
版本对比() {
|
|
# 判断版本是否为空
|
|
if [ -z "${1// }" ]; then
|
|
return 0
|
|
elif [ -z "${2// }" ]; then
|
|
return 1
|
|
fi
|
|
# 使用IFS分割版本号为数组
|
|
IFS='.' read -r -A 版本数组A <<< ${1//[^0-9.]/}
|
|
IFS='.' read -r -A 版本数组B <<< ${2//[^0-9.]/}
|
|
# 逐段比较各个部分的大小
|
|
for ((i=1; i <= ${#版本数组A[@]}; i++)); do
|
|
if (( ${版本数组A[i]} > ${版本数组B[i]} )); then
|
|
return 1
|
|
elif (( ${版本数组A[i]} < ${版本数组B[i]} )); then
|
|
return 0
|
|
fi
|
|
done
|
|
# 如果循环结束仍未返回,则认为两个版本号相等
|
|
return 1
|
|
}
|
|
|
|
# 自动根据文件后缀选择响应的解压工具进行就地解压
|
|
# *-* 一 -> 字符(文件名) <- 压缩文件
|
|
解压(){
|
|
文件名=$1
|
|
后缀="${文件名##*.}"
|
|
if [[ ${文件名} == *".tar."* ]]; then
|
|
后缀="tar.${后缀}"
|
|
fi
|
|
# 根据后缀选择解压命令
|
|
case ${后缀} in
|
|
"tar.gz" | "tgz") tar -xzvf ${文件名} ;;
|
|
"tar.xz") tar -xJvf ${文件名} ;;
|
|
"tar.bz2" | "tbz2") tar -xjvf ${文件名} ;;
|
|
"zip") unzip ${文件名} ;;
|
|
"rar") unrar x ${文件名} ;;
|
|
"7z") 7z x ${文件名} ;;
|
|
*) 输出 5 "不支持的压缩格式" ;;
|
|
esac
|
|
}
|
|
|
|
# 自动获取并且解压压缩包
|
|
# *-* 一 -> 字符(网址) <- 在线获取压缩包的地址
|
|
获解(){
|
|
wget -t 3 --content-disposition -q --show-progress -c $1 || 输出 5 "无法下载程序包"
|
|
包名="$(ls -t | head -n1)"
|
|
输出 2 "已获取${包名}"
|
|
解压 ${包名}
|
|
} |