Compare commits

..

No commits in common. "默认分支" and "main" have entirely different histories.

16 changed files with 0 additions and 1252 deletions

View File

@ -1,5 +0,0 @@
测试.zsh
idea
.vscode

Binary file not shown.

View File

@ -1,4 +0,0 @@
# 介绍
用于个人练手学习

100
start.sh
View File

@ -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

View File

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

View File

@ -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 -原版 ]
包管一搜索() {
}

View File

@ -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:

View File

@ -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 "已成功安装 言灵 ${言灵一版本}"

View File

@ -1,2 +0,0 @@
pacman -Syu
pkgfile --update

View File

@ -1,5 +0,0 @@
# 清理pacman的下载缓存
## 清理时保留最近一个版本的包
paccache -rk1
## 清理所有以及卸载的包
paccache -ruk0

View File

@ -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

View File

@ -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)

View File

@ -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

View File

@ -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>

View File

@ -1,7 +0,0 @@
受限于vim特性, 没法做到执行完命令后自动退出, 如果左侧命令执行完毕, 请手动退出(:qa或:x)
完全不会使用vim请按如下操作:
等左侧执行完毕(所有下载和安装结束, 左侧内容超过五秒没发生任何变化)
1. 双击两下esc
2. 输入`:qa`( 按一下冒号,然后按字母q和a ), 这时候整个vim会退出

View File

@ -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-cdcd目录时可以模糊查找
# 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"