Skip to content

Commit

Permalink
Fix install.sh to make it runnable
Browse files Browse the repository at this point in the history
[GitHub #98 #104]
  • Loading branch information
ccmywish committed Oct 25, 2024
1 parent 15c0ae6 commit c6a0801
Showing 1 changed file with 25 additions and 25 deletions.
50 changes: 25 additions & 25 deletions tool/install.sh
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ noroot_default_install_path="$HOME/.local/bin"
binary_name="chsrc"
temp_install_dir="" # 用于存储临时安装目录
helpflag=0
lan="zh"
lang="zh"

# 输出相关信息
info() {
Expand All @@ -35,7 +35,7 @@ error() {

# 显示 chsrc 安装程序的帮助信息,包括使用说明和可用选项
help() {
if [ "$lan" = "zh" ]; then
if [ "$lang" = "zh" ]; then
echo "chsrc-installer: 在任何类Unix操作系统上安装 chsrc"
echo
echo "使用: install.sh [选项]"
Expand All @@ -58,7 +58,7 @@ help() {
fi
}

# 确定下载路径

set_install_path() {
if [ -n "$install_dir" ]; then
# 扩展 ~ 符号
Expand All @@ -67,14 +67,14 @@ set_install_path() {
# 检查路径是否存在,如果不存在则创建该路径
if [ ! -d "$install_dir" ]; then
# 多种语言输出
if [ "$lan" = "zh" ]; then
if [ "$lang" = "zh" ]; then
echo "目录 $install_dir 不存在,正在创建..."
else
echo "Directory $install_dir does not exist. Creating..."
fi
# 多语言输出
if ! mkdir -p "$install_dir"; then
if [ "$lan" = "zh" ]; then
if [ "$lang" = "zh" ]; then
echo "创建目录失败,请重试"
else
echo "Failed to create directory, please try again"
Expand All @@ -87,7 +87,7 @@ set_install_path() {

elif existing_path=$(command -v "$binary_name" 2>/dev/null); then

if [ "$lan" = "zh"]; then
if [ "$lang" = "zh" ]; then
info "$binary_name 已安装,更新路径: ${existing_path}"
else
info "$binary_name is already installed, updating path: ${existing_path}"
Expand All @@ -98,20 +98,19 @@ set_install_path() {
# 检查默认路径
if [ -d "$default_install_path" ] && [ -w "$default_install_path" ]; then
install_dir="$default_install_path"
else if [ -d "$noroot_default_install_path" ] && [ -w "$noroot_default_install_path" ]; then
elif [ -d "$noroot_default_install_path" ] && [ -w "$noroot_default_install_path" ]; then
install_dir="$noroot_default_install_path"
else
if [ "$lan" = "zh"]; then
if [ "$lang" = "zh"]; then
error "默认下载路径 /usr/local/bin 不可写,请使用 sudo 命令运行脚本;或通过 -d 参数指定其它路径安装"
else
error "Default download path /usr/local/bin is not writable. Please run the script with sudo; or specify another path using the -d option."
fi

fi
fi
}

# 从Gitee仓库安装 指定架构,操作系统,版本 的chsrc二进制文件

install() {
arch="$(uname -m | tr '[:upper:]' '[:lower:]')"

Expand All @@ -120,8 +119,8 @@ install() {
aarch64|arm64) arch="aarch64" ;;
riscv64) arch="riscv64" ;;
armv7*) arch="armv7" ;;
*)
if [ "$lan" = "zh" ]; then
*)
if [ "$lang" = "zh" ]; then
error "不支持的架构: ${arch}"
else
error "Unsupported architecture: ${arch}"
Expand All @@ -134,9 +133,9 @@ install() {
case "$platform" in
linux) platform="linux" ;;
darwin) platform="macos" ;;
*)
if [ "$lan" = "zh" ]; then
error "不支持的平台: ${platform}"
*)
if [ "$lang" = "zh" ]; then
error "不支持的平台: ${platform}"
else
error "Unsupported platform: ${platform}"
fi
Expand All @@ -145,7 +144,7 @@ install() {

if [[ ! "$version" =~ ^(pre|0\.1\.([4-9]))$ ]]; then
# version 不符合条件,报错
if [ "$lan" = "zh" ]; then
if [ "$lang" = "zh" ]; then
error "不支持的版本: ${version},版本号必须在 0.1.4 到 0.1.9 之间或为 'pre'"
else
error "Unsupported version: ${version}. Version number must be between 0.1.4 and 0.1.9 or 'pre'"
Expand All @@ -155,8 +154,8 @@ install() {
url="https://gitee.com/RubyMetric/chsrc/releases/download/${version}/${binary_name}-${arch}-${platform}"

path_to_executable="${install_dir}/${binary_name}"
if [ "$lan" = "zh" ]; then

if [ "$lang" = "zh" ]; then
info "下载 ${binary_name} (${arch} 架构, ${platform} 平台, ${version}版本) 到 ${path_to_executable}"
else
info "Downloading ${binary_name} (${arch} architecture, ${platform} platform, version ${version}) to ${path_to_executable}"
Expand All @@ -165,14 +164,14 @@ install() {
if curl -sL "$url" -o "$path_to_executable"; then
chmod +x "$path_to_executable"

if [ "$lan" = "zh" ]; then
if [ "$lang" = "zh" ]; then
info "🎉 安装完成,版本: $version,路径: $path_to_executable"
else
info "🎉 Installation completed, path: $path_to_executable"
fi

else
if [ "$lan" = "zh" ]; then
if [ "$lang" = "zh" ]; then
error "下载失败,请检查您的网络连接和代理设置: ${url}"
else
error "Download failed, please check your network connection and proxy settings: ${url}"
Expand All @@ -185,7 +184,7 @@ install() {
cleanup() {
if [ -n "$temp_install_dir" ] && [ -d "$temp_install_dir" ]; then

if [ "$lan" = "zh" ]; then
if [ "$lang" = "zh" ]; then
echo "清理创建的目录: $temp_install_dir"
else
echo "Cleaning up created directory: $temp_install_dir"
Expand All @@ -197,6 +196,7 @@ cleanup() {
# 设置 trap 以捕获退出信号
trap cleanup EXIT


# 从命令行读取 安装路径与版本号
while getopts ":hd:v:l:" option; do
case $option in
Expand All @@ -210,7 +210,7 @@ while getopts ":hd:v:l:" option; do
version=${OPTARG}
;;
l)
lan=${OPTARG}
lang=${OPTARG}
;;
\?)
echo "无效的命令行选项,请使用 -h 查看帮助"
Expand All @@ -220,8 +220,8 @@ while getopts ":hd:v:l:" option; do
done

# 判断语言的类型,不符合直接退出
if [[ "$lan" != "zh" && "$lan" != "en" ]]; then
error "无效的语言选项: $lan。支持的选项是 zh 和 en"
if [[ "$lang" != "zh" && "$lang" != "en" ]]; then
error "无效的语言选项: $lang,支持的选项为 zh 和 en"
fi

if [ "$helpflag" -eq 1 ]; then
Expand All @@ -230,4 +230,4 @@ if [ "$helpflag" -eq 1 ]; then
fi

set_install_path
install
install

0 comments on commit c6a0801

Please sign in to comment.