From ac24847591793da753e7ea79e76b8519b49c6d33 Mon Sep 17 00:00:00 2001 From: xunmi-pc <寻觅> Date: Wed, 21 Feb 2024 16:51:46 +0800 Subject: [PATCH] =?UTF-8?q?[=E6=96=B0=E5=A2=9E]=20=E6=96=B0=E5=A2=9Elsd?= =?UTF-8?q?=E5=AE=89=E8=A3=85=E6=A8=A1=E5=9D=97,=20=E4=BF=AE=E5=A4=8Doma?= =?UTF-8?q?=E5=AE=89=E8=A3=85=E8=BF=94=E5=9B=9E=E5=80=BC=E6=9C=AA=E6=8C=89?= =?UTF-8?q?=E9=A2=84=E6=9C=9F=E8=BF=9B=E8=A1=8C=E7=9A=84=E9=97=AE=E9=A2=98?= =?UTF-8?q?,=20=E4=BF=AE=E6=94=B9=E6=8E=A8=E8=8D=90=E5=AE=89=E8=A3=85?= =?UTF-8?q?=E6=96=B9=E5=BC=8F?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .gitnore | 5 ++ .测试.zsh.swp | Bin 0 -> 16384 bytes README.md | 2 +- 公共/包管.zsh | 3 + 安装.zsh | 41 ++++++++--- 测试.zsh | 188 ++++++++++++++++++++++++++++++++++++++++++++++++++ 6 files changed, 230 insertions(+), 9 deletions(-) create mode 100644 .gitnore create mode 100644 .测试.zsh.swp create mode 100755 测试.zsh diff --git a/.gitnore b/.gitnore new file mode 100644 index 0000000..a137a67 --- /dev/null +++ b/.gitnore @@ -0,0 +1,5 @@ + +测试.zsh +idea +.vscode + diff --git a/.测试.zsh.swp b/.测试.zsh.swp new file mode 100644 index 0000000000000000000000000000000000000000..44127d044b65683a728baa4e79285d760c497014 GIT binary patch literal 16384 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 literal 0 HcmV?d00001 diff --git a/README.md b/README.md index 7bd720b..bd713bf 100644 --- a/README.md +++ b/README.md @@ -2,7 +2,7 @@ 欢迎使用 言灵(effective language) 本工具用于在 `龙`(Loong) 架构和其他常用主机架构上的Linux系统中自动配置一个便捷好用的命令行, 使用zsh替代老旧的bash, 使用一些现代化的工具替代老旧工具集, 并且将部分命令添加汉化别名, 避免长时间未使用时遗忘命令 -本脚本主体使用zsh脚本实现, 如无zsh推荐使用 `wget -O- https://gitea.whlug.cn/xunmi/x/raw/start.sh | bash` 命令安装基础模块 +本脚本主体使用zsh脚本实现, 如无zsh推荐使用 `wget https://gitea.whlug.cn/xunmi/x/raw/start.sh && bash start.sh && rm start.sh` 命令安装基础模块 # 功能实现 diff --git a/公共/包管.zsh b/公共/包管.zsh index d50f8a3..96ceb5a 100644 --- a/公共/包管.zsh +++ b/公共/包管.zsh @@ -32,6 +32,9 @@ 包管_安装(){ [ -x "$(command -v $1)" ] && return 0 if [ -x "$(command -v oma)" ]; then + # 解决oma找不到软件包返回值还是0的问题, 先搜索一下软件包 + # 神奇的oma居然不走标准输出(2>&1, 将错误输出重定向到标准输出, 方便管道符处理), 坑人啊 + sudo oma search $1 2>&1 | head -n 1 | grep -q '\[完整匹配\]' || return 1 sudo oma install -y $1 elif [ -x "$(command -v apt)" ]; then sudo apt -y install $1 diff --git a/安装.zsh b/安装.zsh index 6652e45..59f1415 100755 --- a/安装.zsh +++ b/安装.zsh @@ -7,7 +7,7 @@ export DEBIAN_FRONTEND=noninteractive source /etc/os-release # 脚本在执行过程中遇到任何非零返回码的命令时立即退出 -set -e +# set -e ############################################################################### # 全局变量 # @@ -22,7 +22,7 @@ readonly 系统_版本="$(uname -r)" # ID_LIKE不为空,则输出ID_LIKE的值,否则输出ID的值 readonly 系统_发行版=$( ([ -n "${ID_LIKE}" ] && echo "${ID_LIKE}") || ([ -n "${ID}" ] && echo "${ID}")) readonly 系统_发行版_名称=$(echo "${NAME}") - +系统_发行版_标识="" # 龙架构区分新旧世界的标志位 世界_类型="新世界" @@ -63,7 +63,11 @@ readonly 系统_发行版_名称=$(echo "${NAME}") case ${系统_发行版} in *arch*) ;; *Loongnix*) ;; - *aosc*) ;; + *aosc*) + 系统_发行版_标识符="安同" + # 前三个是字体包 + 系统_包列表=('jetbrains-mono' 'powerline-fonts' 'fantasque-sans-mono-nerd-fonts') + ;; *openwrt*) 输出 1 "暂不支持openwrt" exit 1 @@ -89,7 +93,7 @@ readonly 系统_发行版_名称=$(echo "${NAME}") } 优化_常用命令_vim(){ - 输出 2 "启动vim优化" + 输出 2 "启动vim优化, 安装代码检查和树状目录插件, 并优化配置(具体配置可以查看 $HOME/.vimrc 文件)" vim_配置路径=$HOME/.vim/pack/xunmi typeset -a vim_包列表=('vim-airline') 批量安装 ${vim_包列表[@]} && 输出 0 "vim依赖包安装完毕" @@ -100,15 +104,37 @@ readonly 系统_发行版_名称=$(echo "${NAME}") git clone --depth 1 https://gitcode.com/mirrors/scrooloose/nerdtree.git ${vim_配置路径}/start/树状目录 # 代码检查工具 git clone --depth 1 https://gitcode.com/mirrors/dense-analysis/ale.git ${vim_配置路径}/start/代码检查工具 - cp -v 配置/vimrc $HOME/.vimrc + cp -v ${目录_根}/配置/vimrc $HOME/.vimrc 色彩_清除 } +优化_常用命令_ls(){ + 输出 2 "启动ls优化, lsd是rust编写的兼容ls的目录查看工具, 其丰富的配色和图标可有效增加目录的可读性" + 色彩_灰色 + if ! 包管_安装 "lsd"; then + 是否 "在系统源中未发现lsd, 是否使用cargo安装(需要rust语言, 如系统没有则会自动安装)" || return 201 + # todo: 需要判断龙芯旧世界, 旧世界安装的cargo版本过低, 需要从官网下载安装 + if ! 包管_安装 "cargo"; then + 输出 3 "ls优化失败, 未找到cargo, 请手动安装rust语言及其cargo包管理器后重试" + return 202 + fi + cargo install "lsd" + fi + sudo ln -vs $HOME/.cargo/bin/lsd /usr/bin/lsd + 色彩_清除 + if 是否 "将lsd使用别名的方式替代ls"; then + 别名='alias ls="lsd"' + grep -q "${别名}" "$HOME/.zshrc" || echo ${别名} >> $HOME/.zshrc + fi + 输出 0 "ls优化完成" + +} + 优化_常用命令(){ typeset -A 列表=( ["vim"]="添加常用配置项(允许复制 添加行号 显式当前行等), 常用插件(目录 语法检测)" - ["ls"]="使用lsd替代老旧的ls, 需要rust的cargo" - ["top"]="使用btop替代老旧的top" + ["ls"]="使用lsd替代老旧的ls, 需要rust的cargo" + ["top"]="使用xmtop替代老旧的top" ["cat"]="使用bat替代cat" ["sed"]="使用学习成本较低的sd替代sed" ) @@ -147,7 +173,6 @@ echo " if [ ! -f "公共/函数.zsh" ]; then source $HOME/.config/xunmi/* 目录_根=${寻觅}/x - cd ${寻觅} || exit 1 fi echo "执行目录: ${目录_根}" diff --git a/测试.zsh b/测试.zsh new file mode 100755 index 0000000..690c482 --- /dev/null +++ b/测试.zsh @@ -0,0 +1,188 @@ +#!/usr/bin/zsh + +export PATH=/usr/sbin:$PATH +# 让apt包管理器处于非交互模式运行 +export DEBIAN_FRONTEND=noninteractive +# 加载系统配置 +source /etc/os-release + +# 脚本在执行过程中遇到任何非零返回码的命令时立即退出 +# set -e + +############################################################################### +# 全局变量 # +############################################################################### + +typeset -a 通用_包列表=('wget' 'curl' 'git' 'vim' 'sudo') +typeset -a 架构_包列表=() +typeset -a 系统_包列表=() +readonly CPU_架构="$(uname -m)" +readonly 系统_类型="$(uname -s)" +readonly 系统_版本="$(uname -r)" +# ID_LIKE不为空,则输出ID_LIKE的值,否则输出ID的值 +readonly 系统_发行版=$( ([ -n "${ID_LIKE}" ] && echo "${ID_LIKE}") || ([ -n "${ID}" ] && echo "${ID}")) +readonly 系统_发行版_名称=$(echo "${NAME}") + +# 龙架构区分新旧世界的标志位 +世界_类型="新世界" + +############################################################################### +# 函数/方法 # +############################################################################### + +# 调用包管理器批量安装 +批量安装(){ + typeset -a 包列表=($@) + 输出 2 "计划安装列表: ${包列表}" + for 包 in "${包列表[@]}";do + 输出 2 "正在安装 -> ${包} <-" + 色彩_灰色 + 包管_安装 ${包} + 色彩_清除 + done +} + +检查_架构() { + case ${CPU_架构} in + *x86_64*) + 主机_架构="amd64" + ;; + *loong*) + 主机_架构="龙" + ;; + *) + 输出 1 "暂不支持${色彩[3]} ${CPU_架构} ${色彩重置}架构" + exit 1 + ;; + esac + 输出 2 "检测到${色彩[1]} ${主机_架构} ${色彩重置}架构" +} + +检查_发行版() { + 未知=0 + case ${系统_发行版} in + *arch*) ;; + *Loongnix*) ;; + *aosc*) ;; + *openwrt*) + 输出 1 "暂不支持openwrt" + exit 1 + ;; + *) + 未知=1 + ;; + esac + 输出 2 "检测到 ${系统_发行版_名称} (${系统_发行版}) 系统" + if [[ ${未知} == 1 ]]; then + if ! 是否 "此发行版尚未验证, 是否尝试继续安装"; then + 输出 1 "已退出安装" + exit 1 + fi + fi +} + +配置检测(){ + 输出 2 "主机信息检测模块启动" + 检查_架构 + 检查_发行版 + 输出 0 "主机信息检测完毕" +} + +优化_常用命令_vim(){ + 输出 2 "启动vim优化, 安装代码检查和树状目录插件, 并优化配置(具体配置可以查看 $HOME/.vimrc 文件)" + vim_配置路径=$HOME/.vim/pack/xunmi + typeset -a vim_包列表=('vim-airline') + 批量安装 ${vim_包列表[@]} && 输出 0 "vim依赖包安装完毕" + 色彩_灰色 + rm -vrf ${vim_配置路径} + mkdir -vp ${vim_配置路径}/{opt,start} + # 树状目录 + git clone --depth 1 https://gitcode.com/mirrors/scrooloose/nerdtree.git ${vim_配置路径}/start/树状目录 + # 代码检查工具 + git clone --depth 1 https://gitcode.com/mirrors/dense-analysis/ale.git ${vim_配置路径}/start/代码检查工具 + cp -v ${目录_根}/配置/vimrc $HOME/.vimrc + 色彩_清除 + 输出 0 "vim优化完成" +} + +优化_常用命令_ls(){ + 输出 2 "启动ls优化, lsd是rust编写的兼容ls的目录查看工具, 其丰富的配色和图标可有效增加目录的可读性" + 色彩_灰色 + if ! 包管_安装 "lsd"; then + 是否 "在系统源中未发现lsd, 是否使用cargo安装(需要rust语言, 如系统没有则会自动安装)" || return 201 + # todo: 需要判断龙芯旧世界, 旧世界安装的cargo版本过低, 需要从官网下载安装 + if ! 包管_安装 "cargo"; then + 输出 3 "ls优化失败, 未找到cargo, 请手动安装rust语言及其cargo包管理器后重试" + return 202 + fi + cargo install "lsd" + fi + sudo ln -vs $HOME/.cargo/bin/lsd /usr/bin/lsd + 色彩_清除 + if 是否 "将lsd使用别名的方式替代ls"; then + 别名='alias ls="lsd"' + grep -q "${别名}" "$HOME/.zshrc" || echo ${别名} >> $HOME/.zshrc + fi + 输出 0 "ls优化完成" +} + +优化_常用命令(){ + typeset -A 列表=( + ["vim"]="添加常用配置项(允许复制 添加行号 显式当前行等), 常用插件(目录 语法检测)" + ["ls"]="使用lsd替代老旧的ls, 需要rust的cargo" + ["top"]="使用xmtop替代老旧的top" + ["cat"]="使用bat替代cat" + ["sed"]="使用学习成本较低的sd替代sed" + ) + 输出 2 "正在优化 ${(k)列表} 命令" + # 遍历关联数组 + for 键 值 in ${(kv)列表}; do + if 是否 "是否启动 '${键}' 命令优化 -> ${值} <- "; then + 优化_常用命令_${键} + else + 输出 3 "已取消 ${键} 的优化" + fi + done +} + +选配(){ + if 是否 "将Zsh设置为默认命令行"; then + chsh -s /usr/bin/zsh + 输出 0 "已将zsh设置为默认命令行,此设置主要适用于ssh和tty,如终端不生效则需要在可视化设置中手动配置启动时加载 '/usr/bin/zsh' " + else + 输出 2 "如需将zsh设置为默认命令行请执行: 'chsh -s /usr/bin/zsh' " + fi +} + + +############################################################################### +# 主函数(main) # +############################################################################### + +echo " +*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-* +* 欢迎使用 言灵 配置脚本 * +*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-* +" +目录_根=$PWD +# 判断当前执行的位置 如果不再项目路径中就去寻找路径 +if [ ! -f "公共/函数.zsh" ]; then + source $HOME/.config/xunmi/* + 目录_根=${寻觅}/x +fi +echo "执行目录: ${目录_根}" + +# 先检查相关 +[[ ${言灵_函数} == 1 ]] || . ${目录_根}/公共/函数.zsh || exit 2 && 输出 0 "公共函数模块初始化完成" +[[ ${言灵_包管} == 1 ]] || . ${目录_根}/公共/包管.zsh || exit 3 && 输出 0 "包管理器模块初始化完成" + +# 配置检测 + +#[[ ${#通用_包列表} -ne 0 ]] && 批量安装 ${通用_包列表[@]} && 输出 0 "通用包安装完毕" +#[[ ${#架构_包列表} -ne 0 ]] && 批量安装 ${架构_包列表[@]} && 输出 0 "架构专用包安装完毕" +#[[ ${#系统_包列表} -ne 0 ]] && 批量安装 ${系统_包列表[@]} && 输出 0 "系统发行版专用包安装完毕" + +优化_常用命令_ls +# 配置_开发环境 + +#选配