Skip to content

Instantly share code, notes, and snippets.

@aduh95
Last active October 20, 2025 18:54
Show Gist options
  • Save aduh95/affe5ba977acaaa8f480bc7d98161ec9 to your computer and use it in GitHub Desktop.
Save aduh95/affe5ba977acaaa8f480bc7d98161ec9 to your computer and use it in GitHub Desktop.
Nix Home Manager file

Getting started

On macOS

  1. Install Nix.

  2. Install Home manager – I recommend using the unstable channel version.

  3. Update ~/.config/home-manager/home.nix to something like (don't forget to change the home.username value):

    { config, lib, pkgs, ... }:
    
    let
      gist = builtins.fetchurl {
        url = "https://gist.github.com/aduh95/affe5ba977acaaa8f480bc7d98161ec9/raw/home.nix";
        sha256 = lib.fakeHash;
      };
      importedGist = (import "${gist}") { inherit config; inherit lib; inherit pkgs; };
    in
    {
      # Home Manager needs a bit of information about you and the
      # paths it should manage.
      home.username = "TODO";
      home.homeDirectory = "/Users/${home.username}";
      home.stateVersion = importedGist.home.stateVersion;
      home.packages = importedGist.home.packages;
    
      home.sessionPath = [
        "/nix/var/nix/profiles/default/bin"
        "$HOME/.nix-profile/bin"
      ];
      home.sessionVariables = {
        # Here you can define env variables if needed
      };
    
      inherit (importedGist) programs;
    }
  4. Run nix-channel --update && home-manager switch. It should complain about unmatched hash. Replace lib.fakeHash by the correct hash on line 6.

  5. Run nix-channel --update && home-manager switch again.

  6. Open a new shell. Voilà, you're all set.

On NixOS

Edit /etc/nixos/configuration.nix with (replace TODO with your actual user handle):

let
  home-manager = builtins.fetchTarball https://github.com/nix-community/home-manager/archive/release-24.11.tar.gz;
  gist = builtins.fetchurl {
    url = "https://gist.github.com/aduh95/affe5ba977acaaa8f480bc7d98161ec9/raw/home.nix";
    sha256 = pkgs.lib.fakeHash;
  };
in
{
    # …
    imports = [
        # …
        (import "${home-manager}/nixos")
    ];
    # …
    home-manager.users.TODO = import "${gist}";
}

Run nixos-build switch, replace the hash, re-run it, and voilà.

{ config, lib, pkgs, ... }:
let
luaConfig = builtins.fetchurl {
url = "https://gist.github.com/aduh95/affe5ba977acaaa8f480bc7d98161ec9/raw/f927b43b8d3c82d47756cec60d57ba98410d90c3/nvim-config.lua";
sha256 = "1s6s39i1lqrspy3g10bqkgv0fnwkkss6rrhmpgpi8q14lqhpif92";
};
in
{
nixpkgs.config.allowUnfreePredicate = pkg: builtins.elem (lib.getName pkg) [
"mongodb-ce"
"terraform"
];
# This value determines the Home Manager release that your
# configuration is compatible with. This helps avoid breakage
# when a new Home Manager release introduces backwards
# incompatible changes.
#
# You can update Home Manager without changing this value. See
# the Home Manager release notes for a list of state version
# changes in each release.
home.stateVersion = "25.05";
home.packages = [
pkgs.curl
pkgs.jq # JSON stream parser
pkgs.mpv-unwrapped # VLC like
pkgs.neovide
pkgs.nodejs-slim
pkgs.ollama # LLM stuff
pkgs.transmission_4 # Torrenting
# Fonts
pkgs.fira-code
] ++ pkgs.lib.optionals (! pkgs.stdenv.buildPlatform.isDarwin) [
# Packages that are included in xcode-select
pkgs.python3
] ++ [
(pkgs.writeShellScriptBin "npx" "exec corepack npx \"$@\"")
];
# Let Home Manager install and manage itself.
programs.home-manager.enable = true;
programs.git = {
enable = ! pkgs.stdenv.buildPlatform.isDarwin; # It's part of xcode-select
aliases = {
lcm = "log -1 --pretty=%s";
lg = "lg1";
lg1 = "lg1-specific --all";
lg2 = "lg2-specific --all";
lg3 = "lg3-specific --all";
f = "fetch";
fu = "fetch upstream";
fum = "fetch upstream main";
pu = "push upstream";
rfh = "!git difftool -x 'code --wait --diff' && git rfhh";
rfhh = "reset FETCH_HEAD --hard";
rfhia = "rebase FETCH_HEAD -i";
rfhi = "rebase FETCH_HEAD -i --autosquash";
cf = "commit --fixup";
cfh = "commit --fixup HEAD";
ca = "commit --amend --no-edit";
lg1-specific = "log --graph --abbrev-commit --decorate --format=format:'%G? %C(bold blue)%h%C(reset) - %C(bold green)(%ar)%C(reset) %C(white)%s%C(reset) %C(dim white)- %an%C(reset)%C(auto)%d%C(reset)'";
lg2-specific = "log --graph --abbrev-commit --decorate --format=format:'%C(bold blue)%h%C(reset) - %C(bold cyan)%aD%C(reset) %C(bold green)(%ar)%C(reset)%C(auto)%d%C(reset)%n'' %C(white)%s%C(reset) %C(dim white)- %an%C(reset)'";
lg3-specific = "log --graph --abbrev-commit --decorate --format=format:'%C(bold blue)%h%C(reset) - %C(bold cyan)%aD%C(reset) %C(bold green)(%ar)%C(reset) %C(bold cyan)(committed: %cD)%C(reset) %C(auto)%d%C(reset)%n'' %C(white)%s%C(reset)%n'' %C(dim white)- %an <%ae> %C(reset) %C(dim white)(committer: %cn <%ce>, signer: %GS)%C(reset)'";
};
extraConfig = {
apply = {
whitespace = "fix";
};
core = {
autocrlf = "false";
};
init = {
defaultBranch = "main";
};
};
};
programs.neovim = {
enable = true;
defaultEditor = true;
coc = {
enable = true;
settings = {
"git.showCommitInFloating" = true;
};
};
plugins = with pkgs.vimPlugins; [
auto-session
bufresize-nvim
catppuccin-nvim
coc-css
coc-git
coc-html
coc-json
coc-markdownlint
coc-sh
coc-tsserver
diffview-nvim
neo-tree-nvim
neogit
nvim-treesitter.withAllGrammars
telescope-nvim
vim-nix
];
viAlias = true;
extraLuaConfig = builtins.readFile luaConfig;
};
programs.direnv = {
enable = true;
enableZshIntegration = true;
nix-direnv.enable = true;
};
programs.gh = {
enable = true;
settings = {
# Workaround for https://github.com/nix-community/home-manager/issues/4744
version = 1;
editor = if pkgs.stdenv.buildPlatform.isDarwin then "vi" else "${pkgs.neovim}";
};
};
programs.gpg = {
enable = true;
settings = {
auto-key-retrieve = true;
no-emit-version = true;
};
};
programs.vscode = {
enable = true;
package = pkgs.vscodium;
profiles.default = {
extensions = with pkgs.vscode-extensions; [
bbenoist.nix
github.vscode-github-actions
ph-hawkins.arc-plus
streetsidesoftware.code-spell-checker
streetsidesoftware.code-spell-checker-french
tamasfe.even-better-toml
tomoki1207.pdf
vscodevim.vim
waderyan.gitblame
];
keybindings = [
{
key = "alt+enter";
command = "editor.action.quickFix";
when = "editorHasCodeActionsProvider && editorTextFocus && !editorReadonly";
}
{
key = "cmd+shift+l";
command = "workbench.action.editor.changeLanguageMode";
}
{
key = "ctrl+shift+alt+`";
command = "workbench.action.terminal.new";
}
{
key = "ctrl+shift+`";
command = "-workbench.action.terminal.new";
}
{
key = "ctrl+shift+`";
command = "workbench.action.terminal.focus";
}
];
userSettings = {
"cSpell.language" = "en,fr";
"diffEditor.ignoreTrimWhitespace" = false;
"editor.fontFamily" = "'Fira Code'";
"editor.fontLigatures" = true;
"editor.fontSize" = 20;
"editor.inlineSuggest.enabled" = true;
"editor.lineNumbers" = "on";
"editor.mouseWheelZoom" = false;
"editor.renderLineHighlight" = "gutter";
"files.autoSave" = "onFocusChange";
"git.allowNoVerifyCommit" = true;
"git.branchProtectionPrompt" = "alwaysCommit";
"git.enableStatusBarSync" = false;
"git.inputValidation" = true;
"git.pullTags" = false;
"git.terminalAuthentication" = false;
"gitblame.delayBlame" = 500;
"gitblame.inlineMessageEnabled" = true;
"terminal.integrated.fontSize" = 16;
"typescript.updateImportsOnFileMove.enabled" = "never";
"window.autoDetectColorScheme" = true;
"window.zoomLevel" = -2;
"workbench.colorTheme" = "Arc+ (Dark Monochrome)";
"workbench.preferredDarkColorTheme" = "Arc+ (Dark Monochrome)";
# Disabling auto-updates, updates should come from Nix
"extensions.autoCheckUpdates" = false;
"extensions.autoUpdate" = false;
"update.mode" = "none";
};
};
};
programs.zsh = {
enable = true;
autosuggestion = {
enable = true;
};
defaultKeymap = "viins";
oh-my-zsh = {
enable = true;
theme = "robbyrussell";
};
syntaxHighlighting = {
enable = true;
};
sessionVariables = {};
shellAliases = {
# Frequent typos
gti = "git";
igt = "git";
flush-dns = if pkgs.stdenv.buildPlatform.isDarwin then "sudo killall -HUP mDNSResponder" else "sudo resolvectl flush-caches";
notif = if pkgs.stdenv.buildPlatform.isDarwin then "osascript -e 'display notification \"Command exited with code '\$?'\" with title \"Done\"'" else "false";
toggle-dm = if pkgs.stdenv.buildPlatform.isDarwin then "osascript -e 'tell app \"System Events\" to tell appearance preferences to set dark mode to not dark mode'" else "false";
# Corepack aliases (for Node.js package manager versioning)
pnpm = "corepack pnpm";
yarn = "corepack yarn";
# Update all global dependencies
maj = "nix-channel --update && home-manager switch";
remote-node-push-cmd = "awk -F: '{ print \"git push [email protected]:\" $1 \"/node.git +HEAD:refs/heads/\" $2 }' <<<";
};
initContent = ''
gitpushto() {
remote=$1
branch=$2
shift 2
git push "$remote" "HEAD:refs/heads/$branch" $@
}
gitpushtoGH() {
remote="''${1%%:*}"
branch="''${1#*:}"
shift
gitpushto "$remote" "$branch" $@
}
npm() {
command npm "$@" || {
EXIT_CODE=$?
[ "$EXIT_CODE" = 127 ] && corepack npm "$@" || return "$EXIT_CODE"
}
}
bindkey -v
'';
};
}
vim.opt.number = true
vim.opt.relativenumber = true
-- https://raw.githubusercontent.com/neoclide/coc.nvim/master/doc/coc-example-config.lua
-- Some servers have issues with backup files, see #649
vim.opt.backup = false
vim.opt.writebackup = false
-- Having longer updatetime (default is 4000 ms = 4s) leads to noticeable
-- delays and poor user experience
vim.opt.updatetime = 300
-- Always show the signcolumn, otherwise it would shift the text each time
-- diagnostics appeared/became resolved
vim.opt.signcolumn = "yes"
vim.o.sessionoptions="blank,buffers,curdir,folds,help,tabpages,winsize,winpos,terminal,localoptions"
local keyset = vim.keymap.set
-- Autocomplete
function _G.check_back_space()
local col = vim.fn.col('.') - 1
return col == 0 or vim.fn.getline('.'):sub(col, col):match('%s') ~= nil
end
-- Use Tab for trigger completion with characters ahead and navigate
-- NOTE: There's always a completion item selected by default, you may want to enable
-- no select by setting `"suggest.noselect": true` in your configuration file
-- NOTE: Use command ':verbose imap <tab>' to make sure Tab is not mapped by
-- other plugins before putting this into your config
local opts = {silent = true, noremap = true, expr = true, replace_keycodes = false}
keyset("i", "<TAB>", 'coc#pum#visible() ? coc#pum#next(1) : v:lua.check_back_space() ? "<TAB>" : coc#refresh()', opts)
keyset("i", "<S-TAB>", [[coc#pum#visible() ? coc#pum#prev(1) : "\<C-h>"]], opts)
-- Make <CR> to accept selected completion item or notify coc.nvim to format
-- <C-g>u breaks current undo, please make your own choice
keyset("i", "<cr>", [[coc#pum#visible() ? coc#pum#confirm() : "\<C-g>u\<CR>\<c-r>=coc#on_enter()\<CR>"]], opts)
-- Use <c-j> to trigger snippets
keyset("i", "<c-j>", "<Plug>(coc-snippets-expand-jump)")
-- Use <c-space> to trigger completion
keyset("i", "<c-space>", "coc#refresh()", {silent = true, expr = true})
-- Use `[g` and `]g` to navigate diagnostics
-- Use `:CocDiagnostics` to get all diagnostics of current buffer in location list
keyset("n", "[g", "<Plug>(coc-diagnostic-prev)", {silent = true})
keyset("n", "]g", "<Plug>(coc-diagnostic-next)", {silent = true})
-- GoTo code navigation
keyset("n", "gd", "<Plug>(coc-definition)", {silent = true})
keyset("n", "gy", "<Plug>(coc-type-definition)", {silent = true})
keyset("n", "gi", "<Plug>(coc-implementation)", {silent = true})
keyset("n", "gr", "<Plug>(coc-references)", {silent = true})
-- Use K to show documentation in preview window
function _G.show_docs()
local cw = vim.fn.expand('<cword>')
if vim.fn.index({'vim', 'help'}, vim.bo.filetype) >= 0 then
vim.api.nvim_command('h ' .. cw)
elseif vim.api.nvim_eval('coc#rpc#ready()') then
vim.fn.CocActionAsync('doHover')
else
vim.api.nvim_command('!' .. vim.o.keywordprg .. ' ' .. cw)
end
end
keyset("n", "K", '<CMD>lua _G.show_docs()<CR>', {silent = true})
-- Highlight the symbol and its references on a CursorHold event(cursor is idle)
vim.api.nvim_create_augroup("CocGroup", {})
vim.api.nvim_create_autocmd("CursorHold", {
group = "CocGroup",
command = "silent call CocActionAsync('highlight')",
desc = "Highlight symbol under cursor on CursorHold"
})
-- Symbol renaming
keyset("n", "<leader>rn", "<Plug>(coc-rename)", {silent = true})
-- Formatting selected code
keyset("x", "<leader>f", "<Plug>(coc-format-selected)", {silent = true})
keyset("n", "<leader>f", "<Plug>(coc-format-selected)", {silent = true})
-- Apply codeAction to the selected region
-- Example: `<leader>aap` for current paragraph
local opts = {silent = true, nowait = true}
keyset("x", "<leader>a", "<Plug>(coc-codeaction-selected)", opts)
keyset("n", "<leader>a", "<Plug>(coc-codeaction-selected)", opts)
-- Remap keys for apply code actions at the cursor position.
keyset("n", "<leader>ac", "<Plug>(coc-codeaction-cursor)", opts)
-- Remap keys for apply source code actions for current file.
keyset("n", "<leader>as", "<Plug>(coc-codeaction-source)", opts)
-- Apply the most preferred quickfix action on the current line.
keyset("n", "<leader>qf", "<Plug>(coc-fix-current)", opts)
-- Remap keys for apply refactor code actions.
keyset("n", "<leader>re", "<Plug>(coc-codeaction-refactor)", { silent = true })
keyset("x", "<leader>r", "<Plug>(coc-codeaction-refactor-selected)", { silent = true })
keyset("n", "<leader>r", "<Plug>(coc-codeaction-refactor-selected)", { silent = true })
-- Run the Code Lens actions on the current line
keyset("n", "<leader>cl", "<Plug>(coc-codelens-action)", opts)
-- Map function and class text objects
-- NOTE: Requires 'textDocument.documentSymbol' support from the language server
keyset("x", "if", "<Plug>(coc-funcobj-i)", opts)
keyset("o", "if", "<Plug>(coc-funcobj-i)", opts)
keyset("x", "af", "<Plug>(coc-funcobj-a)", opts)
keyset("o", "af", "<Plug>(coc-funcobj-a)", opts)
keyset("x", "ic", "<Plug>(coc-classobj-i)", opts)
keyset("o", "ic", "<Plug>(coc-classobj-i)", opts)
keyset("x", "ac", "<Plug>(coc-classobj-a)", opts)
keyset("o", "ac", "<Plug>(coc-classobj-a)", opts)
-- Remap <C-f> and <C-b> to scroll float windows/popups
---@diagnostic disable-next-line: redefined-local
local opts = {silent = true, nowait = true, expr = true}
keyset("n", "<C-f>", 'coc#float#has_scroll() ? coc#float#scroll(1) : "<C-f>"', opts)
keyset("n", "<C-b>", 'coc#float#has_scroll() ? coc#float#scroll(0) : "<C-b>"', opts)
keyset("i", "<C-f>",
'coc#float#has_scroll() ? "<c-r>=coc#float#scroll(1)<cr>" : "<Right>"', opts)
keyset("i", "<C-b>",
'coc#float#has_scroll() ? "<c-r>=coc#float#scroll(0)<cr>" : "<Left>"', opts)
keyset("v", "<C-f>", 'coc#float#has_scroll() ? coc#float#scroll(1) : "<C-f>"', opts)
keyset("v", "<C-b>", 'coc#float#has_scroll() ? coc#float#scroll(0) : "<C-b>"', opts)
-- Use CTRL-S for selections ranges
-- Requires 'textDocument/selectionRange' support of language server
keyset("n", "<C-s>", "<Plug>(coc-range-select)", {silent = true})
keyset("x", "<C-s>", "<Plug>(coc-range-select)", {silent = true})
-- Add `:Format` command to format current buffer
vim.api.nvim_create_user_command("Format", "call CocAction('format')", {})
-- " Add `:Fold` command to fold current buffer
vim.api.nvim_create_user_command("Fold", "call CocAction('fold', <f-args>)", {nargs = '?'})
-- Add `:OR` command for organize imports of the current buffer
vim.api.nvim_create_user_command("OR", "call CocActionAsync('runCommand', 'editor.action.organizeImport')", {})
-- Add (Neo)Vim's native statusline support
-- NOTE: Please see `:h coc-status` for integrations with external plugins that
-- provide custom statusline: lightline.vim, vim-airline
vim.opt.statusline:prepend("%{coc#status()}%{get(b:,'coc_current_function','')}")
-- Mappings for CoCList
-- code actions and coc stuff
---@diagnostic disable-next-line: redefined-local
local opts = {silent = true, nowait = true}
-- Show all diagnostics
keyset("n", "<space>a", ":<C-u>CocList diagnostics<cr>", opts)
-- Manage extensions
keyset("n", "<space>e", ":<C-u>CocList extensions<cr>", opts)
-- Show commands
keyset("n", "<space>c", ":<C-u>CocList commands<cr>", opts)
-- Find symbol of current document
keyset("n", "<space>o", ":<C-u>CocList outline<cr>", opts)
-- Search workspace symbols
keyset("n", "<space>s", ":<C-u>CocList -I symbols<cr>", opts)
-- Do default action for next item
keyset("n", "<space>j", ":<C-u>CocNext<cr>", opts)
-- Do default action for previous item
keyset("n", "<space>k", ":<C-u>CocPrev<cr>", opts)
-- Resume latest coc list
keyset("n", "<space>p", ":<C-u>CocListResume<cr>", opts)
-- When started with `-p $DIR` (e.g. NeoVIde), set $DIR as CWD
vim.api.nvim_create_autocmd('VimEnter', {
desc = 'cd to passed $PWD when vim starts.',
callback = function()
local args = vim.v.argv
for i = 1, #args - 1 do
if args[i] == "-p" then
local dir = args[i + 1]
local stat = vim.loop.fs_stat(dir)
if stat and stat.type == "directory" then
vim.cmd("cd " .. vim.fn.fnameescape(dir))
vim.g.session_loaded = false
require("auto-session").setup({
log_level = 'info',
auto_session_enable_last_session = false,
auto_session_enabled = true,
auto_save_enabled = true,
auto_restore_enabled = true,
pre_save_cmds = { "tabdo NvimTreeClose" },
post_restore_cmds = {
function()
vim.g.session_loaded = true
end
},
})
require("neo-tree").setup({
sources = { "filesystem", "git_status", "buffers" },
hide_hidden = false,
hide_dotfiles = false,
hide_gitignored = false,
filesystem = {
follow_current_file = { enabled = true },
},
})
vim.schedule(function()
if vim.g.session_loaded then return end
-- Move to main editing window (right side)
vim.cmd("wincmd l")
vim.cmd("enew") -- Empty buffer
-- Open terminal in horizontal split at bottom
vim.cmd("belowright split | terminal")
vim.cmd("resize 10") -- Set terminal height
-- Focus back to editing buffer
vim.cmd("wincmd k")
end)
return
end
end
end
end,
})
vim.keymap.set('n', '<D-p>', require('telescope.builtin').find_files, { noremap = true, silent = true })
vim.keymap.set('n', '<D-S-p>', require('telescope.builtin').commands, {})
vim.keymap.set('n', '<Leader>gg', function() require('neogit').open({ kind = "floating" }) end)
vim.keymap.set('n', '<Leader>b', function() vim.cmd("CocCommand git.showCommit") end)
require('nvim-treesitter.configs').setup({
sync_install = false,
auto_install = false,
highlight = {
enable = true,
-- Setting this to true will run `:h syntax` and tree-sitter at the same time.
-- Set this to `true` if you depend on 'syntax' being enabled (like for indentation).
-- Using this option may slow down your editor, and you may see some duplicate highlights.
-- Instead of true it can also be a list of languages
additional_vim_regex_highlighting = false,
},
})
vim.cmd.colorscheme("catppuccin")
local function copy_relative_path()
local file_path = vim.fn.expand("%:p")
file_path = file_path:gsub(vim.fn.getcwd(), ""):gsub("^/", "")
-- Copy to clipboard
vim.fn.setreg("+", file_path)
print("Relative path copied to clipboard: " .. file_path)
end
-- Get the GitHub remote URL
local function copy_github_permalink()
-- Get the current SHA
local SHA = vim.fn.system("git rev-parse HEAD 2>/dev/null | tr -d '\n'")
if SHA == "" then
print("Not a Git repository, was not able to get the current SHA.")
return
end
local git_url = vim.fn.system("git config --get remote.upstream.url 2>/dev/null | tr -d '\n'")
if git_url == "" then
git_url = vim.fn.system("git config --get remote.origin.url 2>/dev/null | tr -d '\n'")
end
-- Convert [email protected]:user/repo.git to https://github.com/user/repo
git_url = git_url:gsub("[email protected]:", "https://github.com/")
git_url = git_url:gsub("%.git$", "")
-- Get the current file path relative to the repo root
local file_path = vim.fn.expand("%:p")
local repo_root = vim.fn.system("git rev-parse --show-toplevel 2>/dev/null | tr -d '\n'")
if repo_root == "" then
print("Not a Git repository, was not able to find the root folder.")
return
end
file_path = file_path:gsub(repo_root, ""):gsub("^/", "")
-- Get line number(s)
local line1, line2
if vim.fn.mode() == "v" or vim.fn.mode() == "V" or vim.fn.mode() == "\22" then
-- Visual mode: get start and end lines
local pos1 = vim.fn.getpos("'<")
local pos2 = vim.fn.getpos("'>")
line1 = pos1[2]
line2 = pos2[2]
else
-- Normal mode: just current line
line1 = vim.fn.line(".")
line2 = line1
end
-- Construct the URL
local url
if line1 == line2 then
url = string.format("%s/blob/%s/%s#L%d", git_url, SHA, file_path, line1)
else
url = string.format("%s/blob/%s/%s#L%d-L%d", git_url, SHA, file_path, line1, line2)
end
-- Copy to clipboard
vim.fn.setreg("+", url)
print("GitHub permalink copied to clipboard: " .. url)
end
vim.keymap.set({'n', 'v'}, vim.g.neovide and '<D-S-c>' or '<leader>pc', copy_github_permalink, {desc = "Copy GitHub permalink"})
vim.keymap.set({'n', 'v'}, vim.g.neovide and '<D-S-x>' or '<leader>pc', copy_relative_path, {desc = "Copy GitHub permalink"})
local function toggle_or_focus_terminal()
local cur_win = vim.api.nvim_get_current_win()
local cur_buf = vim.api.nvim_win_get_buf(cur_win)
local cur_buftype = vim.api.nvim_buf_get_option(cur_buf, 'buftype')
if cur_buftype == 'terminal' then
-- If we're currently in a terminal buffer,
-- switch to the first normal (editing) buffer
for i = 1, vim.fn.winnr('$') do
local bufnr = vim.fn.winbufnr(i)
local buftype = vim.api.nvim_buf_get_option(bufnr, 'buftype')
if buftype == "" then -- normal buffer has empty 'buftype'
vim.cmd(i .. 'wincmd w')
return
end
end
-- If no normal buffer found, just open a new empty buffer
vim.cmd('enew')
else
-- Not currently in a terminal, so try to focus an existing terminal
for i = 1, vim.fn.winnr('$') do
local bufnr = vim.fn.winbufnr(i)
local buftype = vim.api.nvim_buf_get_option(bufnr, 'buftype')
if buftype == 'terminal' then
vim.cmd(i .. 'wincmd w')
return
end
end
-- No terminal found, open a new one at the bottom
vim.cmd('belowright split | terminal')
vim.cmd('resize 10')
end
end
vim.keymap.set('n', '<F1>', toggle_or_focus_terminal, { noremap = true, silent = true })
vim.keymap.set('t', '<F1>', toggle_or_focus_terminal, { noremap = true, silent = true })
if vim.g.neovide then
vim.o.mouse = 'a'
vim.g.neovide_fullscreen = true
vim.keymap.set('n', '<D-s>', ':w<CR>') -- Save
vim.keymap.set('v', '<D-c>', '"+y') -- Copy
vim.keymap.set('n', '<D-v>', '"+P') -- Paste normal mode
vim.keymap.set('v', '<D-v>', '"+P') -- Paste visual mode
vim.keymap.set('c', '<D-v>', '<C-R>+') -- Paste command mode
vim.keymap.set('i', '<D-v>', '<ESC>l"+Pli') -- Paste insert mode
vim.keymap.set('n', '<C-Tab>', require('telescope.builtin').oldfiles, { noremap = true, silent = true })
vim.keymap.set('n', '<D-S-f>', require('telescope.builtin').live_grep, { noremap = true, silent = true })
vim.keymap.set('n', '<D-n>', function() vim.cmd("enew") end)
vim.api.nvim_create_augroup("AutoSaveOnFocusLost", { clear = true })
vim.api.nvim_create_autocmd("FocusLost", {
group = "AutoSaveOnFocusLost",
command = "silent! wa",
desc = "Save all buffers when focus is lost",
})
else
vim.o.mouse = ''
end
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment