Skip to content

Latest commit

 

History

History
150 lines (118 loc) · 3.87 KB

README.md

File metadata and controls

150 lines (118 loc) · 3.87 KB

seshi.nvim

Seshi.nvim is a Git-aware session manager for Neovim with Telescope integration.

Features

  1. Git-aware Session Management

    • Creates and manages sessions based on the current Git branch
    • Automatically switches working directory and Git branch when loading a session
  2. Telescope Integration

    • Quick session switching using Telescope
    • Delete sessions using Telescope
  3. Autoload Functionality

    • Option to automatically load a session based on the current working directory and active Git branch
  4. Event Hooks

    • Trigger events before and after loading/saving sessions.
    • SeshiLoadPre
    • SeshiLoadPost
    • SeshiSavePre
    • SeshiSavePost

Installation

Lazy.nvim

-- Lua
{
    "sebajun9/seshi.nvim",
    lazy = false, -- Required only if autoloading.
    opt = {}
}

Configuration

Defaults

-- Lua
{
    "sebajun9/seshi.nvim",
    lazy = false, -- Required only if autoloading.
    opt = {
        save_dir = vim.fn.expand(vim.fn.stdpath('data') .. '/sessions/'),
        autoload = true,
        use_git_root = true,
        silent = false,
        telescope = {
          mappings = {
            delete_session = '<C-d>',
          },
        },
      }
    }
}
  • save_dir Session files will be saved to and loaded from save_dir.

  • autoload If autoload is set to true, upon loading nvim without any arguments, will attempt to load an existing session file for the current working directory and Git branch.

  • use_git_root If use_git_root is set to false, session files are associated with the working directory :SeshiSave was run in. If set to true, session files are associated with the root directory of the repository.

  • silent If silent is set to true, it will suppress print statements out of seshi.nvim.

  • telescope.mappings.delete-session Key map for deleting a session file while inside of Telescope.

Scenarios

New session

  1. Start Neovim in your project
  2. Open your buffers and windows
  3. Run :SeshiSave
  4. Your buffers and windows are now saved for the current directory and branch

Loading a session

  1. Start Neovim
  2. Run :SeshiList to bring up a Telescope picker with available sessions
  3. Select the session you want
  4. Start coding!

Autoloading a session

  1. Start Neovim
  2. seshi.nvim will try to load a session file for the current project and branch
  3. Start coding!

Switching sessions

For switching sessions, it is recommended to use an autocmd to perform any clean up tasks before switching projects. Here is a basic autocmd to get started:

local seshi_group = vim.api.nvim_create_augroup('SeshiEvents', {})

vim.api.nvim_create_autocmd({ 'User' }, {
  pattern = 'SeshiLoadPre',
  group = seshi_group,
  callback = function()
    -- Uncomment this if you want to save the current session before cleaning up.
    -- local seshi = require 'seshi'
    -- if seshi.current_session_exists() then
    --   seshi.save_session()
    -- end

    -- Note that I've occasionally had strange interactions with other plugins
    -- that create special buffers. My solution was to disable the offending 
    -- plugins before running `%bd!` and then enabling them after.
    vim.cmd '%bd!'
  end,
})

Deleting a session

  1. Run :SeshiList
  2. Highlight the session to delete
  3. Press the delete_session keymap (default <C-d>)

Usage

SeshiSave

:SeshiSave

Saves the session for the current directory and Git branch.

SeshiList

:SeshiList

Opens a Telescope picket with a list of sessions. Making a selection loads the session. You can also delete a session by pressing the delete_session keymap (default <C-d>).

SeshiLoadCurrent

:SeshiLoadCurrent

Tries to load a session for the current directory and branch.

SeshiDeleteCurrent

:SeshiDeleteCurrent

Tries to delete an existing session for the current directory and branch.