Compare commits
No commits in common. "默认分支" and "main" have entirely different histories.
BIN
.安装.zsh.swp
BIN
.安装.zsh.swp
Binary file not shown.
100
start.sh
100
start.sh
|
@ -1,100 +0,0 @@
|
|||
#!/usr/bin/bash
|
||||
|
||||
PACK_LIST=("git" "zsh")
|
||||
# 脚本根地址
|
||||
ROOT_URL="https://gitea.whlug.cn/xunmi/x/"
|
||||
# 脚本安装默认路径
|
||||
ROOT_INSTALL="/opt/xunmi"
|
||||
|
||||
###############################################################################
|
||||
# 终端配色 #
|
||||
###############################################################################
|
||||
|
||||
readonly COLOUR_RESET='\e[0m'
|
||||
readonly aCOLOUR=(
|
||||
'\e[38;5;154m' # 0: 亮绿
|
||||
'\e[1m' # 1: 白
|
||||
'\e[90m' # 2: 灰
|
||||
'\e[91m' # 3: 红
|
||||
'\e[32m' # 4: 绿
|
||||
)
|
||||
Show() {
|
||||
if (($1 == 0)); then
|
||||
echo -e "${aCOLOUR[2]}[$COLOUR_RESET${aCOLOUR[0]} 成功 $COLOUR_RESET${aCOLOUR[2]}]$COLOUR_RESET $2"
|
||||
elif (($1 == 1)); then
|
||||
echo -e "${aCOLOUR[2]}[$COLOUR_RESET${aCOLOUR[3]} 失败 $COLOUR_RESET${aCOLOUR[2]}]$COLOUR_RESET $2"
|
||||
exit 1
|
||||
elif (($1 == 2)); then
|
||||
echo -e "${aCOLOUR[2]}[$COLOUR_RESET${aCOLOUR[4]} 信息 $COLOUR_RESET${aCOLOUR[2]}]$COLOUR_RESET $2"
|
||||
fi
|
||||
}
|
||||
GreyStart() {
|
||||
echo -e "${aCOLOUR[2]}\c"
|
||||
}
|
||||
ColorReset() {
|
||||
echo -e "$COLOUR_RESET\c"
|
||||
}
|
||||
|
||||
###############################################################################
|
||||
# 函数 #
|
||||
###############################################################################
|
||||
|
||||
# 更新包管理器
|
||||
Update_PKG() {
|
||||
Show 2 "更新包管理器..."
|
||||
GreyStart
|
||||
if [ -x "$(command -v oma)" ]; then
|
||||
sudo oma refresh
|
||||
elif [ -x "$(command -v apt)" ]; then
|
||||
sudo apt-get update -qq
|
||||
elif [ -x "$(command -v yum)" ]; then
|
||||
sudo yum update
|
||||
fi
|
||||
ColorReset
|
||||
Show 0 "包管理器更新完毕"
|
||||
}
|
||||
|
||||
# 安装依赖
|
||||
Install_PKG() {
|
||||
Update_PKG
|
||||
for ((i = 0; i < ${#PACK_LIST[@]}; i++)); do
|
||||
pack=${PACK_LIST[i]}
|
||||
[ -x "$(command -v $pack)" ] && continue
|
||||
Show 2 "安装必要的依赖项: ${aCOLOUR[4]} $pack $COLOUR_RESET"
|
||||
GreyStart
|
||||
if [ -x "$(command -v oma)" ]; then
|
||||
sudo oma install -y $pack
|
||||
elif [ -x "$(command -v apt)" ]; then
|
||||
sudo apt -y install $pack
|
||||
elif [ -x "$(command -v yum)" ]; then
|
||||
sudo yum install -y $pack
|
||||
elif [ -x "$(command -v pacman)" ]; then
|
||||
sudo pacman -Sy --needed $pack
|
||||
else
|
||||
Show 1 "未找到包管理器, 您需要手动安装: ${aCOLOUR[5]} $pack $COLOUR_RESET"
|
||||
fi
|
||||
ColorReset
|
||||
done
|
||||
Show 0 "依赖安装完成"
|
||||
}
|
||||
|
||||
Download_X(){
|
||||
Show 0 "开始下载配置言灵"
|
||||
GreyStart
|
||||
x_dir=$ROOT_INSTALL/x
|
||||
sudo rm -vrf $x_dir
|
||||
sudo git clone $ROOT_URL $x_dir || Show 1 "言灵拉去失败"
|
||||
mkdir -vp $HOME/.config/xunmi
|
||||
echo "言灵一路径=$ROOT_INSTALL" >> $HOME/.config/xunmi/信息
|
||||
ColorReset
|
||||
}
|
||||
|
||||
#################################################################
|
||||
# 主函数(main) #
|
||||
#################################################################
|
||||
|
||||
Install_PKG
|
||||
Download_X
|
||||
sudo chown -R $USER:$USER $ROOT_INSTALL
|
||||
[ -f "安装.zsh" ] && zsh 安装.zsh || zsh $x_dir/安装.zsh
|
||||
exec zsh
|
130
公共/函数.zsh
130
公共/函数.zsh
|
@ -1,130 +0,0 @@
|
|||
#!/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 "已获取${包名}"
|
||||
解压 ${包名}
|
||||
}
|
54
公共/包管.zsh
54
公共/包管.zsh
|
@ -1,54 +0,0 @@
|
|||
#!/usr/bin/zsh
|
||||
|
||||
# 路径名称: 公共/包管.zsh
|
||||
# 脚本作用: 统一不同发行版中预制的不同的包管理的功能
|
||||
# 当前支持的包管理器有: apt yum pacman
|
||||
# 可实现的功能有 `包管_更新` `包管_安装` `包管_搜索`
|
||||
# 第一作者: 寻觅(xunmiemail@vip.qq.com)
|
||||
# 创建时间: 2024年2月5日11:25:00
|
||||
# 使用方法: 在言灵根目录下使用`. 公共/包管.zsh`
|
||||
|
||||
# 启动言灵包管理模块的标识符
|
||||
言灵一包管=1
|
||||
|
||||
# 调用当前包管理器检查和更新
|
||||
# 参数 [ -n --no-update -不更 ] 携带此参数为仅检查更新
|
||||
# 参数 [ -y -确认 ] 跳过包管理器更新时的二次确认
|
||||
# 实例 `包管_更新 -n`; `包管_更新 -确认`
|
||||
包管一更新() {
|
||||
if [ -x "$(command -v oma)" ]; then
|
||||
# ${特权} oma refresh
|
||||
${特权} oma update -y
|
||||
elif [ -x "$(command -v apt)" ]; then
|
||||
${特权} apt-get update -qq
|
||||
elif [ -x "$(command -v yum)" ]; then
|
||||
${特权} yum update
|
||||
elif [ -x "$(command -v pacman)"]; then
|
||||
${特权} pacman -Syu
|
||||
fi
|
||||
}
|
||||
|
||||
# 调用当前包管理器的安装模块
|
||||
包管一安装(){
|
||||
[ -x "$(command -v $1)" ] && return 0
|
||||
if [ -x "$(command -v oma)" ]; then
|
||||
# 解决oma找不到软件包返回值还是0的问题, 先搜索一下软件包
|
||||
# 神奇的oma居然不走标准输出(2>&1, 将错误输出重定向到标准输出, 方便管道符处理), 坑人啊
|
||||
${特权} oma search $1 2>&1 | head -n 1 | grep -q '\[完整匹配\]' || return 1
|
||||
${特权} oma install -y $1
|
||||
elif [ -x "$(command -v apt)" ]; then
|
||||
${特权} apt -y install $1
|
||||
elif [ -x "$(command -v yum)" ]; then
|
||||
${特权} yum install -y $1
|
||||
elif [ -x "$(command -v pacman)" ]; then
|
||||
${特权} pacman -Sy --needed $1
|
||||
else
|
||||
return 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 默认会尝试使用 apt-file pkgfile 等第三方搜索工具, 未找到第三方搜索工具时尝试使用包管理器自带搜索模块
|
||||
# 参数 [ -n --no-file -原版 ]
|
||||
包管一搜索() {
|
||||
|
||||
}
|
141
公共/开发环境.zsh
141
公共/开发环境.zsh
|
@ -1,141 +0,0 @@
|
|||
#!/usr/bin/zsh
|
||||
|
||||
#####################################
|
||||
# 自动配置常用开发环境 #
|
||||
# [x] go #
|
||||
# [x] rust #
|
||||
# [ ] java #
|
||||
# [ ] nodejs #
|
||||
#####################################
|
||||
|
||||
# 不使用包管理器, 直接用官网的二进制包
|
||||
# 龙芯旧世界更新频率低, 且迟早被弃用, 旧世界仅做有限支持
|
||||
|
||||
#############################################################################
|
||||
# 变量 #
|
||||
#############################################################################
|
||||
|
||||
# 加载基础环境
|
||||
source $HOME/.config/xunmi/信息
|
||||
# source $HOME/x/公共/函数.zsh
|
||||
source ${言灵一路径}/x/公共/函数.zsh
|
||||
路径一开发环境="${言灵一路径}/ide"
|
||||
mkdir -p ${路径一开发环境}
|
||||
|
||||
# 配置全局变量
|
||||
local 旧世界一下载地址="http://ftp.loongnix.cn"
|
||||
|
||||
typeset -A 语言一GO=(
|
||||
['组件']=('go' 'gofmt')
|
||||
['下载地址']="https://golang.google.cn/dl/"
|
||||
['版本正则']="go1.*linux-架构\.tar\.gz"
|
||||
['旧世界版本']="go1.22.0"
|
||||
)
|
||||
typeset -A 语言一RUST=(
|
||||
['组件']=('rustc' 'cargo')
|
||||
['下载地址']="http://ftp.loongnix.cn/toolchain/rust/rust-1.78/2024-05-06/abi1.0/"
|
||||
['版本正则']="rust.*-架构-unknown-linux-gnu\.tar\.gz"
|
||||
['旧世界版本']="1.78.0"
|
||||
)
|
||||
|
||||
#############################################################################
|
||||
# 函数(func) #
|
||||
#############################################################################
|
||||
|
||||
开发环境一检测一GO(){
|
||||
# 检测安装情况
|
||||
unset 下载地址
|
||||
# 获取在线版本
|
||||
版本一在线=$(curl -s ${语言一GO[下载地址]} | grep -o $(echo "${语言一GO[版本正则]}" | sed "s/架构/${言灵一系统架构}/g") | head -n 1)
|
||||
语言一GO[下载地址]="${语言一GO[下载地址]}${版本一在线}"
|
||||
if [[ ${系统一世界类型} == "旧世界" ]]; then
|
||||
输出 4 "[GO检测]旧世界支持开发兼容性较差,建议尽快迁移进入龙芯新世界!"
|
||||
版本一在线=${语言一GO[旧世界版本]}
|
||||
语言一GO[下载地址]="${旧世界一下载地址}/toolchain/golang/${版本一在线%.*}/abi1.0/${版本一在线}.linux-loong64.tar.gz"
|
||||
fi
|
||||
输出 2 "[GO检测]在线版本: ${版本一在线%.linux*}"
|
||||
# 对比本地版本
|
||||
if [ -x "$(command -v go)" ]; then
|
||||
版本一本地="$(echo $(go version) | awk '{print $3}')"
|
||||
# 判断版本新旧
|
||||
输出 2 "[GO检测]本地版本: ${版本一本地}"
|
||||
if 版本对比 "${版本一本地}" "${版本一在线%.linux*}"; then
|
||||
输出 2 "[GO检测]发现新版本GO"
|
||||
return 1
|
||||
fi
|
||||
输出 2 "[GO检测]已是最新的GO版本"
|
||||
return 0
|
||||
fi
|
||||
输出 2 "[GO检测]未检测到GO语言的本地版本"
|
||||
return 1
|
||||
}
|
||||
开发环境一检测一RUST(){
|
||||
# 检测安装情况
|
||||
# 获取在线版本
|
||||
版本一在线=$(curl -s ${语言一RUST[下载地址]} | grep -o $(echo "${语言一RUST[版本正则]}" | sed "s/架构/${言灵一系统架构}/g") | head -n 1)
|
||||
语言一RUST[下载地址]="${语言一RUST[下载地址]}${版本一在线}"
|
||||
if [[ ${系统一世界类型} == "旧世界" ]]; then
|
||||
输出 4 "[RUST检测]旧世界支持开发兼容性较差,建议尽快迁移进入龙芯新世界!"
|
||||
版本一在线=${语言一RUST[旧世界版本]}
|
||||
语言一RUST[下载地址]="${旧世界一下载地址}/toolchain/rust/${rust-版本一在线%.*}/2024-05-06/abi1.0/${rust-版本一在线}-loongarch64-unknown-linux-gnu.tar.gz "
|
||||
fi
|
||||
输出 2 "[RUST检测]在线版本: ${版本一在线%.linux*}"
|
||||
# 对比本地版本
|
||||
if [ -x "$(command -v rustc)" ]; then
|
||||
版本一本地="$(echo $(rustc version) | awk '{print $2}')"
|
||||
# 判断版本新旧
|
||||
输出 2 "[RUST检测]本地版本: ${版本一本地}"
|
||||
if 版本对比 "${版本一本地}" "${版本一在线%.loongarch64*}"; then
|
||||
输出 2 "[RUST检测]发现新版本RUST"
|
||||
return 1
|
||||
fi
|
||||
输出 2 "[RUST检测]已是最新的RUST版本"
|
||||
return 0
|
||||
fi
|
||||
输出 2 "[RUST检测]未检测到RUST语言的本地版本"
|
||||
return 1
|
||||
}
|
||||
|
||||
# 用于检测当前版本是否最新
|
||||
# 备注: 所有`开发环境一检测一*`返回0则代表无需更新,返回1则代表需要更新
|
||||
# *-* -> 位置参数1 <- 需要检测的编程语言
|
||||
开发环境一检测(){
|
||||
|
||||
}
|
||||
|
||||
# 加载主机信息
|
||||
开发环境一初始化(){
|
||||
if [[ ${言灵一系统一主机架构} == "龙" ]]; then
|
||||
if [[ ${言灵一系统一世界类型} == "新世界" ]]; then
|
||||
系统一主机架构="loong64"
|
||||
fi
|
||||
fi
|
||||
系统一主机架构=${言灵一系统一主机架构}
|
||||
}
|
||||
|
||||
开发环境一部署一GO(){
|
||||
输出 2 "开始从 ${语言一GO[下载地址]} 下载部署最新版go语言"
|
||||
|
||||
cd ${路径一开发环境}
|
||||
获解 ${语言一GO[下载地址]}
|
||||
echo "# [觅库]GO语言环境变量-1" >> $HOME/.zshrc
|
||||
echo "export PATH=${路径一开发环境}/go/bin:\$PATH" >> $HOME/.zshrc
|
||||
echo "export GOPATH=$HOME/.goenv" >> $HOME/.zshrc
|
||||
source $HOME/.zshrc
|
||||
go env -w GOPROXY=https://goproxy.cn
|
||||
输出 0 "成功安装GO语言($(go version)), 并自动切换为国内GO语言下载源, 重启zsh生效!"
|
||||
cd -
|
||||
}
|
||||
|
||||
开发环境一部署(){
|
||||
|
||||
}
|
||||
|
||||
###############################################################################
|
||||
# 主函数(main) #
|
||||
###############################################################################
|
||||
|
||||
开发环境一初始化
|
||||
|
||||
开发环境一检测一GO
|
||||
# 开发环境一部署一GO:
|
365
安装.zsh
365
安装.zsh
|
@ -1,365 +0,0 @@
|
|||
#!/usr/bin/zsh
|
||||
|
||||
export PATH=/usr/sbin:$PATH
|
||||
# 让apt包管理器处于非交互模式运行
|
||||
export DEBIAN_FRONTEND=noninteractive
|
||||
# 加载系统配置
|
||||
source /etc/os-release
|
||||
|
||||
# 脚本在执行过程中遇到任何非零返回码的命令时立即退出
|
||||
# set -e
|
||||
|
||||
readonly 言灵一版本="v1.1.0"
|
||||
|
||||
###############################################################################
|
||||
# 全局变量 #
|
||||
###############################################################################
|
||||
|
||||
typeset -a 通用一包列表=('wget' 'curl' 'git' 'vim')
|
||||
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}")
|
||||
系统一发行版一标识=""
|
||||
# 龙架构区分新旧世界的标志位
|
||||
世界一类型="旧世界"
|
||||
|
||||
if command -v sudo >/dev/null 2>&1; then
|
||||
特权="sudo"
|
||||
else
|
||||
特权=""
|
||||
fi
|
||||
|
||||
typeset -a 预设一默认=("vim" "zsh")
|
||||
readonly 言灵一镜像站="http://yum.gdie.top:50200/ylib/"
|
||||
配置一预设=false
|
||||
配置一镜像=false
|
||||
# 帮助信息
|
||||
帮助一信息=$(cat <<EOF
|
||||
用法: $0 [选项]
|
||||
|
||||
选项:
|
||||
-h, -帮助 显示帮助信息
|
||||
-v, -版本 显示版本信息
|
||||
-Y, -预设 使用预设配置安装 ${预设一默认}
|
||||
-J, -镜像 使用镜像源安装 ${言灵一镜像站}
|
||||
|
||||
示例:
|
||||
$0 -h 显示此帮助信息
|
||||
$0 -Y -J 使用预设配置和镜像源安装
|
||||
|
||||
EOF
|
||||
)
|
||||
|
||||
###############################################################################
|
||||
# 函数/方法 #
|
||||
###############################################################################
|
||||
|
||||
# 调用包管理器批量安装
|
||||
批量安装(){
|
||||
typeset -a 包列表=($@)
|
||||
输出 2 "计划安装列表: ${包列表}"
|
||||
for 包 in "${包列表[@]}";do
|
||||
输出 2 "正在安装 -> ${包} <-"
|
||||
色彩一灰色
|
||||
包管一安装 ${包}
|
||||
色彩一清除
|
||||
done
|
||||
}
|
||||
|
||||
# 从git镜像仓库获取依赖
|
||||
# *-* -> 位置参数 1 <- 拉取`作者/仓库名`
|
||||
# *-* -> 位置参数 2 <- 保存地址, 保存到本地的哪个路径
|
||||
获取一git(){
|
||||
色彩一灰色
|
||||
if [ -z "$2" ]; then
|
||||
输出 2 "正在拉取 $1 ..."
|
||||
else
|
||||
输出 2 "正在拉取 $1($2) ..."
|
||||
fi
|
||||
|
||||
if [ -z "${配置一镜像}" ]; then
|
||||
git clone --depth 1 -q ${言灵一镜像站}/${1#*/}.git $2
|
||||
else
|
||||
git clone --depth 1 -q "https://github.com/$1.git" $2
|
||||
fi
|
||||
色彩一清除
|
||||
}
|
||||
|
||||
检查一架构() {
|
||||
case ${CPU一架构} in
|
||||
*x86_64*)
|
||||
主机一架构="amd64"
|
||||
;;
|
||||
*loong*)
|
||||
主机一架构="龙"
|
||||
# 龙架构二进制 第四行是43开头是新世界, 03开头是旧世界
|
||||
世界一类型一标志位=$(hexdump -s 48 -C /usr/bin/sh | head -n 1 | awk '{print $2}')
|
||||
if [[ ${世界一类型一标志位} == "43" ]];then
|
||||
世界一类型="新世界"
|
||||
fi
|
||||
;;
|
||||
*)
|
||||
输出 1 "暂不支持${色彩[3]} ${CPU一架构} ${色彩重置}架构"
|
||||
exit 1
|
||||
;;
|
||||
esac
|
||||
输出 2 "检测到${色彩[1]} ${主机一架构} ${色彩重置}架构"
|
||||
}
|
||||
|
||||
检查一发行版() {
|
||||
未知=0
|
||||
case ${系统一发行版} in
|
||||
*arch*) ;;
|
||||
*Loongnix*) ;;
|
||||
*aosc*)
|
||||
系统一发行版一标识符="安同"
|
||||
# 前三个是字体包
|
||||
系统一包列表=('jetbrains-mono' 'powerline-fonts' 'fantasque-sans-mono-nerd-fonts')
|
||||
;;
|
||||
*debian*)
|
||||
if [[ ${系统一发行版一名称}=="Ubuntu" ]]; then
|
||||
系统一发行版一标识符="乌班图"
|
||||
fi
|
||||
;;
|
||||
*openwrt*)
|
||||
输出 1 "暂不支持openwrt"
|
||||
exit 1
|
||||
;;
|
||||
*)
|
||||
未知=1
|
||||
;;
|
||||
esac
|
||||
|
||||
输出 2 "检测到 ${系统一发行版一名称} (${系统一发行版}) 系统"
|
||||
if [[ ${未知} == 1 ]]; then
|
||||
if 是否 "此发行版尚未验证, 是否尝试继续安装"; then
|
||||
输出 3 "在尚未验证的系统中安装可能会出现未知问题, 如果部分字体出现 口口口 或者乱码的问题, 请手动安装nerd-fonts字体家族的字体"
|
||||
else
|
||||
输出 1 "已退出安装"
|
||||
exit 1
|
||||
fi
|
||||
fi
|
||||
}
|
||||
|
||||
配置检测(){
|
||||
输出 2 "主机信息检测模块启动"
|
||||
检查一架构
|
||||
检查一发行版
|
||||
# 检查本地版本
|
||||
if [[ -n ${言灵一本地版本} ]]; then
|
||||
if 版本对比 ${言灵一版本} ${言灵一本地版本}; then
|
||||
是否 "发现本地版本已是最新版, 是否需要重复安装" || 输出 1 "已退出安装"
|
||||
fi
|
||||
fi
|
||||
# 将本机信息更新到指定文件
|
||||
配置信息=${目录一配置}/信息
|
||||
rm -v ${配置信息}
|
||||
echo "言灵一路径=${言灵一路径}" >> ${配置信息}
|
||||
echo "言灵一发行系统=${系统一发行版一标识符}" >> ${配置信息}
|
||||
if [[ ${主机一架构} == "龙" ]];then
|
||||
echo "言灵一世界类型=${世界一类型}" >> ${配置信息}
|
||||
fi
|
||||
echo "言灵一系统架构=${主机一架构}" >> ${配置信息}
|
||||
输出 0 "主机信息检测完毕"
|
||||
}
|
||||
|
||||
优化一常用命令一zsh(){
|
||||
# 创建下载文件的临时目录
|
||||
输出 2 "启动zsh优化"
|
||||
# 下载zsh扩展
|
||||
色彩一灰色
|
||||
配置一路径=${言灵一路径}/oh-my-zsh
|
||||
${特权} rm -vrf ${配置一路径}
|
||||
获取一git ohmyzsh/ohmyzsh ${配置一路径}
|
||||
获取一git zsh-users/zsh-autosuggestions ${配置一路径}/custom/plugins/zsh-autosuggestions
|
||||
获取一git zsh-users/zsh-syntax-highlighting ${配置一路径}/custom/plugins/zsh-syntax-highlighting
|
||||
|
||||
if [ -f $HOME/.zshrc ]; then
|
||||
mv $HOME/.zshrc $HOME/.zshrc.old
|
||||
fi
|
||||
cp -v ${目录一根}/配置/zshrc $HOME/.zshrc
|
||||
sed -i "s:export ZSH=/etc/oh-my-zsh:export ZSH=${配置一路径}:" $HOME/.zshrc
|
||||
是否 "是否需要将zsh预设配置赋予所有新用户" && ${特权} cp $HOME/.zshrc /etc/skel/.zshrc
|
||||
if 是否 "将Zsh设置为默认命令行"; then
|
||||
chsh -s /usr/bin/zsh
|
||||
输出 0 "已将zsh设置为默认命令行,此设置主要适用于ssh和tty如终端不生效则需要在可视化设置中手动配置启动时加载 '/usr/bin/zsh' "
|
||||
else
|
||||
输出 2 "如需将zsh设置为默认命令行请执行: 'chsh -s /usr/bin/zsh' "
|
||||
fi
|
||||
色彩一清除
|
||||
输出 0 "Zsh优化完成"
|
||||
}
|
||||
|
||||
优化一常用命令一vim(){
|
||||
输出 2 "启动vim优化, 安装代码检查和树状目录插件, 并优化配置(具体配置可以查看 $HOME/.vimrc 文件)"
|
||||
|
||||
# 安装tag
|
||||
typeset -a 标签包名=('universal-ctags' 'ctag')
|
||||
批量安装 标签包名 && 输出 0 "通用包安装完毕"
|
||||
|
||||
vim一配置路径=$HOME/.vim/pack/xunmi
|
||||
色彩一灰色
|
||||
if [ -f $HOME/.vimrc ]; then
|
||||
mv $HOME/.vimrc $HOME/.vimrc.old
|
||||
fi
|
||||
cp -v ${目录一根}/配置/vimrc $HOME/.vimrc
|
||||
rm -vrf ${vim一配置路径}
|
||||
mkdir -vp ${vim一配置路径}/{opt,start}
|
||||
vim说明=${目录一根}/配置/vim配置说明.vim
|
||||
获取一git scrooloose/nerdtree ${vim一配置路径}/start/树状目录
|
||||
获取一git jiangmiao/auto-pairs ${vim一配置路径}/start/括号补齐
|
||||
获取一git preservim/nerdcommenter ${vim一配置路径}/start/注释工具
|
||||
获取一git vim-airline/vim-airline ${vim一配置路径}/start/VIM状态栏
|
||||
获取一git vim-airline/vim-airline-themes ${vim一配置路径}/start/VIM状态栏_皮肤
|
||||
获取一git airblade/vim-gitgutter ${vim一配置路径}/start/Git插件
|
||||
获取一git preservim/tagbar ${vim一配置路径}/start/标签栏
|
||||
获取一git Yggdroot/LeaderF ${vim一配置路径}/start/模糊搜索器
|
||||
# if 是否 "是否启用基于c的模糊搜索(默认使用python, c的性能会好很多)"; then
|
||||
# vim -c ":LeaderfInstallCExtension" ${vim说明}
|
||||
# fi
|
||||
色彩一清除
|
||||
输出 0 "Zsh优化完成"
|
||||
}
|
||||
|
||||
优化一常用命令一ls(){
|
||||
输出 2 "启动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
|
||||
${特权} 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优化完成"
|
||||
}
|
||||
|
||||
优化一常用命令一top(){
|
||||
if [[ ${主机一架构}=="龙" ]]; then
|
||||
xmtop版本="v4.2.1"
|
||||
输出 2 "开始下载 xmtop-${xmtop版本}-${世界一类型}"
|
||||
xmtop_url="https://gitea.whlug.cn/xunmi/xmtop/releases/download/${xmtop版本}/xmtop_${世界一类型}"
|
||||
${特权} wget -t 3 -q --show-progress -c ${xmtop_url} || 输出 5 "无法下载程序包"
|
||||
${特权} mv -v xmtop_${世界一类型} /usr/bin/xmtop
|
||||
${特权} chmod 755 /usr/bin/xmtop
|
||||
else
|
||||
输出 2 "${主机一架构} 架构, 暂未适配top优化, 推荐手动安装gotop, btop等代替top"
|
||||
fi
|
||||
输出 0 "xmtop配置完毕,输入xmtop查看效果"
|
||||
}
|
||||
|
||||
优化一常用命令(){
|
||||
# 优化git, 修复git中文显示为8进制风格的问题
|
||||
git config --global core.quotepath false
|
||||
|
||||
git config --global core.editor "vim"
|
||||
|
||||
typeset -A 列表=(
|
||||
["zsh"]="添加omyzsh, zsh自动补齐, 快速添加${特权}, 便捷操作目录, 优化命令行提示符等"
|
||||
["vim"]="添加常用配置项(允许复制 添加行号 显式当前行等), 常用插件(目录 语法检测)"
|
||||
["ls"]="使用lsd替代老旧的ls, (lsd是rust编写的兼容ls的目录查看工具, 其丰富的配色和图标可有效增加目录的可读性)"
|
||||
#["cat"]="使用bat替代cat"
|
||||
["top"]="使用xmtop替代老旧的top系统信息监控功能"
|
||||
#["sed"]="使用学习成本较低的sd替代sed"
|
||||
)
|
||||
# 查看预设是否被启动
|
||||
if ${配置一预设}; then
|
||||
输出 2 "正在优化 ${预设一默认} 命令"
|
||||
for 默认 in "${预设一默认[@]}";do
|
||||
echo "正在启动 ${默认} 优化, ->${列表[$默认]}<-"
|
||||
优化一常用命令一${默认}
|
||||
done
|
||||
else
|
||||
输出 2 "正在优化 ${(k)列表} 命令"
|
||||
# 遍历关联数组
|
||||
for 键 值 in ${(kv)列表}; do
|
||||
if 是否 "是否启动 '${键}' 命令优化 -> ${值} <- "; then
|
||||
优化一常用命令一${键}
|
||||
else
|
||||
输出 3 "已取消 ${键} 的优化"
|
||||
fi
|
||||
done
|
||||
fi
|
||||
}
|
||||
|
||||
###############################################################################
|
||||
# 主函数(main) #
|
||||
###############################################################################
|
||||
|
||||
echo "
|
||||
*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*
|
||||
* 欢迎使用 言灵 配置脚本 *
|
||||
*-*-*-*-*-*-*-*-*-*-*-*-*-*-*-*
|
||||
"
|
||||
目录一根=$PWD
|
||||
目录一配置=$HOME/.config/xunmi
|
||||
source ${目录一配置}/信息
|
||||
# 判断当前执行的位置 如果不再项目路径中就去寻找路径
|
||||
if [ ! -f "公共/函数.zsh" ]; then
|
||||
目录一根=${言灵一路径}/x
|
||||
fi
|
||||
echo "执行目录: ${目录一根}"
|
||||
|
||||
# 先检查公共函数是否正常加载
|
||||
[[ ${言灵一函数} == 1 ]] || . ${目录一根}/公共/函数.zsh || exit 2 && 输出 0 "公共函数模块初始化完成"
|
||||
[[ ${言灵一包管} == 1 ]] || . ${目录一根}/公共/包管.zsh || exit 3 && 输出 0 "包管理器模块初始化完成"
|
||||
|
||||
# 处理用户输入
|
||||
# 使用 case 语句检查命令行参数
|
||||
while [[ $# -gt 0 ]]; do
|
||||
case "$1" in
|
||||
-h | -帮助 | --help )
|
||||
echo "\n*-*-*-*-*-*-*-*-*-*-*-*-*-*\n"${帮助一信息}
|
||||
exit 0
|
||||
;;
|
||||
-v | -版本 | --version )
|
||||
echo "版本号:${言灵一版本}"
|
||||
exit 0
|
||||
;;
|
||||
-Y | -预设)
|
||||
输出 2 "启用预设模式"
|
||||
配置一预设=true
|
||||
;;
|
||||
-J | -镜像)
|
||||
# 判断镜像网站的连通性, 可以连通则使用
|
||||
if $(curl -IsS ${言灵一镜像站} | head -n 1 | grep -q "200"); then
|
||||
输出 2 "启动镜像下载"
|
||||
配置一预设=true
|
||||
else
|
||||
输出 4 "无法访问镜像站, 使用默认的github"
|
||||
fi
|
||||
;;
|
||||
*)
|
||||
输出 4 "未知选项 -> $1 <- "
|
||||
echo ${帮助一信息}
|
||||
exit 0
|
||||
;;
|
||||
esac
|
||||
shift
|
||||
done
|
||||
|
||||
配置检测
|
||||
|
||||
[[ ${#通用一包列表} -ne 0 ]] && 批量安装 ${通用一包列表[@]} && 输出 0 "通用包安装完毕"
|
||||
[[ ${#架构一包列表} -ne 0 ]] && 批量安装 ${架构一包列表[@]} && 输出 0 "架构专用包安装完毕"
|
||||
[[ ${#系统一包列表} -ne 0 ]] && 批量安装 ${系统一包列表[@]} && 输出 0 "系统发行版专用包安装完毕"
|
||||
|
||||
优化一常用命令
|
||||
# 配置一开发环境
|
||||
|
||||
echo "言灵一本地版本=${言灵一版本}" >> ${目录一配置}/信息
|
||||
输出 0 "已成功安装 言灵 ${言灵一版本}"
|
|
@ -1,2 +0,0 @@
|
|||
pacman -Syu
|
||||
pkgfile --update
|
|
@ -1,5 +0,0 @@
|
|||
# 清理pacman的下载缓存
|
||||
## 清理时保留最近一个版本的包
|
||||
paccache -rk1
|
||||
## 清理所有以及卸载的包
|
||||
paccache -ruk0
|
|
@ -1,196 +0,0 @@
|
|||
#!/usr/bin/bash
|
||||
|
||||
###############################################################################
|
||||
# 变量 #
|
||||
###############################################################################
|
||||
|
||||
# 将终端的输出重置为默认设置,并且不会换行(用于重置终端的字体颜色、背景色和文本样式等设置)
|
||||
echo -e "\e[0m\c"
|
||||
|
||||
# shellcheck disable=SC2016
|
||||
|
||||
# 脚本在执行过程中遇到任何非零返回码的命令时立即退出
|
||||
set -e
|
||||
|
||||
# 下载域
|
||||
readonly DOWNLOAD_DOMAIN=https://gitea.whlug.cn/
|
||||
# 下载保存路径
|
||||
TMP_ROOT=/tmp/xunmi
|
||||
|
||||
# 读取系统架构和内核信息
|
||||
readonly UNAME_M="$(uname -m)"
|
||||
WorldType="新世界"
|
||||
|
||||
# 加载系统信息
|
||||
source /etc/os-release
|
||||
readonly Release=$(echo "${ID}")
|
||||
readonly ReleaseName=$(echo "${NAME}")
|
||||
|
||||
# 获取项目路径
|
||||
ItemDir=$1
|
||||
|
||||
###############################################################################
|
||||
# 终端配色 #
|
||||
###############################################################################
|
||||
|
||||
# 颜色配置
|
||||
readonly COLOUR_RESET='\e[0m'
|
||||
readonly aCOLOUR=(
|
||||
'\e[38;5;154m' # 0: 亮绿
|
||||
'\e[1m' # 1: 白
|
||||
'\e[90m' # 2: 灰
|
||||
'\e[91m' # 3: 红
|
||||
'\e[32m' # 4: 绿
|
||||
'\e[33m' # 5: 黄
|
||||
)
|
||||
|
||||
Show() {
|
||||
if (($1 == 0)); then
|
||||
echo -e "${aCOLOUR[2]}[$COLOUR_RESET${aCOLOUR[0]} 成功 $COLOUR_RESET${aCOLOUR[2]}]$COLOUR_RESET $2"
|
||||
elif (($1 == 1)); then
|
||||
echo -e "${aCOLOUR[2]}[$COLOUR_RESET${aCOLOUR[3]} 失败 $COLOUR_RESET${aCOLOUR[2]}]$COLOUR_RESET $2"
|
||||
exit 1
|
||||
elif (($1 == 2)); then
|
||||
echo -e "${aCOLOUR[2]}[$COLOUR_RESET${aCOLOUR[4]} 信息 $COLOUR_RESET${aCOLOUR[2]}]$COLOUR_RESET $2"
|
||||
elif (($1 == 3)); then
|
||||
echo -e "${aCOLOUR[2]}[$COLOUR_RESET${aCOLOUR[5]} 通知 $COLOUR_RESET${aCOLOUR[2]}]$COLOUR_RESET $2"
|
||||
fi
|
||||
}
|
||||
|
||||
# 灰色信息(处理一些无关紧要的信息, 调用后在没有清除颜色之前会一直使用灰色输出)
|
||||
GreyStart() {
|
||||
echo -e "${aCOLOUR[2]}\c"
|
||||
}
|
||||
|
||||
# 清除颜色(一般和灰色信息连用)
|
||||
ColorReset() {
|
||||
echo -e "$COLOUR_RESET\c"
|
||||
}
|
||||
|
||||
###############################################################################
|
||||
# 函数/方法 #
|
||||
###############################################################################
|
||||
|
||||
# 检查文件是否存在
|
||||
exist_file() {
|
||||
if [ -e "$1" ]; then
|
||||
return 0
|
||||
else
|
||||
return 1
|
||||
fi
|
||||
}
|
||||
|
||||
# 识别架构
|
||||
Check_Arch() {
|
||||
case $UNAME_M in
|
||||
*loongarch64*)
|
||||
TARGET_ARCH="loong64"
|
||||
;;
|
||||
*)
|
||||
Show 1 "此模块仅支持 loong64 架构处理器暂不支持 $UNAME_M 架构"
|
||||
exit 1
|
||||
;;
|
||||
esac
|
||||
Show 2 "检测到 $TARGET_ARCH 架构"
|
||||
}
|
||||
|
||||
# 检查发行版和世界信息
|
||||
Check_Distribution() {
|
||||
sType=2
|
||||
notice=""
|
||||
case $Release in
|
||||
*arch*) ;;
|
||||
*Loongnix*);;
|
||||
*openwrt*)
|
||||
Show 1 "暂不支持openwrt"
|
||||
exit 1
|
||||
;;
|
||||
*)
|
||||
sType=3
|
||||
notice="我们尚未在此发行版上进行测试,默认使用新世界文件替换"
|
||||
;;
|
||||
esac
|
||||
WorldNum=$(hexdump -s 48 -C /usr/bin/sh | head -n 1 | awk '{print $2}')
|
||||
if [[ ${WorldNum} == "03" ]]; then
|
||||
WorldType="旧世界"
|
||||
fi
|
||||
Show ${sType} "检测到 ${ReleaseName} 发行版系统, 根据内核版本推断属于 -> ${WorldType} <- 系统 "
|
||||
|
||||
if [[ ${sType} == 1 ]]; then
|
||||
select yn in "Yes" "No"; do
|
||||
case $yn in
|
||||
[yY][eE][sS] | [yY])
|
||||
Show 0 "检查已忽略"
|
||||
break
|
||||
;;
|
||||
[nN][oO] | [nN])
|
||||
Show 1 "已退出安装"
|
||||
exit 1
|
||||
;;
|
||||
esac
|
||||
done < /dev/tty # < /dev/tty 用于从终端读取输入信息
|
||||
fi
|
||||
}
|
||||
|
||||
# 下载替换依赖
|
||||
DownloadAndInstall() {
|
||||
PACKAGES=(
|
||||
"${DOWNLOAD_DOMAIN}public/JetBrains_jna/releases/download/1.0/libjnidispatch_${WorldType}.so"
|
||||
"${DOWNLOAD_DOMAIN}public/JetBrains_pty4j/releases/download/1.0/libpty_${WorldType}.so"
|
||||
|
||||
"${DOWNLOAD_DOMAIN}public/JetBrains_fsnotifier/releases/download/1.0/fsnotifier_${WorldType}"
|
||||
)
|
||||
|
||||
# 检测项目路径是否存在
|
||||
exist_file $ItemDir/lib/jna/amd64 || Show 1 "未找到关键路径 '$ItemDir/lib/jna/amd64' 请使用最新版JetBrains"
|
||||
|
||||
rm -rf ${TMP_ROOT}
|
||||
mkdir -p ${TMP_ROOT} || Show 1 "无法创建临时目录"
|
||||
TmpDir=$(mktemp -d -p ${TMP_ROOT} || Show 1 "无法创建临时目录")
|
||||
pushd "${TmpDir}"
|
||||
|
||||
for PACKAGE in "${PACKAGES[@]}"; do
|
||||
Show 2 "下载 ${PACKAGE}..."
|
||||
GreyStart
|
||||
wget -t 3 -q --show-progress -c "${PACKAGE}" || Show 1 "无法下载程序包"
|
||||
ColorReset
|
||||
Show 0 "下载完成"
|
||||
done
|
||||
now=$(date +"%Y%m%d-%H%M%S")
|
||||
exist_file $ItemDir/lib/jna/amd64 || Show 1 "未找到指定路径 $ItemDir"
|
||||
|
||||
Show 2 "开始文件替换"
|
||||
GreyStart
|
||||
mv -nv $ItemDir/lib/jna/amd64/libjnidispatch.so $ItemDir/lib/jna/amd64/libjnidispatch_x86_$now.so
|
||||
cp -v $TmpDir/libjnidispatch_${WorldType}.so $ItemDir/lib/jna/amd64/libjnidispatch.so
|
||||
mkdir -vp $ItemDir/lib/pty4j/linux/loongarch64
|
||||
cp -v $TmpDir/libpty_${WorldType}.so $ItemDir/lib/pty4j/linux/loongarch64/libpty.so
|
||||
cp -v $TmpDir/fsnotifier_${WorldType} ~/.config/JetBrains/fsnotifier
|
||||
chmod -v 755 ~/.config/JetBrains/fsnotifier
|
||||
echo "idea.filewatcher.executable.path=$(readlink -f ~/.config/JetBrains/fsnotifier)" >> $ItemDir/bin/idea.properties
|
||||
ColorReset
|
||||
Show 0 "文件替换完成"
|
||||
}
|
||||
|
||||
###############################################################################
|
||||
# 入口(main) #
|
||||
###############################################################################
|
||||
|
||||
usage() {
|
||||
cat <<-EOF
|
||||
使用方法: "$0 <PATH>"
|
||||
PATH: JetBrains软件解压路径
|
||||
EOF
|
||||
}
|
||||
|
||||
if [ $# -eq 0 ]; then
|
||||
usage
|
||||
Show 1 "该脚本需要至少一个参数!"
|
||||
fi
|
||||
|
||||
# 检查架构
|
||||
Check_Arch
|
||||
# 检查发行版
|
||||
Check_Distribution
|
||||
# 下载替换依赖
|
||||
DownloadAndInstall
|
|
@ -1,78 +0,0 @@
|
|||
# 寻觅的vim用法
|
||||
|
||||
言灵vim配置用法, 查看此教程前需对vim有一定了解, 如果您完全没有使用过vim, 请在命令行中执行 `vimtutor` 学习vim相关操作后再来查看此vim扩展
|
||||
> 最少查看 `vimtutor` 的前三章
|
||||
|
||||
## 快捷键
|
||||
|
||||
vim常用快捷键记录
|
||||
|
||||
> 备注: <占位符>(\<leader>): 自定义键盘前缀, 默认为反斜杠`\` 在`~/.vimrc`可自定义 -> `let mapleader = 'x'`
|
||||
> 冒号 `:` 开头的快捷键是需要用户在预览模式下输入启动
|
||||
|
||||
* `[数量]<占位符>cc` 注释当前行和选中行
|
||||
* `[数量]<占位符>ci` 执行反转注释操作,选中区域注释部分取消注释,非注释部分添加注释
|
||||
* `[数量]<占位符>cA` 跳转到该行结尾添加注释,并进入编辑模式
|
||||
* `[数量]<占位符>cu` 取消注释
|
||||
|
||||
* `ctrl ]` 跳转到光标下的函数定义处
|
||||
* `*` 在本文件中查找函数或变量
|
||||
* `ctrl o` 返回跳转之前的位置
|
||||
* `ctrl i` 返回 `ctrl o` 跳转之前的位置
|
||||
* `]c` 跳转到下一个修改的位置
|
||||
* `[c` 跳转到上一个修改的位置
|
||||
|
||||
* `ctrl g` 打开属性栏
|
||||
* `ctrl n` 打开目录栏
|
||||
* `<占位符>n` 将光标聚焦到目录
|
||||
* `ctrl t` 切换目录状态(打开则关闭, 关闭则打开)
|
||||
* `ctrl f` 打开目录搜索框
|
||||
* `ctrl w` 多个窗口之间切换焦点, 按下此快捷键后在按上下左右或者k(上)j(下)h(左)l(右)
|
||||
* `:sp` 水平切分窗口
|
||||
* `:vsp` 垂直切分窗口
|
||||
* `ctrl 6` 切换缓冲区
|
||||
* `:bn` 切换到下一个缓冲区
|
||||
* `:bp` 切换到上一个缓冲区
|
||||
|
||||
* `<占位符>ff` 目录搜索(相当于:Leaderf file)
|
||||
* `<占位符>fb` 缓冲区搜索(相当于:Leaderf buffer)
|
||||
* `<占位符>fm` 搜索最近使用的文件(相当于:Leaderf mru)
|
||||
* `<占位符>ft` 在缓冲区中导航标签, 相当于搜索当前文件定义的函数(相当于:Leaderf bufTag)
|
||||
* `<占位符>fl` 在缓冲区中搜索行, 相当于搜索当前文件(相当于:Leaderf line)
|
||||
* `ctrl j` \[搜索窗口]向下移动搜索框
|
||||
* `ctrl k` \[搜索窗口]向上移动搜索框
|
||||
* `ctrl x` \[搜索窗口]在水平拆分窗口中打开
|
||||
* `ctrl ]` \[搜索窗口]在垂直拆分窗口中打开
|
||||
* `ctrl T` \[搜索窗口]在新选项卡页中打开
|
||||
* `ctrl ↓` \[搜索窗口]在弹出预览窗口中向下滚动
|
||||
* `ctrl ↑` \[搜索窗口]在弹出预览窗口中向上滚动
|
||||
* `ctrl R` \[搜索窗口]在模糊搜索模式和正则表达式模式之间切换
|
||||
* `ctrl F` \[搜索窗口]在全路径搜索模式和仅名称搜索模式之间切换
|
||||
* `ctrl B` 使用 Leaderf 插件和 rg 命令在当前缓冲区中进行模糊搜索当前光标下的单词
|
||||
* `ctrl F` 使用 Leaderf 插件和 rg 命令在所有文件中进行模糊搜索当前光标下的单词
|
||||
* `gf` 在可视模式下选择文本后,使用 Leaderf 插件和 rg 命令进行精确搜索所选的文本
|
||||
* `go` 执行上次搜索
|
||||
|
||||
## 代码补全工具(coc.nvim)
|
||||
|
||||
```vim
|
||||
# 安装
|
||||
:CocInstall [包名]
|
||||
# 更新
|
||||
:CocUpdate
|
||||
# 移除
|
||||
:CocUninstall [包名]
|
||||
# 查看已安装
|
||||
:CocList extensions
|
||||
```
|
||||
|
||||
## 已安装插件
|
||||
|
||||
* 代码补全工具[neoclide/coc.nvim](https://gitcode.com/mirrors/neoclide/coc.nvim)
|
||||
* 数状目录[scrooloose/nerdtree](https://gitcode.com/mirrors/scrooloose/nerdtree)
|
||||
* VIM状态栏[vim-airline/vim-airline](https://gitcode.com/vim-airline/vim-airline/overview)
|
||||
* VIM状态栏-皮肤[vim-airline/vim-airline-themes](https://gitcode.com/mirrors/vim-airline/vim-airline-themes)
|
||||
* 注释工具[preservim/nerdcommenter](https://gitcode.com/mirrors/preservim/nerdcommenter/overview)
|
||||
* 模糊搜索[Yggdroot/LeaderF](https://gitcode.com/Yggdroot/LeaderF/overview)
|
||||
* Git插件[airblade/vim-gitgutter](https://gitcode.com/mirrors/airblade/vim-gitgutter)
|
||||
* 标签栏[preservim/tagbar](https://gitcode.com/mirrors/preservim/tagbar)
|
|
@ -1 +0,0 @@
|
|||
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQCTLiA/lthLkG3C1dGKF7Ls32M5iTEViYUHcA8rIldL7YlZFFxd/G0lrzvYKLh4rNpDIuSPfUOCWK0owKZDzaoz1MqXxqezzNDwZ8vZ33LbR5bFnGUst55tjEJNg/Zx9XdXmCcpSU2TE5FE7IGHjqOf+hi7k0tY6DCYiuJjK6Bo99O1ZsrASDjga8ksYChZpCDNpV8ZHP7urgO1Ztf/ukrknm6EcKWCu2fO+UbwRSHTz73lTMAuaSPdNI7x37jIoLHmUt0LUjIrzRRCLnYXeGkBvlU+fi6JDdLiA3DKQTS/QSrzdvLpP1e+qPaFIY0KMtnRaXXk+G/FdK/Z4hyZK/ZLgVhe+m1d3CovSQz5S2XwXFqlpnbE8srT3xG5pfdhdsuZ6LW9BAj/3QLlzLsd2lYBhmxYo287MSPnNERZ4qZ1iwWt5283tfHseD9WESSJrW0tTZPEFViI+UmDAR7lYYptBFT03lY/VJzB8/yBddcqnjn0lcKMyQcmT7noj+rxNF8= xunmi@archlinux
|
77
配置/vimrc
77
配置/vimrc
|
@ -1,77 +0,0 @@
|
|||
set nocompatible " 去除 vi 一致性
|
||||
set number " 打开行数查看
|
||||
set cursorline " 光标所在的当前行高亮。
|
||||
set linebreak " 只有遇到指定的符号(比如空格、连词号和其他标点符号),才发生折行。
|
||||
|
||||
set laststatus=2 " 是否显示状态栏。0 表示不显示,1 表示只在多窗口时显示,2 表示显示。
|
||||
set ruler " 在状态栏显示光标的当前位置(位于哪一行哪一列)。
|
||||
set undofile " 保留撤销历史。
|
||||
set undodir=~/.vim/.undo " 设置操作历史文件的保存位置。
|
||||
set encoding=utf-8 " 使用 utf-8 编码
|
||||
set autoindent " 按下回车键后,下一行的缩进会自动跟上一行的缩进保持一致。
|
||||
set smartindent " 智能缩进
|
||||
set tabstop=4 " 按下 Tab 键时,Vim 显示的空格数。
|
||||
filetype indent on " 开启文件类型检查,并且载入与该类型对应的缩进规则。
|
||||
filetype on " 开启文件类型检测
|
||||
filetype plugin indent on " 开启文件类型插件检测
|
||||
syntax on " 开启语法高亮
|
||||
|
||||
set showmode " 在底部显示,当前处于命令模式还是插入模式。
|
||||
set showcmd " 命令模式下,在底部显示,当前键入的指令。比如,键入的指令是 2y3d,那么底部就会显示 2y3,当键入 d 的时候,操作完成,显示消失。
|
||||
set mouse= " 支持使用鼠标(但这样会导致无法复制!)
|
||||
|
||||
let g:airline#extensions#tabline#enabled = 1 " 设置开启 tab 样式
|
||||
let g:airline#extensions#tabline#formatter = 'jsformatter' " 设置默认 tab 栏样式
|
||||
let g:airline_theme='angr' " 选择配色
|
||||
|
||||
let g:NERDSpaceDelims = 1 " 默认情况下,在注释分隔符后添加空格
|
||||
let g:NERDCompactSexyComs = 1 " 使用紧凑的语法来美化多行注释
|
||||
let g:NERDTrimTrailingWhitespace = 1 " 启用在取消注释时修剪尾部空白的功能
|
||||
let g:NERDToggleCheckAllLines = 1 " 启用 NERDCommenterToggle 以检查所有选定行是否已注释
|
||||
|
||||
" 树状目录(preservim/nerdtree): 在vim侧栏启动目录
|
||||
autocmd StdinReadPre * let s:std_in=1
|
||||
" 使用目录启动时自动启动侧栏
|
||||
autocmd VimEnter * if argc() == 1 && isdirectory(argv()[0]) && !exists('s:std_in') |
|
||||
\ execute 'NERDTree' argv()[0] | wincmd p | enew | execute 'cd '.argv()[0] | endif
|
||||
" 在没有文件参数的情况下启动
|
||||
autocmd VimEnter * if argc() == 0 && !exists('s:std_in') | NERDTree | endif
|
||||
" 定义树状目录的快捷键
|
||||
nnoremap <leader>n :NERDTreeFocus<CR>
|
||||
nnoremap <C-n> :NERDTree<CR>
|
||||
nnoremap <C-t> :NERDTreeToggle<CR>
|
||||
nnoremap <C-f> :NERDTreeFind<CR>
|
||||
" 如果目录是最后一个窗口则自动退出vim
|
||||
autocmd BufEnter * if tabpagenr('$') == 1 && winnr('$') == 1 && exists('b:NERDTree') && b:NERDTree.isTabTree() | quit | endif
|
||||
let g:NERDTreeFileLines = 1 " 显示文件行
|
||||
|
||||
" 标签生成器(ludovicchabant/vim-gutentags): 在特定目录下自动调用ctags生成标签
|
||||
set statusline+=%{gutentags#statusline()} " 在状态行中打印字符串“tag”,当Gutengs在后台生成内容时
|
||||
let g:gutentags_project_root = ['.git', '.svn', 'Makefile'] " 工程根目录标识(打开包含如下文件或目录是激活Gutentag)。
|
||||
let g:gutentags_ctags_tagfile = '.tags' " 生成数据文件名称。
|
||||
let g:gutentags_cache_dir = expand('~/.config/xunmi/tag') " 指定缓存根目录,ctags保存在该目录下。
|
||||
"Ctags配置参数。
|
||||
let g:gutentags_ctags_extra_args = ['--fields=+niazS', '--extra=+q']
|
||||
let g:gutentags_ctags_extra_args += ['--c++-kinds=+pxI']
|
||||
let g:gutentags_ctags_extra_args += ['--c-kinds=+px']
|
||||
|
||||
" 模糊搜索(Yggdroot/LeaderF)
|
||||
let g:Lf_HideHelp = 1 " 在正常模式下不显示帮助
|
||||
let g:Lf_UseCache = 0 " 不使用缓存, 避免更新文件后搜索异常
|
||||
let g:Lf_UseVersionControlTool = 1 " 使用版本控制工具(如Git)来获取文件的状态信息
|
||||
let g:Lf_IgnoreCurrentBufferName = 1 " 忽略当前的缓冲区名称
|
||||
let g:Lf_WindowPosition = 'popup' " 窗口模式
|
||||
let g:Lf_ShortcutF = "<leader>ff" " 打开LeaderF搜索界面
|
||||
noremap <leader>fb :<C-U><C-R>=printf("Leaderf buffer %s", "")<CR><CR>
|
||||
noremap <leader>fm :<C-U><C-R>=printf("Leaderf mru %s", "")<CR><CR>
|
||||
noremap <leader>ft :<C-U><C-R>=printf("Leaderf bufTag %s", "")<CR><CR>
|
||||
noremap <leader>fl :<C-U><C-R>=printf("Leaderf line %s", "")<CR><CR>
|
||||
noremap <C-B> :<C-U><C-R>=printf("Leaderf! rg --current-buffer -e %s ", expand("<cword>"))<CR>
|
||||
noremap <C-F> :<C-U><C-R>=printf("Leaderf! rg -e %s ", expand("<cword>"))<CR>
|
||||
" 按字面意思搜索视觉选择的文本
|
||||
xnoremap gf :<C-U><C-R>=printf("Leaderf! rg -F -e %s ", leaderf#Rg#visual())<CR>
|
||||
noremap go :<C-U>Leaderf! rg --recall<CR>
|
||||
|
||||
" 标签栏
|
||||
nnoremap <C-g> :TagbarToggle<CR>
|
||||
|
|
@ -1,7 +0,0 @@
|
|||
受限于vim特性, 没法做到执行完命令后自动退出, 如果左侧命令执行完毕, 请手动退出(:qa或:x)
|
||||
|
||||
完全不会使用vim请按如下操作:
|
||||
等左侧执行完毕(所有下载和安装结束, 左侧内容超过五秒没发生任何变化)
|
||||
1. 双击两下esc
|
||||
2. 输入`:qa`( 按一下冒号,然后按字母q和a ), 这时候整个vim会退出
|
||||
|
87
配置/zshrc
87
配置/zshrc
|
@ -1,87 +0,0 @@
|
|||
export ZSH=/etc/oh-my-zsh
|
||||
# 添加环境变量
|
||||
# export PATH=$HOME/bin:/usr/local/bin:$HOME/.local/bin:$PATH
|
||||
|
||||
# zsh 主题,在线预览 https://github.com/ohmyzsh/ohmyzsh/wiki/Themes
|
||||
# 推荐主题: gnzh、jispwoso[双行: 1 用户名-目录-Git]
|
||||
# af-magic [目录-Git, 用户名后置]; fishy [仿照 fish,类似原生 shell,但是路径会缩写]
|
||||
# alanpeabody [用户名-目录, Git 后置]; dst [双行: 1 用户名-目录-Git, 2 后置时间]
|
||||
# rkj-repos [双行: 1 用户名-目录-时间, 2 返回值-Git]; bira [双行: 1 用户名-目录-Git]
|
||||
ZSH_THEME="rkj-repos"
|
||||
|
||||
# 启动大小写区分
|
||||
# CASE_SENSITIVE="true"
|
||||
|
||||
# 使用不敏感连字符的补全。 _ 和 - 将是可互换的。
|
||||
HYPHEN_INSENSITIVE="true"
|
||||
|
||||
# 取消下列行之一的注释,以更改自动更新行为
|
||||
# zstyle ':omz:update' mode disabled # 禁用自动更新
|
||||
zstyle ':omz:update' mode auto # update 会自动更新而不需要询问
|
||||
# zstyle ':omz:update' mode reminder # 提醒我要及時更新
|
||||
|
||||
# 取消下面一行的注释,以更改自动更新的频率(以天为单位)。
|
||||
# zstyle ':omz:update' frequency 13
|
||||
|
||||
# 修复链接 URL 错误的问题
|
||||
# DISABLE_MAGIC_FUNCTIONS="true"
|
||||
|
||||
# 禁用 ls 的颜色
|
||||
# DISABLE_LS_COLORS="true"
|
||||
|
||||
# 禁止自动设置命令行标题
|
||||
# DISABLE_AUTO_TITLE="true"
|
||||
|
||||
# 取消注释以下行,以启用命令自动更正。
|
||||
# ENABLE_CORRECTION="true"
|
||||
|
||||
# 取消注释以下行,以便在等待完成时显示红点。
|
||||
# 您也可以将其设置为另一个字符串,以显示该字符串,而不是默认的红点。
|
||||
# 例如 COMPLETION_WAITING_DOTS="%F{yellow}waiting...%f"
|
||||
COMPLETION_WAITING_DOTS="true"
|
||||
|
||||
# 如果要禁用标记未跟踪的文件,请取消注释以下行
|
||||
# 这使得对大型存储库的存储库状态检查快得多。
|
||||
# DISABLE_UNTRACKED_FILES_DIRTY="true"
|
||||
|
||||
# 如果要更改历史命令输出中显示的命令执行时间戳,请取消注释以下行。
|
||||
# 可以设置可选的三种格式之一: “ mm/dd/yyyy”| “ dd.mm.yyyy”| “ yyyy-mm-dd”
|
||||
# 或使用 strftime 函数格式规范设置自定义格式,详见‘ man strftime’。
|
||||
HIST_STAMPS="yyyy-mm-dd"
|
||||
|
||||
# 你想加载哪些插件?
|
||||
# 标准插件可以在 `$ZSH/plugins/` 中找到
|
||||
# 自定义插件可以添加到 `$ZSH_CUSTOM/plugins/`
|
||||
# 注意: 太多的插件会降低 shell 启动的速度。
|
||||
# command-not-found当前仅支持debian系
|
||||
# 支持fzf可以尝试使用zsh-interactive-cd,cd目录时可以模糊查找
|
||||
# znt zsh官方出的导航工具:https://github.com/z-shell/zsh-navigation-tools
|
||||
# 官方插件及其功能说明可以查看:https://github.com/ohmyzsh/ohmyzsh/wiki/Plugins
|
||||
plugins=(
|
||||
git
|
||||
sudo
|
||||
#zsh-interactive-cd
|
||||
zsh-navigation-tools
|
||||
zsh-autosuggestions
|
||||
zsh-syntax-highlighting
|
||||
)
|
||||
|
||||
# arch系列安装pkgfile后可以使用其内置的command-not-found功能
|
||||
# source /usr/share/doc/pkgfile/command-not-found.zsh
|
||||
|
||||
source $ZSH/oh-my-zsh.sh
|
||||
|
||||
# 用户配置
|
||||
# export MANPATH="/usr/local/man:$MANPATH"
|
||||
|
||||
# 编译标志
|
||||
# export ARCHFLAGS="-arch loongarch64"
|
||||
# export ARCH=$(uname -m)
|
||||
|
||||
# 配置中文环境
|
||||
export LC_ALL="zh_CN.UTF-8"
|
||||
|
||||
# 别名
|
||||
# alias ls='lsd'
|
||||
alias zshconfig="vim ~/.zshrc"
|
||||
|
Loading…
Reference in New Issue
Block a user