aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorXander Swan <email>2025-12-03 10:00:41 -0500
committerXander Swan <email>2025-12-03 10:00:41 -0500
commit9c504cd8639c82d476c2af41796743185ffd706a (patch)
treedca0f9f7c5347b7f0798b13d99b1b0df4d9a4ef0
parentceb1360704f390862eecbd405d3837f9c42f1baa (diff)
Add i3
-rw-r--r--.config/alacritty/alacritty.yml8
-rw-r--r--.config/i3/config238
-rw-r--r--.config/i3/i3blocks.conf45
-rw-r--r--.config/i3/music.lua18
-rw-r--r--.config/i3/music.sh20
-rw-r--r--.config/i3/shellutils.lua16
-rw-r--r--.config/nvim/lua/lsp.lua12
-rw-r--r--.config/nvim/plugin/packer_compiled.lua169
-rw-r--r--update.sh3
9 files changed, 514 insertions, 15 deletions
diff --git a/.config/alacritty/alacritty.yml b/.config/alacritty/alacritty.yml
index e563273..8670648 100644
--- a/.config/alacritty/alacritty.yml
+++ b/.config/alacritty/alacritty.yml
@@ -29,13 +29,13 @@ colors:
font:
normal:
- family: "Less Perfect DOS VGA"
+ family: "Maple Mono NF"
style: Regular
bold:
- family: "Less Perfect DOS VGA"
+ family: "Maple Mono NF"
style: Bold
italic:
- family: "Less Perfect DOS VGA"
+ family: "Maple Mono NF"
style: "Italic"
size: 12.0
@@ -45,4 +45,4 @@ mouse_bindings:
cursor:
style: Block
-draw_bold_text_with_bright_colors: true
+draw_bold_text_with_bright_colors: true \ No newline at end of file
diff --git a/.config/i3/config b/.config/i3/config
new file mode 100644
index 0000000..86a0ee1
--- /dev/null
+++ b/.config/i3/config
@@ -0,0 +1,238 @@
+# i3 config file (v4)
+#
+# Please see https://i3wm.org/docs/userguide.html for a complete reference!
+#
+# This config file uses keycodes (bindsym) and was written for the QWERTY
+# layout.
+#
+# To get a config file with the same key positions, but for your current
+# layout, use the i3-config-wizard
+#
+
+# Font for window titles. Will also be used by the bar unless a different font
+# is used in the bar {} block below.
+font pango:Maple Mono NF 8
+
+# This font is widely installed, provides lots of unicode glyphs, right-to-left
+# text rendering and scalability on retina/hidpi displays (thanks to pango).
+#font pango:DejaVu Sans Mono 8
+
+# Start XDG autostart .desktop files using dex. See also
+# https://wiki.archlinux.org/index.php/XDG_Autostart
+exec --no-startup-id dex --autostart --environment i3
+
+# The combination of xss-lock, nm-applet and pactl is a popular choice, so
+# they are included here as an example. Modify as you see fit.
+
+# xss-lock grabs a logind suspend inhibit lock and will use i3lock to lock the
+# screen before suspend. Use loginctl lock-session to lock your screen.
+exec --no-startup-id xss-lock --transfer-sleep-lock -- i3lock --nofork
+
+# NetworkManager is the most popular way to manage wireless networks on Linux,
+# and nm-applet is a desktop environment-independent system tray GUI for it.
+exec --no-startup-id nm-applet
+
+exec setxkbmap -option "caps:super"
+exec nitrogen --restore
+exec alacritty --hold -e sudo pacman -Syu
+
+# Use pactl to adjust volume in PulseAudio.
+set $refresh_i3status killall -SIGUSR1 i3status
+bindsym XF86AudioRaiseVolume exec --no-startup-id pactl set-sink-volume @DEFAULT_SINK@ +2% && $refresh_i3status
+bindsym XF86AudioLowerVolume exec --no-startup-id pactl set-sink-volume @DEFAULT_SINK@ -2% && $refresh_i3status
+bindsym XF86AudioMute exec --no-startup-id pactl set-sink-mute @DEFAULT_SINK@ toggle && $refresh_i3status
+bindsym XF86AudioMicMute exec --no-startup-id pactl set-source-mute @DEFAULT_SOURCE@ toggle && $refresh_i3status
+bindsym XF86AudioPause exec --no-startup-id playerctl play-pause && $refresh_i3status
+bindsym XF86AudioNext exec --no-startup-id playerctl next && $refresh_i3status
+bindsym XF86AudioPrev exec --no-startup-id playerctl previous && $refresh_i3status
+
+# use these keys for focus, movement, and resize directions when reaching for
+# the arrows is not convenient
+set $up j
+set $down k
+set $left l
+set $right semicolon
+set $mod Mod4
+
+# use Mouse+$mod to drag floating windows to their wanted position
+floating_modifier $mod
+
+# move tiling windows via drag & drop by left-clicking into the title bar,
+# or left-clicking anywhere into the window while holding the floating modifier.
+tiling_drag modifier titlebar
+
+# start a terminal
+bindsym $mod+Return exec alacritty
+
+bindsym Print exec flameshot gui
+
+# kill focused window
+bindsym $mod+Shift+q kill
+
+# start dmenu (a program launcher)
+bindsym $mod+d exec --no-startup-id rofi -show drun
+# A more modern dmenu replacement is rofi:
+# bindsym $mod+d exec "rofi -modi drun,run -show drun"
+# There also is i3-dmenu-desktop which only displays applications shipping a
+# .desktop file. It is a wrapper around dmenu, so you need that installed.
+# bindsym $mod+d exec --no-startup-id i3-dmenu-desktop
+
+# change focus
+bindsym $mod+$left focus left
+bindsym $mod+$down focus down
+bindsym $mod+$up focus up
+bindsym $mod+$right focus right
+
+# alternatively, you can use the cursor keys:
+bindsym $mod+Left focus left
+bindsym $mod+Down focus down
+bindsym $mod+Up focus up
+bindsym $mod+Right focus right
+
+# move focused window
+bindsym $mod+Shift+$left move left
+bindsym $mod+Shift+$down move down
+bindsym $mod+Shift+$up move up
+bindsym $mod+Shift+$right move right
+
+# alternatively, you can use the cursor keys:
+bindsym $mod+Shift+Left move left
+bindsym $mod+Shift+Down move down
+bindsym $mod+Shift+Up move up
+bindsym $mod+Shift+Right move right
+
+# split in horizontal orientation
+bindsym $mod+h split h
+
+# split in vertical orientation
+bindsym $mod+v split v
+
+# enter fullscreen mode for the focused container
+bindsym $mod+f fullscreen toggle
+
+# change container layout (stacked, tabbed, toggle split)
+bindsym $mod+s layout stacking
+bindsym $mod+w layout tabbed
+bindsym $mod+e layout toggle split
+
+# toggle tiling / floating
+bindsym $mod+Shift+space floating toggle
+
+# change focus between tiling / floating windows
+bindsym $mod+space focus mode_toggle
+
+# focus the parent container
+bindsym $mod+a focus parent
+
+# focus the child container
+#bindsym $mod+d focus child
+
+# move the currently focused window to the scratchpad
+bindsym $mod+Shift+minus move scratchpad
+
+# Show the next scratchpad window or hide the focused scratchpad window.
+# If there are multiple scratchpad windows, this command cycles through them.
+bindsym $mod+minus scratchpad show
+
+# Define names for default workspaces for which we configure key bindings later on.
+# We use variables to avoid repeating the names in multiple places.
+set $ws1 "1"
+set $ws2 "2"
+set $ws3 "3"
+set $ws4 "4"
+set $ws5 "5"
+set $ws6 "6"
+set $ws7 "7"
+set $ws8 "8"
+set $ws9 "9"
+set $ws10 "10"
+
+# switch to workspace
+bindsym $mod+1 workspace number $ws1
+bindsym $mod+2 workspace number $ws2
+bindsym $mod+3 workspace number $ws3
+bindsym $mod+4 workspace number $ws4
+bindsym $mod+5 workspace number $ws5
+bindsym $mod+6 workspace number $ws6
+bindsym $mod+7 workspace number $ws7
+bindsym $mod+8 workspace number $ws8
+bindsym $mod+9 workspace number $ws9
+bindsym $mod+0 workspace number $ws10
+
+# move focused container to workspace
+bindsym $mod+Shift+1 move container to workspace number $ws1
+bindsym $mod+Shift+2 move container to workspace number $ws2
+bindsym $mod+Shift+3 move container to workspace number $ws3
+bindsym $mod+Shift+4 move container to workspace number $ws4
+bindsym $mod+Shift+5 move container to workspace number $ws5
+bindsym $mod+Shift+6 move container to workspace number $ws6
+bindsym $mod+Shift+7 move container to workspace number $ws7
+bindsym $mod+Shift+8 move container to workspace number $ws8
+bindsym $mod+Shift+9 move container to workspace number $ws9
+bindsym $mod+Shift+0 move container to workspace number $ws10
+
+# reload the configuration file
+bindsym $mod+Shift+c reload
+# restart i3 inplace (preserves your layout/session, can be used to upgrade i3)
+bindsym $mod+Shift+r restart
+# exit i3 (logs you out of your X session)
+bindsym $mod+Shift+e exec "i3-nagbar -t warning -m 'You pressed the exit shortcut. Do you really want to exit i3? This will end your X session.' -B 'Yes, exit i3' 'i3-msg exit'"
+
+# resize window (you can also use the mouse for that)
+mode "resize" {
+ # These bindings trigger as soon as you enter the resize mode
+
+ # Pressing left will shrink the window’s width.
+ # Pressing right will grow the window’s width.
+ # Pressing up will shrink the window’s height.
+ # Pressing down will grow the window’s height.
+ bindsym $left resize shrink width 10 px or 10 ppt
+ bindsym $down resize grow height 10 px or 10 ppt
+ bindsym $up resize shrink height 10 px or 10 ppt
+ bindsym $right resize grow width 10 px or 10 ppt
+
+ # same bindings, but for the arrow keys
+ bindsym Left resize shrink width 10 px or 10 ppt
+ bindsym Down resize grow height 10 px or 10 ppt
+ bindsym Up resize shrink height 10 px or 10 ppt
+ bindsym Right resize grow width 10 px or 10 ppt
+
+ # back to normal: Enter or Escape or $mod+r
+ bindsym Return mode "default"
+ bindsym Escape mode "default"
+ bindsym $mod+r mode "default"
+}
+
+bindsym $mod+r mode "resize"
+
+# Start i3bar to display a workspace bar (plus the system information i3status
+# finds out, if available)
+bar {
+ status_command i3blocks -c ~/.config/i3/i3blocks.conf
+ # mode hide
+
+ colors {
+ background #111111
+ statusline #ffffff
+ separator #666666
+
+ # border bg text
+ focused_workspace #ffffff #aaaaaa #444444
+ active_workspace #cccccc #888888 #444444
+ inactive_workspace #444444 #000000 #888888
+ urgent_workspace #2f343a #900000 #ffffff
+ binding_mode #2f343a #900000 #ffffff
+ }
+}
+
+#######################################################################
+# automatically start i3-config-wizard to offer the user to create a
+# keysym-based config which used their favorite modifier (alt or windows)
+#
+# i3-config-wizard will not launch if there already is a config file
+# in ~/.config/i3/config (or $XDG_CONFIG_HOME/i3/config if set) or
+# ~/.i3/config.
+#
+# Please remove the following exec line:
+#######################################################################
+exec i3-config-wizard
diff --git a/.config/i3/i3blocks.conf b/.config/i3/i3blocks.conf
new file mode 100644
index 0000000..981c368
--- /dev/null
+++ b/.config/i3/i3blocks.conf
@@ -0,0 +1,45 @@
+# Define the custom separator in global properties for boilerplate
+full_text=
+align=center
+separator=false
+separator_block_width=1
+
+[time]
+instance=ny
+TZ=America/New_York
+command=date +" %H:%M "
+interval=1
+background=#99FFFF
+color=#000000
+
+[date]
+instance=ny
+TZ=America/New_York
+command=date +" %y/%m/%d %b "
+interval=3600
+background=#999999
+color=#000000
+
+[packages]
+command=echo " PKGS: $(pacman -Q | wc -l) "
+interval=3600
+background=#FF9999
+color=#000000
+
+[volume]
+command=echo " VOLUME: $(pactl get-sink-volume @DEFAULT_SINK@ | awk -F"/" '{print $2}' | xargs) "
+interval=repeat
+background=#55CC77
+color=#000000
+
+[music]
+command=lua ~/.config/i3/music.lua
+interval=2
+background=#99FF99
+color=#000000
+
+[weather]
+command=echo " $(curl -Ss 'https://wttr.in?0&T&Q&M' | cut -c 16- | head -2 | xargs) "
+interval=3600
+background=#009999
+color=#000000
diff --git a/.config/i3/music.lua b/.config/i3/music.lua
new file mode 100644
index 0000000..1960f9b
--- /dev/null
+++ b/.config/i3/music.lua
@@ -0,0 +1,18 @@
+local shell_utils = require("shellutils")
+
+local status = shell_utils.get_output("playerctl status")
+local song = shell_utils.get_output("playerctl metadata title")
+local artist = shell_utils.get_output("playerctl metadata artist")
+local album = shell_utils.get_output("playerctl metadata album")
+
+if #album ~= 0 then
+ album = ("from %s "):format(album)
+end
+
+if status == "Playing" then
+ print((" Playing | %s by %s %s"):format(song, artist, album))
+elseif status == "Paused" then
+ print((" Paused | %s by %s %s"):format(song, artist, album))
+else
+ print((" Stopped "):format(status))
+end \ No newline at end of file
diff --git a/.config/i3/music.sh b/.config/i3/music.sh
new file mode 100644
index 0000000..d678ed1
--- /dev/null
+++ b/.config/i3/music.sh
@@ -0,0 +1,20 @@
+#!/bin/bash
+
+status=$(playerctl status)
+song=$(playerctl metadata title)
+album=" (`playerctl metadata album`)"
+
+if [ "$album" == " ()" ]
+then
+ album=""
+fi
+
+if [ $status = "Playing" ]
+then
+ echo " Playing | $song$album by $(playerctl metadata artist) "
+elif [ $status = "Paused" ]
+then
+ echo " Paused | $song$album by $(playerctl metadata artist) "
+else
+ echo " Stopped "
+fi \ No newline at end of file
diff --git a/.config/i3/shellutils.lua b/.config/i3/shellutils.lua
new file mode 100644
index 0000000..cb27943
--- /dev/null
+++ b/.config/i3/shellutils.lua
@@ -0,0 +1,16 @@
+local shell_utils = {}
+
+local temp_file_path = "/tmp/i3luacommandouput"
+
+function shell_utils.get_output(command)
+ os.execute(command .. " > " .. temp_file_path .. " 2> " .. temp_file_path)
+ local file = io.open(temp_file_path, "r")
+ if file == nil then
+ error("Can't read output.")
+ end
+ local output = file:read()
+ file:close()
+ return output or ""
+end
+
+return shell_utils \ No newline at end of file
diff --git a/.config/nvim/lua/lsp.lua b/.config/nvim/lua/lsp.lua
index 66574b1..3fa5f48 100644
--- a/.config/nvim/lua/lsp.lua
+++ b/.config/nvim/lua/lsp.lua
@@ -10,14 +10,4 @@ lsp.lua_ls.setup {
}
}
-lsp.ccls.setup {
- init_options = {
- compilationDatabaseDirectory = "build",
- index = {
- threads = 0,
- },
- clang = {
- excludeArgs = { "-frounding-math" },
- },
- }
-}
+lsp.clangd.setup {}
diff --git a/.config/nvim/plugin/packer_compiled.lua b/.config/nvim/plugin/packer_compiled.lua
new file mode 100644
index 0000000..e2d44c3
--- /dev/null
+++ b/.config/nvim/plugin/packer_compiled.lua
@@ -0,0 +1,169 @@
+-- Automatically generated packer.nvim plugin loader code
+
+if vim.api.nvim_call_function('has', {'nvim-0.5'}) ~= 1 then
+ vim.api.nvim_command('echohl WarningMsg | echom "Invalid Neovim version for packer.nvim! | echohl None"')
+ return
+end
+
+vim.api.nvim_command('packadd packer.nvim')
+
+local no_errors, error_msg = pcall(function()
+
+_G._packer = _G._packer or {}
+_G._packer.inside_compile = true
+
+local time
+local profile_info
+local should_profile = false
+if should_profile then
+ local hrtime = vim.loop.hrtime
+ profile_info = {}
+ time = function(chunk, start)
+ if start then
+ profile_info[chunk] = hrtime()
+ else
+ profile_info[chunk] = (hrtime() - profile_info[chunk]) / 1e6
+ end
+ end
+else
+ time = function(chunk, start) end
+end
+
+local function save_profiles(threshold)
+ local sorted_times = {}
+ for chunk_name, time_taken in pairs(profile_info) do
+ sorted_times[#sorted_times + 1] = {chunk_name, time_taken}
+ end
+ table.sort(sorted_times, function(a, b) return a[2] > b[2] end)
+ local results = {}
+ for i, elem in ipairs(sorted_times) do
+ if not threshold or threshold and elem[2] > threshold then
+ results[i] = elem[1] .. ' took ' .. elem[2] .. 'ms'
+ end
+ end
+ if threshold then
+ table.insert(results, '(Only showing plugins that took longer than ' .. threshold .. ' ms ' .. 'to load)')
+ end
+
+ _G._packer.profile_output = results
+end
+
+time([[Luarocks path setup]], true)
+local package_path_str = "/home/xswan/.cache/nvim/packer_hererocks/2.1.0-beta3/share/lua/5.1/?.lua;/home/xswan/.cache/nvim/packer_hererocks/2.1.0-beta3/share/lua/5.1/?/init.lua;/home/xswan/.cache/nvim/packer_hererocks/2.1.0-beta3/lib/luarocks/rocks-5.1/?.lua;/home/xswan/.cache/nvim/packer_hererocks/2.1.0-beta3/lib/luarocks/rocks-5.1/?/init.lua"
+local install_cpath_pattern = "/home/xswan/.cache/nvim/packer_hererocks/2.1.0-beta3/lib/lua/5.1/?.so"
+if not string.find(package.path, package_path_str, 1, true) then
+ package.path = package.path .. ';' .. package_path_str
+end
+
+if not string.find(package.cpath, install_cpath_pattern, 1, true) then
+ package.cpath = package.cpath .. ';' .. install_cpath_pattern
+end
+
+time([[Luarocks path setup]], false)
+time([[try_loadstring definition]], true)
+local function try_loadstring(s, component, name)
+ local success, result = pcall(loadstring(s), name, _G.packer_plugins[name])
+ if not success then
+ vim.schedule(function()
+ vim.api.nvim_notify('packer.nvim: Error running ' .. component .. ' for ' .. name .. ': ' .. result, vim.log.levels.ERROR, {})
+ end)
+ end
+ return result
+end
+
+time([[try_loadstring definition]], false)
+time([[Defining packer_plugins]], true)
+_G.packer_plugins = {
+ ["beacon.nvim"] = {
+ loaded = true,
+ path = "/home/xswan/.local/share/nvim/site/pack/packer/start/beacon.nvim",
+ url = "https://github.com/DanilaMihailov/beacon.nvim"
+ },
+ ["gv.vim"] = {
+ loaded = true,
+ path = "/home/xswan/.local/share/nvim/site/pack/packer/start/gv.vim",
+ url = "https://github.com/junegunn/gv.vim"
+ },
+ indentLine = {
+ loaded = true,
+ path = "/home/xswan/.local/share/nvim/site/pack/packer/start/indentLine",
+ url = "https://github.com/Yggdroot/indentLine"
+ },
+ ["lualine.nvim"] = {
+ loaded = true,
+ path = "/home/xswan/.local/share/nvim/site/pack/packer/start/lualine.nvim",
+ url = "https://github.com/nvim-lualine/lualine.nvim"
+ },
+ ["nvim-autopairs"] = {
+ loaded = true,
+ path = "/home/xswan/.local/share/nvim/site/pack/packer/start/nvim-autopairs",
+ url = "https://github.com/windwp/nvim-autopairs"
+ },
+ ["nvim-lspconfig"] = {
+ loaded = true,
+ path = "/home/xswan/.local/share/nvim/site/pack/packer/start/nvim-lspconfig",
+ url = "https://github.com/neovim/nvim-lspconfig"
+ },
+ ["nvim-tree.lua"] = {
+ loaded = true,
+ path = "/home/xswan/.local/share/nvim/site/pack/packer/start/nvim-tree.lua",
+ url = "https://github.com/kyazdani42/nvim-tree.lua"
+ },
+ ["nvim-web-devicons"] = {
+ loaded = true,
+ path = "/home/xswan/.local/share/nvim/site/pack/packer/start/nvim-web-devicons",
+ url = "https://github.com/kyazdani42/nvim-web-devicons"
+ },
+ ["plenary.nvim"] = {
+ loaded = true,
+ path = "/home/xswan/.local/share/nvim/site/pack/packer/start/plenary.nvim",
+ url = "https://github.com/nvim-lua/plenary.nvim"
+ },
+ tagbar = {
+ loaded = true,
+ path = "/home/xswan/.local/share/nvim/site/pack/packer/start/tagbar",
+ url = "https://github.com/majutsushi/tagbar"
+ },
+ ["telescope.nvim"] = {
+ loaded = true,
+ path = "/home/xswan/.local/share/nvim/site/pack/packer/start/telescope.nvim",
+ url = "https://github.com/nvim-telescope/telescope.nvim"
+ },
+ ["terminal.nvim"] = {
+ loaded = true,
+ path = "/home/xswan/.local/share/nvim/site/pack/packer/start/terminal.nvim",
+ url = "https://github.com/rebelot/terminal.nvim"
+ },
+ ["tomorrow-theme"] = {
+ loaded = true,
+ path = "/home/xswan/.local/share/nvim/site/pack/packer/start/tomorrow-theme",
+ url = "https://github.com/chriskempson/tomorrow-theme"
+ },
+ ["vim-fugitive"] = {
+ loaded = true,
+ path = "/home/xswan/.local/share/nvim/site/pack/packer/start/vim-fugitive",
+ url = "https://github.com/tpope/vim-fugitive"
+ },
+ ["vim-startify"] = {
+ loaded = true,
+ path = "/home/xswan/.local/share/nvim/site/pack/packer/start/vim-startify",
+ url = "https://github.com/mhinz/vim-startify"
+ }
+}
+
+time([[Defining packer_plugins]], false)
+
+_G._packer.inside_compile = false
+if _G._packer.needs_bufread == true then
+ vim.cmd("doautocmd BufRead")
+end
+_G._packer.needs_bufread = false
+
+if should_profile then save_profiles() end
+
+end)
+
+if not no_errors then
+ error_msg = error_msg:gsub('"', '\\"')
+ vim.api.nvim_command('echohl ErrorMsg | echom "Error in packer_compiled: '..error_msg..'" | echom "Please check your config for correctness" | echohl None')
+end
diff --git a/update.sh b/update.sh
index 6198d05..4eea3c1 100644
--- a/update.sh
+++ b/update.sh
@@ -8,3 +8,6 @@ cp -r ~/.config/alacritty ./.config/
cp -r ~/.config/nvim ./.config/
rm -rf ./.config/nvim/site/
+# i3
+
+cp -r ~/.config/i3 ./.config