feat: switch to neovim

This commit is contained in:
Job 2024-09-17 18:32:24 +00:00
parent c510c7f919
commit 17e3a6840f
Signed by: Job79
SSH Key Fingerprint: SHA256:BezbKv3jZaqu7SdNrZM0e42b8nlNwh63zaVj/pUxc7U
6 changed files with 51 additions and 4 deletions

View File

@ -1,4 +0,0 @@
{
"name": "idea-demo",
"image": "ubuntu:16.04"
}

15
Containerfile Normal file
View File

@ -0,0 +1,15 @@
FROM docker.io/fedora:41
# === setup system ===
RUN dnf -y install neovim zoxide unzip git go procps bash-completion
# === setup container user ===
RUN useradd -ms /bin/bash user && usermod -aG wheel user && sed -i '/NOPASSWD/s/^#//g' /etc/sudoers
USER user
WORKDIR /home/user
COPY config/user/bashrc /home/user/.bashrc
# === setup neovim ===
RUN git clone --depth 1 https://github.com/AstroNvim/template ~/.config/nvim
COPY config/nvim/lua/community.lua /home/user/.config/nvim/lua/community.lua
COPY config/nvim/lua/polish.lua /home/user/.config/nvim/lua/polish.lua

View File

@ -0,0 +1,5 @@
---@type LazySpec
return {
"AstroNvim/astrocommunity",
{ import = "astrocommunity.completion.copilot-lua-cmp" },
}

View File

@ -0,0 +1,2 @@
vim.opt.relativenumber = false
vim.opt.textwidth = 60

18
config/user/bashrc Normal file
View File

@ -0,0 +1,18 @@
. /etc/bashrc
# === environment ===
export EDITOR=nvim \
WAYLAND_DISPLAY=wayland-0 \
XDG_RUNTIME_DIR=/run/user/1000 \
SSH_AUTH_SOCK=/run/user/1000/ssh-auth-sock
if [ -n "$MYVIMRC" ]; then
PS1='\[\e[90;42m\] container | \w \[\e[40;32m\]\[\e[m\] '
else
PS1='\[\e[97;42m\] container | \w \[\e[49;32m\]\[\e[m\] '
fi
# === aliases and functions ===
alias vi=nvim
post() { curl -sF "content=<-" "https://paste.plabble.org/$2?lang=$1" && echo; }
eval "$(zoxide init --cmd cd bash)"

11
container.sh Executable file
View File

@ -0,0 +1,11 @@
#!/bin/sh
podman run -it \
--name "${dev:-dev}" \
-v /run/user/1000/wayland-0:/run/user/1000/wayland-0 \
-v "$SSH_AUTH_SOCK":/run/user/1000/ssh-auth-sock \
-v ~/Documents:/home/user/Documents \
-v ~/.ssh:/home/user/.ssh \
-v ~/.config/git:/home/user/.config/git \
--security-opt label=disable \
--userns=keep-id \
dev