x/公共/函数.zsh

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 "已获取${包名}"
解压 ${包名}
}