1 Commits

Author SHA1 Message Date
Shaun Setlock
5add7af8b0 Created Actions workflow for nvim container build. 2025-05-03 16:42:24 -04:00
13 changed files with 65 additions and 147 deletions

View File

@@ -1,38 +0,0 @@
name: Build and Push Docker Image
on:
push:
tags:
- "v*"
workflow_dispatch:
jobs:
build-push:
runs-on: ubuntu-latest
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Log in to Gitea Container Registry
uses: docker/login-action@v3
with:
registry: gitea.setlock.net
username: ${{ secrets.USER }}
password: ${{ secrets.TOKEN }}
- name: Extract Tag Name (if any)
id: get_tag
run: |
echo "GIT_TAG=${GITHUB_REF##*/}" >> $GITHUB_ENV
- name: Build and Push Docker Image
uses: docker/build-push-action@v5
with:
context: ./tools
push: true
platforms: linux/amd64
tags: |
gitea.setlock.net/shaun/dev-container:latest
gitea.setlock.net/shaun/dev-container:${{ env.GIT_TAG }}

View File

@@ -0,0 +1,47 @@
# .gitea/workflows/docker-build-push.yml
name: Build and Push Docker Image
on:
push:
branches:
- main
- master
tags:
- "v*" # triggers when you push a tag like v1.0.0
paths:
- "**/Dockerfile"
workflow_dispatch: # manual run button
jobs:
build-and-push:
runs-on: ubuntu-latest
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Log in to Gitea Container Registry
uses: docker/login-action@v3
with:
registry: gitea.example.com
username: ${{ secrets.GITEA_USERNAME }}
password: ${{ secrets.GITEA_TOKEN }}
- name: Extract Tag Name (if any)
id: get_tag
run: |
echo "GIT_TAG=${GITHUB_REF##*/}" >> $GITHUB_ENV
- name: Build and Push Docker Image
uses: docker/build-push-action@v5
with:
context: ./nvim/tools
push: true
platforms: linux/amd64,linux/arm64
tags: |
https://gitea.setlock.net/shaun/dotfiles:latest
https://gitea.setlock.net/shaun/dotfiles:${{ env.GIT_TAG }}

View File

@@ -1,31 +0,0 @@
name: Build and Push Docker Image
on:
schedule:
- cron: "0 2 * * *"
workflow_dispatch:
jobs:
build-push:
runs-on: ubuntu-latest
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Log in to Gitea Container Registry
uses: docker/login-action@v3
with:
registry: gitea.setlock.net
username: ${{ secrets.USER }}
password: ${{ secrets.TOKEN }}
- name: Build and Push Docker Image
uses: docker/build-push-action@v5
with:
context: ./tools
push: true
platforms: linux/amd64
tags: |
gitea.setlock.net/shaun/dev-container:nightly

View File

@@ -1,5 +0,0 @@
# Defined in - @ line 1
function dev --wraps='docker exec -it mydev fish' --description 'alias dev=docker exec -it mydev fish'
docker exec -it mydev fish
end

View File

@@ -1,5 +0,0 @@
# Defined in - @ line 1
function oo --wraps='nvim ~/Obsidian' --description 'alias oo=nvim ~/Obsidian'
nvim ~/Obsidian
end

View File

@@ -1,5 +0,0 @@
# Defined in - @ line 1
function v --wraps='nvim .' --description 'alias v=nvim .'
nvim .
end

View File

@@ -1,5 +0,0 @@
# Defined in - @ line 1
function vh --wraps='nvim ~/' --description 'alias vh=nvim ~/'
nvim ~/
end

View File

@@ -1,2 +0,0 @@
config:
MD013: false

View File

@@ -1,26 +0,0 @@
return {
"saghen/blink.cmp",
opts = function(_, opts)
local completion_toggle = Snacks.toggle({
name = "Completion",
get = function()
return vim.b.completion
end,
set = function(state)
vim.b.completion = state
end,
})
local function toggle_completion()
require("blink.cmp").hide()
completion_toggle:toggle()
end
vim.keymap.set({ "i", "n" }, "<C-Space>", toggle_completion, { desc = "Toggle Completion" })
opts.enabled = function()
return vim.b.completion
end
return opts
end,
}

View File

@@ -1,12 +0,0 @@
local HOME = os.getenv("HOME")
return {
"mfussenegger/nvim-lint",
optional = true,
opts = {
linters = {
["markdownlint-cli2"] = {
args = { "--config", HOME .. "/.config/nvim/lua/plugins/.markdownlint-cli2.yaml", "--" },
},
},
},
}

View File

@@ -16,9 +16,9 @@ RUN useradd -m -u 1000 -s /usr/bin/fish shaun
# Install required software # Install required software
RUN apt-get update && apt-get -y install \ RUN apt-get update && apt-get -y install \
curl fzf ripgrep tree git xclip python3 python3-pip python3-venv nodejs npm \ curl fzf ripgrep tree git xclip python3 python3-pip python3-venv nodejs npm \
tzdata ninja-build gettext libtool libtool-bin autoconf automake cmake g++ \ tzdata ninja-build gettext libtool libtool-bin autoconf automake cmake g++ \
pkg-config zip unzip fish tmux pkg-config zip unzip fish tmux
# Cooperate Neovim with Python 3. # Cooperate Neovim with Python 3.
RUN python3 -m pip install --break-system-packages --root-user-action ignore pynvim RUN python3 -m pip install --break-system-packages --root-user-action ignore pynvim
@@ -28,9 +28,9 @@ RUN npm i -g neovim
# Install Neovim from source. # Install Neovim from source.
RUN mkdir -p /tmp/neovim-src && \ RUN mkdir -p /tmp/neovim-src && \
git clone --depth 1 --branch stable https://github.com/neovim/neovim /tmp/neovim-src && \ git clone --depth 1 --branch stable https://github.com/neovim/neovim /tmp/neovim-src && \
cd /tmp/neovim-src && make -j$(nproc) && make install && \ cd /tmp/neovim-src && make -j$(nproc) && make install && \
rm -rf /tmp/neovim-src rm -rf /tmp/neovim-src
# Clone configuration files. # Clone configuration files.
USER shaun USER shaun
@@ -48,7 +48,7 @@ RUN ln -s /home/shaun/dotfiles/tmux /home/shaun/.config
# Install tmux plugin manager. # Install tmux plugin manager.
RUN git clone https://github.com/tmux-plugins/tpm /home/shaun/.config/tmux/plugins/tpm && \ RUN git clone https://github.com/tmux-plugins/tpm /home/shaun/.config/tmux/plugins/tpm && \
/home/shaun/.config/tmux/plugins/tpm/scripts/install_plugins.sh /home/shaun/.config/tmux/plugins/tpm/scripts/install_plugins.sh
# Get oh-my-fish and bob-the-fish installed. # Get oh-my-fish and bob-the-fish installed.
RUN curl https://raw.githubusercontent.com/oh-my-fish/oh-my-fish/master/bin/install > install RUN curl https://raw.githubusercontent.com/oh-my-fish/oh-my-fish/master/bin/install > install
@@ -63,12 +63,11 @@ USER root
RUN usermod --shell /usr/bin/fish shaun RUN usermod --shell /usr/bin/fish shaun
# Set workspace directory # Set workspace directory
RUN mkdir -p /workspace RUN mkdir -p /workspace && chown shaun:shaun /workspace
RUN chown -R shaun:shaun /workspace WORKDIR /workspace
# Switch to non-root user # Switch to non-root user
USER shaun USER shaun
WORKDIR /workspace
# Avoid container exit. # Avoid container exit.
CMD ["tail", "-f", "/dev/null"] CMD ["tail", "-f", "/dev/null"]

View File

@@ -0,0 +1,9 @@
version: "3"
services:
nv:
container_name: nv
image: shaun/neovim:latest
user: "1000:1000"
restart: unless-stopped
volumes:
- ~/code:/root/workspace

View File

@@ -1,8 +0,0 @@
version: "3"
services:
mydev:
container_name: mydev
image: gitea.setlock.net/shaun/dev-container:latest
restart: unless-stopped
volumes:
- /home/shaun:/workspace