Project.nvim
The superior project management solution for neovim.
Install / Use
/learn @ahmedkhalf/Project.nvimREADME
🗃️ project.nvim
project.nvim is an all in one neovim plugin written in lua that provides superior project management.

⚡ Requirements
- Neovim >= 0.5.0
✨ Features
- Automagically cd to project directory using nvim lsp
- Dependency free, does not rely on lspconfig
- If no lsp then uses pattern matching to cd to root directory
- Telescope integration
:Telescope projects- Access your recently opened projects from telescope!
- Asynchronous file io so it will not slow down vim when reading the history file on startup.
- ~~Nvim-tree.lua support/integration~~
- Please add the following to your config instead:
" Vim Script lua << EOF require("nvim-tree").setup({ sync_root_with_cwd = true, respect_buf_cwd = true, update_focused_file = { enable = true, update_root = true }, }) EOF-- lua require("nvim-tree").setup({ sync_root_with_cwd = true, respect_buf_cwd = true, update_focused_file = { enable = true, update_root = true }, })
- Please add the following to your config instead:
📦 Installation
Install the plugin with your preferred package manager:
vim-plug
" Vim Script
Plug 'ahmedkhalf/project.nvim'
lua << EOF
require("project_nvim").setup {
-- your configuration comes here
-- or leave it empty to use the default settings
-- refer to the configuration section below
}
EOF
packer
-- Lua
use {
"ahmedkhalf/project.nvim",
config = function()
require("project_nvim").setup {
-- your configuration comes here
-- or leave it empty to use the default settings
-- refer to the configuration section below
}
end
}
⚙️ Configuration
project.nvim comes with the following defaults:
{
-- Manual mode doesn't automatically change your root directory, so you have
-- the option to manually do so using `:ProjectRoot` command.
manual_mode = false,
-- Methods of detecting the root directory. **"lsp"** uses the native neovim
-- lsp, while **"pattern"** uses vim-rooter like glob pattern matching. Here
-- order matters: if one is not detected, the other is used as fallback. You
-- can also delete or rearangne the detection methods.
detection_methods = { "lsp", "pattern" },
-- All the patterns used to detect root dir, when **"pattern"** is in
-- detection_methods
patterns = { ".git", "_darcs", ".hg", ".bzr", ".svn", "Makefile", "package.json" },
-- Table of lsp clients to ignore by name
-- eg: { "efm", ... }
ignore_lsp = {},
-- Don't calculate root dir on specific directories
-- Ex: { "~/.cargo/*", ... }
exclude_dirs = {},
-- Show hidden files in telescope
show_hidden = false,
-- When set to false, you will get a message when project.nvim changes your
-- directory.
silent_chdir = true,
-- What scope to change the directory, valid options are
-- * global (default)
-- * tab
-- * win
scope_chdir = 'global',
-- Path where project.nvim will store the project history for use in
-- telescope
datapath = vim.fn.stdpath("data"),
}
Even if you are pleased with the defaults, please note that setup {} must be
called for the plugin to start.
Pattern Matching
project.nvim's pattern engine uses the same expressions as vim-rooter, but for your convenience, I will copy paste them here:
To specify the root is a certain directory, prefix it with =.
patterns = { "=src" }
To specify the root has a certain directory or file (which may be a glob), just give the name:
patterns = { ".git", "Makefile", "*.sln", "build/env.sh" }
To specify the root has a certain directory as an ancestor (useful for
excluding directories), prefix it with ^:
patterns = { "^fixtures" }
To specify the root has a certain directory as its direct ancestor / parent
(useful when you put working projects in a common directory), prefix it with
>:
patterns = { ">Latex" }
To exclude a pattern, prefix it with !.
patterns = { "!.git/worktrees", "!=extras", "!^fixtures", "!build/env.sh" }
List your exclusions before the patterns you do want.
Telescope Integration
To enable telescope integration:
require('telescope').load_extension('projects')
Telescope Projects Picker
To use the projects picker
require'telescope'.extensions.projects.projects{}
Telescope mappings
project.nvim comes with the following mappings:
| Normal mode | Insert mode | Action | | ----------- | ----------- | -------------------------- | | f | <c-f> | find_project_files | | b | <c-b> | browse_project_files | | d | <c-d> | delete_project | | s | <c-s> | search_in_project_files | | r | <c-r> | recent_project_files | | w | <c-w> | change_working_directory |
API
Get a list of recent projects:
local project_nvim = require("project_nvim")
local recent_projects = project_nvim.get_recent_projects()
print(vim.inspect(recent_projects))
🤝 Contributing
- All pull requests are welcome.
- If you encounter bugs please open an issue.
Related Skills
trello
336.5kManage Trello boards, lists, and cards via the Trello REST API.
mcporter
336.5kUse the mcporter CLI to list, configure, auth, and call MCP servers/tools directly (HTTP or stdio), including ad-hoc servers, config edits, and CLI/type generation.
ccpm
7.8kProject management skill system for Agents that uses GitHub Issues and Git worktrees for parallel agent execution.
mcp-atlassian
4.7kMCP server for Atlassian tools (Confluence, Jira)
