Compare commits

...

71 Commits
v1.0.0 ... main

Author SHA1 Message Date
Folke Lemaitre
166a79a55b
refactor: cleanup 2025-02-25 19:20:14 +01:00
folke
3ae5cb9bc0 chore(build): auto-generate docs 2025-02-25 18:17:41 +00:00
Jakub Okoński
ae0d7e8e45
fix(start): don't count ft=jj buffers for persistence (#90)
## Description

Don't count `ft=jj` buffers towards those that need persisting

## Related Issue(s)

https://github.com/LazyVim/LazyVim/discussions/5545
2025-02-25 19:16:59 +01:00
folke
f6aad7dde7 chore(build): auto-generate docs 2024-07-22 12:25:55 +00:00
Folke Lemaitre
fce1ea237e
ci: update 2024-07-22 14:24:46 +02:00
github-actions[bot]
40a137dd92
chore(update): update repository (#72)
Automated changes by
[create-pull-request](https://github.com/peter-evans/create-pull-request)
GitHub action

Co-authored-by: folke <292349+folke@users.noreply.github.com>
2024-07-15 17:09:09 +02:00
folke
43f180d2f5 chore(build): auto-generate docs 2024-07-15 09:20:05 +00:00
github-actions[bot]
da993034f4
chore(update): update repository (#71)
Automated changes by
[create-pull-request](https://github.com/peter-evans/create-pull-request)
GitHub action

Co-authored-by: folke <292349+folke@users.noreply.github.com>
2024-07-15 11:19:27 +02:00
github-actions[bot]
1e7d01fc7f
chore(update): update repository (#69)
Automated changes by
[create-pull-request](https://github.com/peter-evans/create-pull-request)
GitHub action

Co-authored-by: folke <292349+folke@users.noreply.github.com>
2024-07-13 18:09:22 +02:00
github-actions[bot]
dbedb2fc07
chore(update): update repository (#68)
Automated changes by
[create-pull-request](https://github.com/peter-evans/create-pull-request)
GitHub action

Co-authored-by: folke <292349+folke@users.noreply.github.com>
2024-07-13 16:15:44 +02:00
folke
96ca1ce371 chore(build): auto-generate docs 2024-07-13 08:09:16 +00:00
github-actions[bot]
f89430a7dc
chore(update): update repository (#67)
Automated changes by
[create-pull-request](https://github.com/peter-evans/create-pull-request)
GitHub action

Co-authored-by: folke <292349+folke@users.noreply.github.com>
2024-07-13 10:08:36 +02:00
github-actions[bot]
c45ff862b5
chore(main): release 3.1.0 (#66)
🤖 I have created a release *beep* *boop*
---


##
[3.1.0](https://github.com/folke/persistence.nvim/compare/v3.0.1...v3.1.0)
(2024-07-07)


### Features

* **load:** fallback to regular session when branch session does not
exist (yet)
([a93748a](a93748acdb))

---
This PR was generated with [Release
Please](https://github.com/googleapis/release-please). See
[documentation](https://github.com/googleapis/release-please#release-please).

Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
2024-07-07 21:24:56 +02:00
Folke Lemaitre
a93748acdb
feat(load): fallback to regular session when branch session does not exist (yet) 2024-07-07 19:01:19 +02:00
github-actions[bot]
fc8273bac0
chore(main): release 3.0.1 (#63)
🤖 I have created a release *beep* *boop*
---


##
[3.0.1](https://github.com/folke/persistence.nvim/compare/v3.0.0...v3.0.1)
(2024-07-07)


### Bug Fixes

* branch detection. Closes
[#62](https://github.com/folke/persistence.nvim/issues/62)
([a1d37fa](a1d37fa32e))
* **branch:** escape branch name. Fixes
[#65](https://github.com/folke/persistence.nvim/issues/65)
([1565ca0](1565ca0af2))
* windows
([2d83b1a](2d83b1a5c3))

---
This PR was generated with [Release
Please](https://github.com/googleapis/release-please). See
[documentation](https://github.com/googleapis/release-please#release-please).

Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
2024-07-07 09:24:55 +02:00
Folke Lemaitre
2d83b1a5c3
fix: windows 2024-07-07 05:36:38 +02:00
folke
f18d0131ed chore(build): auto-generate docs 2024-07-07 05:03:13 +00:00
Folke Lemaitre
1565ca0af2
fix(branch): escape branch name. Fixes #65 2024-07-07 07:02:32 +02:00
Folke Lemaitre
2c7d3eb6b8
ci: update 2024-07-06 23:45:36 +02:00
Folke Lemaitre
a1d37fa32e
fix: branch detection. Closes #62 2024-07-06 23:21:20 +02:00
Folke Lemaitre
34f337e383
ci: update 2024-07-06 23:19:54 +02:00
Folke Lemaitre
8b83876213
ci: update 2024-07-06 23:18:35 +02:00
github-actions[bot]
7f1e8ce997
chore(main): release 3.0.0 (#61)
🤖 I have created a release *beep* *boop*
---


##
[3.0.0](https://github.com/folke/persistence.nvim/compare/v2.0.0...v3.0.0)
(2024-07-06)


### ⚠ BREAKING CHANGES

* opts.need specifieds how many buffers should be open for saving.
Replaces save_empty. Closes #19
* removed load_pre/load_post/save_pre/save_post in favor of events.
Check the readme
* removed `opts.options`. Use `vim.o.sessionoptions` instead.

### Features

* added `require("persistence").select()` to select a session to load
([5346b53](5346b5346a))
* opts.need specifieds how many buffers should be open for saving.
Replaces save_empty. Closes
[#19](https://github.com/folke/persistence.nvim/issues/19)
([7bb5755](7bb575517c))
* persistence.active. Check if a session saving is active
([f0ac0e9](f0ac0e981e))
* **persistence:** add `pre-` and `post-` load hooks
([#24](https://github.com/folke/persistence.nvim/issues/24))
([3d443bd](3d443bd0a7))
* removed `opts.options`. Use `vim.o.sessionoptions` instead.
([eb5622e](eb5622edae))
* removed load_pre/load_post/save_pre/save_post in favor of events.
Check the readme
([f58a838](f58a838282))
* sessions per branch. Closes
[#9](https://github.com/folke/persistence.nvim/issues/9)
([cd0054e](cd0054e6a4))


### Bug Fixes

* don't save `gitrebase` session
([#44](https://github.com/folke/persistence.nvim/issues/44))
([9dbe264](9dbe2648c6))
* opts.need
([9c0e522](9c0e5227fa))
* remove expand() as stdpath() expands itself
([#50](https://github.com/folke/persistence.nvim/issues/50))
([a2fd3d9](a2fd3d9965))

---
This PR was generated with [Release
Please](https://github.com/googleapis/release-please). See
[documentation](https://github.com/googleapis/release-please#release-please).

Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
2024-07-06 22:01:55 +02:00
folke
e1e2bf917f chore(build): auto-generate docs 2024-07-06 20:00:45 +00:00
Folke Lemaitre
cd0054e6a4
feat: sessions per branch. Closes #9 2024-07-06 22:00:20 +02:00
Folke Lemaitre
9c0e5227fa
fix: opts.need 2024-07-06 21:54:41 +02:00
Folke Lemaitre
7bb575517c
feat!: opts.need specifieds how many buffers should be open for saving. Replaces save_empty. Closes #19 2024-07-06 21:41:58 +02:00
Folke Lemaitre
f0ac0e981e
feat: persistence.active. Check if a session saving is active 2024-07-06 21:31:22 +02:00
folke
06e8ef93c8 chore(build): auto-generate docs 2024-07-06 19:24:52 +00:00
Folke Lemaitre
5346b5346a
feat: added require("persistence").select() to select a session to load 2024-07-06 21:24:22 +02:00
Folke Lemaitre
f58a838282
feat!: removed load_pre/load_post/save_pre/save_post in favor of events. Check the readme 2024-07-06 21:23:56 +02:00
Folke Lemaitre
eb5622edae
feat!: removed opts.options. Use vim.o.sessionoptions instead. 2024-07-06 21:22:40 +02:00
github-actions[bot]
08af8fee77
chore(update): update repository (#60)
Automated changes by
[create-pull-request](https://github.com/peter-evans/create-pull-request)
GitHub action

Co-authored-by: folke <292349+folke@users.noreply.github.com>
2024-07-06 18:06:06 +02:00
github-actions[bot]
4452f973c3
chore(update): update repository (#59)
Automated changes by
[create-pull-request](https://github.com/peter-evans/create-pull-request)
GitHub action

Co-authored-by: folke <292349+folke@users.noreply.github.com>
2024-07-06 14:59:44 +02:00
folke
b915cbd3d1 chore(build): auto-generate docs 2024-07-06 09:48:09 +00:00
Folke Lemaitre
f11c573cb2
ci: update 2024-07-06 11:45:26 +02:00
Folke Lemaitre
57953891f8
ci: update 2024-07-05 19:00:53 +02:00
folke
04599f36b5 chore(build): auto-generate docs 2024-07-05 13:46:37 +00:00
Folke Lemaitre
6a45b4fe2c
ci: update 2024-07-05 15:46:10 +02:00
github-actions[bot]
95d03ad545 chore(build): auto-generate vimdoc 2024-06-12 03:53:44 +00:00
Aaron
a2fd3d9965
fix: remove expand() as stdpath() expands itself (#50) 2024-06-12 05:53:08 +02:00
github-actions[bot]
5fe077056c chore(build): auto-generate vimdoc 2024-05-16 17:03:50 +00:00
Roeeeee
3d443bd0a7
feat(persistence): add pre- and post- load hooks (#24)
* Add optional hook typings to config object

* Add optional hooks conditional calls

* Add hooks description to main readme
2024-05-16 19:03:16 +02:00
github-actions[bot]
4982499c16 chore(build): auto-generate vimdoc 2024-01-19 15:14:59 +00:00
FineFindus
9dbe2648c6
fix: don't save gitrebase session (#44) 2024-01-19 16:14:29 +01:00
Frederik Buchlák
09af251a93
docs: folke => lazy.nvim (#39) 2024-01-19 16:14:01 +01:00
github-actions[bot]
ad538bfd53
chore(main): release 2.0.0 (#36)
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
2023-10-15 21:42:03 +02:00
github-actions[bot]
01d7fa95fe chore(build): auto-generate vimdoc 2023-10-15 19:41:11 +00:00
Folke Lemaitre
0361df7775
fix(start)!: session name is now based on the cwd when the session starts and not when the session ends. Fixes #1688 2023-10-15 21:40:27 +02:00
github-actions[bot]
9730a073fd
chore(main): release 1.2.1 (#34)
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
2023-10-13 08:56:34 +02:00
Folke Lemaitre
8f7cbccfb5
fix: dont save the session when only gitcommit buffers are present. Fixes #14 2023-10-13 08:47:08 +02:00
github-actions[bot]
21f55da0d3
chore(main): release 1.2.0 (#33)
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
2023-10-13 07:58:56 +02:00
github-actions[bot]
878c3b32d9 chore(build): auto-generate vimdoc 2023-10-13 05:57:50 +00:00
Folke Lemaitre
e9afeaf3a7
feat: don't save the session when no files are open (save_empty = false) 2023-10-13 07:57:09 +02:00
github-actions[bot]
4b8051c01f chore(build): auto-generate vimdoc 2023-05-22 14:39:07 +00:00
Folke Lemaitre
7b86ec2430
docs: lazy install 2023-05-22 16:38:25 +02:00
Folke Lemaitre
c814fae5c3
chore: update templates 2023-03-19 21:15:43 +01:00
github-actions[bot]
4d2857b647 chore(build): auto-generate vimdoc 2023-03-19 19:37:23 +00:00
Folke Lemaitre
74475d1f7d
chore: update templates 2023-03-19 20:36:39 +01:00
github-actions[bot]
adcf691369
chore(main): release 1.1.0 (#23)
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
2023-02-28 12:43:14 +01:00
github-actions[bot]
5e47847262 chore(build): auto-generate vimdoc 2023-02-28 09:06:44 +00:00
Iron-E
f4bb0c5641
feat(persistence): pre_save option to call before saving (#22)
* feat(persistence): `pre_save` option to call before saving

This commit adds the `pre_save` option, which is a `fun()|nil` that will
be called (if present) before saving the current session. Use cases
include filtering buffers, executing `User` autocmds, etc.

* docs: `pre_save` option
2023-02-28 10:05:58 +01:00
github-actions[bot]
d8a3eda0e1 chore(build): auto-generate vimdoc 2023-01-23 19:53:21 +00:00
Folke Lemaitre
b0e2b283c6
ci: checkout v3 2023-01-23 20:52:38 +01:00
github-actions[bot]
cc68aed5a1 chore(build): auto-generate vimdoc 2023-01-17 09:54:20 +00:00
Folke Lemaitre
5b7e71abe9
docs: update path to session in state directory. Fixes #20 2023-01-17 10:53:36 +01:00
github-actions[bot]
8484fdaa28
chore(main): release 1.0.1 (#18)
Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
2023-01-06 19:33:37 +01:00
github-actions[bot]
8c40aa7b80 chore(build): auto-generate vimdoc 2023-01-06 18:29:26 +00:00
Folke Lemaitre
70c281e54e
fix: dont throw error when session was already stopped 2023-01-06 19:28:37 +01:00
github-actions[bot]
7421e30704 chore(build): auto-generate vimdoc 2023-01-05 07:38:46 +00:00
Jann Marc
5453a25028
docs: updated session directory (#16)
* Update README.md

* Update docs
2023-01-05 08:38:06 +01:00
20 changed files with 419 additions and 305 deletions

7
.editorconfig Normal file
View File

@ -0,0 +1,7 @@
root = true
[*]
insert_final_newline = true
indent_style = space
indent_size = 2
charset = utf-8

View File

@ -6,7 +6,10 @@ body:
- type: markdown - type: markdown
attributes: attributes:
value: | value: |
**Before** reporting an issue, make sure to read the [documentation](https://github.com/folke/persistence.nvim) and search [existing issues](https://github.com/folke/persistence.nvim/issues). Usage questions such as ***"How do I...?"*** belong in [Discussions](https://github.com/folke/persistence.nvim/discussions) and will be closed. **Before** reporting an issue, make sure to read the [documentation](https://github.com/folke/persistence.nvim)
and search [existing issues](https://github.com/folke/persistence.nvim/issues).
Usage questions such as ***"How do I...?"*** belong in [Discussions](https://github.com/folke/persistence.nvim/discussions) and will be closed.
- type: checkboxes - type: checkboxes
attributes: attributes:
label: Did you check docs and existing issues? label: Did you check docs and existing issues?
@ -14,9 +17,11 @@ body:
options: options:
- label: I have read all the persistence.nvim docs - label: I have read all the persistence.nvim docs
required: true required: true
- label: I have updated the plugin to the latest version before submitting this issue
required: true
- label: I have searched the existing issues of persistence.nvim - label: I have searched the existing issues of persistence.nvim
required: true required: true
- label: I have searched the exsiting issues of plugins related to this issue - label: I have searched the existing issues of plugins related to this issue
required: true required: true
- type: input - type: input
attributes: attributes:
@ -57,32 +62,15 @@ body:
label: Repro label: Repro
description: Minimal `init.lua` to reproduce this issue. Save as `repro.lua` and run with `nvim -u repro.lua` description: Minimal `init.lua` to reproduce this issue. Save as `repro.lua` and run with `nvim -u repro.lua`
value: | value: |
-- DO NOT change the paths and don't remove the colorscheme vim.env.LAZY_STDPATH = ".repro"
local root = vim.fn.fnamemodify("./.repro", ":p") load(vim.fn.system("curl -s https://raw.githubusercontent.com/folke/lazy.nvim/main/bootstrap.lua"))()
-- set stdpaths to use .repro
for _, name in ipairs({ "config", "data", "state", "cache" }) do
vim.env[("XDG_%s_HOME"):format(name:upper())] = root .. "/" .. name
end
-- bootstrap lazy require("lazy.minit").repro({
local lazypath = root .. "/plugins/lazy.nvim" spec = {
if not vim.loop.fs_stat(lazypath) then { "folke/persistence.nvim", opts = {} },
vim.fn.system({ "git", "clone", "--filter=blob:none", "https://github.com/folke/lazy.nvim.git", lazypath, }) -- add any other plugins here
end },
vim.opt.runtimepath:prepend(lazypath)
-- install plugins
local plugins = {
"folke/tokyonight.nvim",
"folke/persistence.nvim",
-- add any other plugins here
}
require("lazy").setup(plugins, {
root = root .. "/plugins",
}) })
render: lua
vim.cmd.colorscheme("tokyonight")
-- add anything else here
render: Lua
validations: validations:
required: false required: false

5
.github/ISSUE_TEMPLATE/config.yml vendored Normal file
View File

@ -0,0 +1,5 @@
blank_issues_enabled: false
contact_links:
- name: Ask a question
url: https://github.com/folke/persistence.nvim/discussions
about: Use Github discussions instead

16
.github/PULL_REQUEST_TEMPLATE.md vendored Normal file
View File

@ -0,0 +1,16 @@
## Description
<!-- Describe the big picture of your changes to communicate to the maintainers
why we should accept this pull request. -->
## Related Issue(s)
<!--
If this PR fixes any issues, please link to the issue here.
- Fixes #<issue_number>
-->
## Screenshots
<!-- Add screenshots of the changes if applicable. -->

6
.github/dependabot.yml vendored Normal file
View File

@ -0,0 +1,6 @@
version: 2
updates:
- package-ecosystem: "github-actions"
directory: "/"
schedule:
interval: "weekly"

View File

@ -1,68 +1,14 @@
name: CI name: CI
on: on:
push: push:
branches: [main, master]
pull_request: pull_request:
jobs: jobs:
tests: ci:
strategy: uses: folke/github/.github/workflows/ci.yml@main
matrix: secrets: inherit
# os: [ubuntu-latest, windows-latest] with:
os: [ubuntu-latest] plugin: persistence.nvim
runs-on: ${{ matrix.os }} repo: folke/persistence.nvim
steps:
- uses: actions/checkout@v3
- name: Install Neovim
shell: bash
run: |
wget -q https://github.com/neovim/neovim/releases/download/nightly/nvim-linux64.deb -O /tmp/nvim.deb
sudo dpkg -i /tmp/nvim.deb
- name: Run Tests
run: |
nvim --version
[ ! -d tests ] && exit 0
nvim --headless -u tests/init.lua -c "PlenaryBustedDirectory tests/ {minimal_init = 'tests/init.lua', sequential = true}"
docs:
runs-on: ubuntu-latest
needs: tests
if: ${{ github.ref == 'refs/heads/main' }}
steps:
- uses: actions/checkout@v3
- name: panvimdoc
uses: kdheepak/panvimdoc@main
with:
vimdoc: persistence.nvim
version: "Neovim >= 0.8.0"
demojify: true
treesitter: true
- name: Push changes
uses: stefanzweifel/git-auto-commit-action@v4
with:
commit_message: "chore(build): auto-generate vimdoc"
commit_user_name: "github-actions[bot]"
commit_user_email: "github-actions[bot]@users.noreply.github.com"
commit_author: "github-actions[bot] <github-actions[bot]@users.noreply.github.com>"
release:
name: release
if: ${{ github.ref == 'refs/heads/main' }}
needs:
- docs
- tests
runs-on: ubuntu-latest
steps:
- uses: google-github-actions/release-please-action@v3
id: release
with:
release-type: simple
package-name: persistence.nvim
- uses: actions/checkout@v2
- name: tag stable versions
if: ${{ steps.release.outputs.release_created }}
run: |
git config user.name github-actions[bot]
git config user.email github-actions[bot]@users.noreply.github.com
git remote add gh-token "https://${{ secrets.GITHUB_TOKEN }}@github.com/google-github-actions/release-please-action.git"
git tag -d stable || true
git push origin :stable || true
git tag -a stable -m "Last Stable Release"
git push origin stable

8
.github/workflows/labeler.yml vendored Normal file
View File

@ -0,0 +1,8 @@
name: "PR Labeler"
on:
- pull_request_target
jobs:
labeler:
uses: folke/github/.github/workflows/labeler.yml@main
secrets: inherit

18
.github/workflows/pr.yml vendored Normal file
View File

@ -0,0 +1,18 @@
name: PR Title
on:
pull_request_target:
types:
- opened
- edited
- synchronize
- reopened
- ready_for_review
permissions:
pull-requests: read
jobs:
pr-title:
uses: folke/github/.github/workflows/pr.yml@main
secrets: inherit

11
.github/workflows/stale.yml vendored Normal file
View File

@ -0,0 +1,11 @@
name: Stale Issues & PRs
on:
schedule:
- cron: "30 1 * * *"
jobs:
stale:
if: contains(fromJSON('["folke", "LazyVim"]'), github.repository_owner)
uses: folke/github/.github/workflows/stale.yml@main
secrets: inherit

13
.github/workflows/update.yml vendored Normal file
View File

@ -0,0 +1,13 @@
name: Update Repo
on:
workflow_dispatch:
schedule:
# Run every hour
- cron: "0 * * * *"
jobs:
update:
if: contains(fromJSON('["folke", "LazyVim"]'), github.repository_owner)
uses: folke/github/.github/workflows/update.yml@main
secrets: inherit

13
.gitignore vendored
View File

@ -1,6 +1,9 @@
tt.* *.log
.tests /.repro
doc/tags /.tests
debug /build
.repro /debug
/doc/tags
foo.* foo.*
node_modules
tt.*

View File

@ -1,5 +1,86 @@
# Changelog # Changelog
## [3.1.0](https://github.com/folke/persistence.nvim/compare/v3.0.1...v3.1.0) (2024-07-07)
### Features
* **load:** fallback to regular session when branch session does not exist (yet) ([a93748a](https://github.com/folke/persistence.nvim/commit/a93748acdb2e7bc4389b3738b4c787b764c3b2a6))
## [3.0.1](https://github.com/folke/persistence.nvim/compare/v3.0.0...v3.0.1) (2024-07-07)
### Bug Fixes
* branch detection. Closes [#62](https://github.com/folke/persistence.nvim/issues/62) ([a1d37fa](https://github.com/folke/persistence.nvim/commit/a1d37fa32ef9431f6a57c217ba5c456d20834679))
* **branch:** escape branch name. Fixes [#65](https://github.com/folke/persistence.nvim/issues/65) ([1565ca0](https://github.com/folke/persistence.nvim/commit/1565ca0af2d93ee94335c2950d92bc133c90aa82))
* windows ([2d83b1a](https://github.com/folke/persistence.nvim/commit/2d83b1a5c3fe5b2251866f5263fb9607db8d64c0))
## [3.0.0](https://github.com/folke/persistence.nvim/compare/v2.0.0...v3.0.0) (2024-07-06)
### ⚠ BREAKING CHANGES
* opts.need specifieds how many buffers should be open for saving. Replaces save_empty. Closes #19
* removed load_pre/load_post/save_pre/save_post in favor of events. Check the readme
* removed `opts.options`. Use `vim.o.sessionoptions` instead.
### Features
* added `require("persistence").select()` to select a session to load ([5346b53](https://github.com/folke/persistence.nvim/commit/5346b5346a2dd1732ae84f05251ecb704f35df87))
* opts.need specifieds how many buffers should be open for saving. Replaces save_empty. Closes [#19](https://github.com/folke/persistence.nvim/issues/19) ([7bb5755](https://github.com/folke/persistence.nvim/commit/7bb575517cebbc2b172caa04581dc5d91be90136))
* persistence.active. Check if a session saving is active ([f0ac0e9](https://github.com/folke/persistence.nvim/commit/f0ac0e981e4c864df11e613636a23c5bad09376d))
* **persistence:** add `pre-` and `post-` load hooks ([#24](https://github.com/folke/persistence.nvim/issues/24)) ([3d443bd](https://github.com/folke/persistence.nvim/commit/3d443bd0a7e1d9eebfa37321fc8118d8d538af13))
* removed `opts.options`. Use `vim.o.sessionoptions` instead. ([eb5622e](https://github.com/folke/persistence.nvim/commit/eb5622edae69ec65f6f83fcdd0eb5a70ce48ece7))
* removed load_pre/load_post/save_pre/save_post in favor of events. Check the readme ([f58a838](https://github.com/folke/persistence.nvim/commit/f58a838282dac1ed33165a5fd03829b036584df2))
* sessions per branch. Closes [#9](https://github.com/folke/persistence.nvim/issues/9) ([cd0054e](https://github.com/folke/persistence.nvim/commit/cd0054e6a4c17e4068a3e69a030013d268e569f9))
### Bug Fixes
* don't save `gitrebase` session ([#44](https://github.com/folke/persistence.nvim/issues/44)) ([9dbe264](https://github.com/folke/persistence.nvim/commit/9dbe2648c67b678bf7fe688f03b57a2514e03e6f))
* opts.need ([9c0e522](https://github.com/folke/persistence.nvim/commit/9c0e5227fa7b36208a2db0d812008965c1aac889))
* remove expand() as stdpath() expands itself ([#50](https://github.com/folke/persistence.nvim/issues/50)) ([a2fd3d9](https://github.com/folke/persistence.nvim/commit/a2fd3d99656ac496e56233aa4a40dd045a16fdc4))
## [2.0.0](https://github.com/folke/persistence.nvim/compare/v1.2.1...v2.0.0) (2023-10-15)
### ⚠ BREAKING CHANGES
* **start:** session name is now based on the cwd when the session starts and not when the session ends. Fixes #1688
### Bug Fixes
* **start:** session name is now based on the cwd when the session starts and not when the session ends. Fixes [#1688](https://github.com/folke/persistence.nvim/issues/1688) ([0361df7](https://github.com/folke/persistence.nvim/commit/0361df7775f5b4ed51a6d7fe159438573b7f07a6))
## [1.2.1](https://github.com/folke/persistence.nvim/compare/v1.2.0...v1.2.1) (2023-10-13)
### Bug Fixes
* dont save the session when only `gitcommit` buffers are present. Fixes [#14](https://github.com/folke/persistence.nvim/issues/14) ([8f7cbcc](https://github.com/folke/persistence.nvim/commit/8f7cbccfb506fe6cb35db9ad966137c363b049c5))
## [1.2.0](https://github.com/folke/persistence.nvim/compare/v1.1.0...v1.2.0) (2023-10-13)
### Features
* don't save the session when no files are open (save_empty = false) ([e9afeaf](https://github.com/folke/persistence.nvim/commit/e9afeaf3a7bb645ca73980cd13048c48c292500c))
## [1.1.0](https://github.com/folke/persistence.nvim/compare/v1.0.1...v1.1.0) (2023-02-28)
### Features
* **persistence:** `pre_save` option to call before saving ([#22](https://github.com/folke/persistence.nvim/issues/22)) ([f4bb0c5](https://github.com/folke/persistence.nvim/commit/f4bb0c5641a0e6c9ac3675ddd794ca78099d8510))
## [1.0.1](https://github.com/folke/persistence.nvim/compare/v1.0.0...v1.0.1) (2023-01-06)
### Bug Fixes
* dont throw error when session was already stopped ([70c281e](https://github.com/folke/persistence.nvim/commit/70c281e54e34630d8bef9b1cf9f7a0ac3edd6a1c))
## 1.0.0 (2023-01-04) ## 1.0.0 (2023-01-04)

View File

@ -4,44 +4,28 @@
## ✨ Features ## ✨ Features
- automatically saves the active session under `.config/nvim/sessions` on exit - automatically saves the active session under `~/.local/state/nvim/sessions` on exit
- simple API to restore the current or last session - simple API to restore the current or last session
## ⚡️ Requirements ## ⚡️ Requirements
- Neovim >= 0.5.0 - Neovim >= 0.7.2
## 📦 Installation ## 📦 Installation
Install the plugin with your preferred package manager: Install the plugin with your preferred package manager:
### [packer](https://github.com/wbthomason/packer.nvim) ### [lazy.nvim](https://github.com/folke/lazy.nvim)
```lua ```lua
-- Lua -- Lua
use({ {
"folke/persistence.nvim", "folke/persistence.nvim",
event = "BufReadPre", -- this will only start session saving when an actual file was opened event = "BufReadPre", -- this will only start session saving when an actual file was opened
module = "persistence", opts = {
config = function() -- add any custom options here
require("persistence").setup()
end,
})
```
### [vim-plug](https://github.com/junegunn/vim-plug)
```vim
" Vim Script
Plug 'folke/persistence.nvim'
lua << EOF
require("persistence").setup {
-- your configuration comes here
-- or leave it empty to use the default settings
-- refer to the configuration section below
} }
EOF }
``` ```
## ⚙️ Configuration ## ⚙️ Configuration
@ -50,23 +34,39 @@ Persistence comes with the following defaults:
```lua ```lua
{ {
dir = vim.fn.expand(vim.fn.stdpath("config") .. "/sessions/"), -- directory where session files are saved dir = vim.fn.stdpath("state") .. "/sessions/", -- directory where session files are saved
options = { "buffers", "curdir", "tabpages", "winsize" }, -- sessionoptions used for saving -- minimum number of file buffers that need to be open to save
-- Set to 0 to always save
need = 1,
branch = true, -- use git branch to save session
} }
``` ```
> [!TIP]
> To configure what should be saved in your session, check [:h 'sessionoptions'](https://neovim.io/doc/user/options.html#'sessionoptions')
## 🚀 Usage ## 🚀 Usage
**Persistence** works well with plugins like `startify` or `dashboard`. It will never restore a session automatically, **Persistence** works well with plugins like `startify` or `dashboard`. It will never restore a session automatically,
but you can of course write an autocmd that does exactly that if you want. but you can of course write an autocmd that does exactly that if you want.
```lua ```lua
-- restore the session for the current directory -- load the session for the current directory
vim.api.nvim_set_keymap("n", "<leader>qs", [[<cmd>lua require("persistence").load()<cr>]], {}) vim.keymap.set("n", "<leader>qs", function() require("persistence").load() end)
-- restore the last session -- select a session to load
vim.api.nvim_set_keymap("n", "<leader>ql", [[<cmd>lua require("persistence").load({ last = true })<cr>]], {}) vim.keymap.set("n", "<leader>qS", function() require("persistence").select() end)
-- load the last session
vim.keymap.set("n", "<leader>ql", function() require("persistence").load({ last = true }) end)
-- stop Persistence => session won't be saved on exit -- stop Persistence => session won't be saved on exit
vim.api.nvim_set_keymap("n", "<leader>qd", [[<cmd>lua require("persistence").stop()<cr>]], {}) vim.keymap.set("n", "<leader>qd", function() require("persistence").stop() end)
``` ```
## 📅 Events
- **PersistenceLoadPre**: before loading a session
- **PersistenceLoadPost**: after loading a session
- **PersistenceSavePre**: before saving a session
- **PersistenceSavePost**: after saving a session

View File

@ -1,98 +1,98 @@
*persistence.nvim.txt* For Neovim >= 0.8.0 Last change: 2023 January 04 *persistence.nvim.txt* For Neovim Last change: 2025 February 25
============================================================================== ==============================================================================
Table of Contents *persistence.nvim-table-of-contents* Table of Contents *persistence.nvim-table-of-contents*
1. Persistence |persistence.nvim-persistence| 1. Persistence |persistence.nvim-persistence|
- Features |persistence.nvim-features| - Features |persistence.nvim-persistence-features|
- Requirements |persistence.nvim-requirements| - Requirements |persistence.nvim-persistence-requirements|
- Installation |persistence.nvim-installation| - Installation |persistence.nvim-persistence-installation|
- Configuration |persistence.nvim-configuration| - Configuration |persistence.nvim-persistence-configuration|
- Usage |persistence.nvim-usage| - Usage |persistence.nvim-persistence-usage|
- Events |persistence.nvim-persistence-events|
============================================================================== ==============================================================================
1. Persistence *persistence.nvim-persistence* 1. Persistence *persistence.nvim-persistence*
**Persistence** is a simple lua plugin for automated session management. **Persistence** is a simple lua plugin for automated session management.
FEATURES *persistence.nvim-features*
FEATURES *persistence.nvim-persistence-features*
- automatically saves the active session under `.config/nvim/sessions` on exit - automatically saves the active session under `~/.local/state/nvim/sessions` on exit
- simple API to restore the current or last session - simple API to restore the current or last session
REQUIREMENTS *persistence.nvim-requirements* REQUIREMENTS *persistence.nvim-persistence-requirements*
- Neovim >= 0.7.2
- Neovim >= 0.5.0 INSTALLATION *persistence.nvim-persistence-installation*
INSTALLATION *persistence.nvim-installation*
Install the plugin with your preferred package manager: Install the plugin with your preferred package manager:
PACKER <HTTPS://GITHUB.COM/WBTHOMASON/PACKER.NVIM> ~
LAZY.NVIM ~
>lua >lua
-- Lua -- Lua
use({ {
"folke/persistence.nvim", "folke/persistence.nvim",
event = "BufReadPre", -- this will only start session saving when an actual file was opened event = "BufReadPre", -- this will only start session saving when an actual file was opened
module = "persistence", opts = {
config = function() -- add any custom options here
require("persistence").setup()
end,
})
<
VIM-PLUG <HTTPS://GITHUB.COM/JUNEGUNN/VIM-PLUG> ~
>vim
" Vim Script
Plug 'folke/persistence.nvim'
lua << EOF
require("persistence").setup {
-- your configuration comes here
-- or leave it empty to use the default settings
-- refer to the configuration section below
} }
EOF }
< <
CONFIGURATION *persistence.nvim-configuration* CONFIGURATION *persistence.nvim-persistence-configuration*
Persistence comes with the following defaults: Persistence comes with the following defaults:
>lua >lua
{ {
dir = vim.fn.expand(vim.fn.stdpath("config") .. "/sessions/"), -- directory where session files are saved dir = vim.fn.stdpath("state") .. "/sessions/", -- directory where session files are saved
options = { "buffers", "curdir", "tabpages", "winsize" }, -- sessionoptions used for saving -- minimum number of file buffers that need to be open to save
-- Set to 0 to always save
need = 1,
branch = true, -- use git branch to save session
} }
< <
USAGE *persistence.nvim-usage* [!TIP] To configure what should be saved in your session, check |:h
'sessionoptions'|
USAGE *persistence.nvim-persistence-usage*
**Persistence** works well with plugins like `startify` or `dashboard`. It will **Persistence** works well with plugins like `startify` or `dashboard`. It will
never restore a session automatically, but you can of course write an autocmd never restore a session automatically, but you can of course write an autocmd
that does exactly that if you want. that does exactly that if you want.
>lua >lua
-- restore the session for the current directory -- load the session for the current directory
vim.api.nvim_set_keymap("n", "<leader>qs", [[<cmd>lua require("persistence").load()<cr>]], {}) vim.keymap.set("n", "<leader>qs", function() require("persistence").load() end)
-- restore the last session -- select a session to load
vim.api.nvim_set_keymap("n", "<leader>ql", [[<cmd>lua require("persistence").load({ last = true })<cr>]], {}) vim.keymap.set("n", "<leader>qS", function() require("persistence").select() end)
-- load the last session
vim.keymap.set("n", "<leader>ql", function() require("persistence").load({ last = true }) end)
-- stop Persistence => session won't be saved on exit -- stop Persistence => session won't be saved on exit
vim.api.nvim_set_keymap("n", "<leader>qd", [[<cmd>lua require("persistence").stop()<cr>]], {}) vim.keymap.set("n", "<leader>qd", function() require("persistence").stop() end)
< <
EVENTS *persistence.nvim-persistence-events*
- **PersistenceLoadPre**before loading a session
- **PersistenceLoadPost**after loading a session
- **PersistenceSavePre**before saving a session
- **PersistenceSavePost**after saving a session
Generated by panvimdoc <https://github.com/kdheepak/panvimdoc> Generated by panvimdoc <https://github.com/kdheepak/panvimdoc>
vim:tw=78:ts=8:noet:ft=help:norl: vim:tw=78:ts=8:noet:ft=help:norl:

View File

@ -1,98 +0,0 @@
*persistence.txt* For NVIM v0.8.0 Last change: 2023 January 04
==============================================================================
Table of Contents *persistence-table-of-contents*
1. 💾 Persistence |persistence-💾-persistence|
- ✨ Features |persistence-✨-features|
- ⚡️ Requirements |persistence-⚡️-requirements|
- 📦 Installation |persistence-📦-installation|
- ⚙️ Configuration |persistence-⚙️-configuration|
- 🚀 Usage |persistence-🚀-usage|
==============================================================================
1. 💾 Persistence *persistence-💾-persistence*
**Persistence** is a simple lua plugin for automated session management.
✨ FEATURES *persistence-✨-features*
- automatically saves the active session under `.config/nvim/sessions` on exit
- simple API to restore the current or last session
⚡️ REQUIREMENTS *persistence-⚡️-requirements*
- Neovim >= 0.5.0
📦 INSTALLATION *persistence-📦-installation*
Install the plugin with your preferred package manager:
PACKER <HTTPS://GITHUB.COM/WBTHOMASON/PACKER.NVIM> ~
>
-- Lua
use({
"folke/persistence.nvim",
event = "BufReadPre", -- this will only start session saving when an actual file was opened
module = "persistence",
config = function()
require("persistence").setup()
end,
})
<
VIM-PLUG <HTTPS://GITHUB.COM/JUNEGUNN/VIM-PLUG> ~
>
" Vim Script
Plug 'folke/persistence.nvim'
lua << EOF
require("persistence").setup {
-- your configuration comes here
-- or leave it empty to use the default settings
-- refer to the configuration section below
}
EOF
<
⚙️ CONFIGURATION *persistence-⚙️-configuration*
Persistence comes with the following defaults:
>
{
dir = vim.fn.expand(vim.fn.stdpath("config") .. "/sessions/"), -- directory where session files are saved
options = { "buffers", "curdir", "tabpages", "winsize" }, -- sessionoptions used for saving
}
<
🚀 USAGE *persistence-🚀-usage*
**Persistence** works well with plugins like `startify` or `dashboard`. It will
never restore a session automatically, but you can of course write an autocmd
that does exactly that if you want.
>
-- restore the session for the current directory
vim.api.nvim_set_keymap("n", "<leader>qs", [[<cmd>lua require("persistence").load()<cr>]], {})
-- restore the last session
vim.api.nvim_set_keymap("n", "<leader>ql", [[<cmd>lua require("persistence").load({ last = true })<cr>]], {})
-- stop Persistence => session won't be saved on exit
vim.api.nvim_set_keymap("n", "<leader>qd", [[<cmd>lua require("persistence").stop()<cr>]], {})
<
Generated by panvimdoc <https://github.com/kdheepak/panvimdoc>
vim:tw=78:ts=8:noet:ft=help:norl:

View File

@ -1,12 +1,15 @@
local M = {} local M = {}
---@class PersistenceOptions ---@class Persistence.Config
local defaults = { local defaults = {
dir = vim.fn.expand(vim.fn.stdpath("state") .. "/sessions/"), -- directory where session files are saved dir = vim.fn.stdpath("state") .. "/sessions/", -- directory where session files are saved
options = { "buffers", "curdir", "tabpages", "winsize" }, -- sessionoptions used for saving -- minimum number of file buffers that need to be open to save
-- Set to 0 to always save
need = 1,
branch = true, -- use git branch to save session
} }
---@type PersistenceOptions ---@type Persistence.Config
M.options = {} M.options = {}
function M.setup(opts) function M.setup(opts)

View File

@ -1,64 +1,146 @@
local Config = require("persistence.config") local Config = require("persistence.config")
local uv = vim.uv or vim.loop
local M = {} local M = {}
M._active = false
local e = vim.fn.fnameescape local e = vim.fn.fnameescape
function M.get_current() ---@param opts? {branch?: boolean}
local pattern = "/" function M.current(opts)
if vim.fn.has("win32") == 1 then opts = opts or {}
pattern = "[\\:]" local name = vim.fn.getcwd():gsub("[\\/:]+", "%%")
if Config.options.branch and opts.branch ~= false then
local branch = M.branch()
if branch and branch ~= "main" and branch ~= "master" then
name = name .. "%%" .. branch:gsub("[\\/:]+", "%%")
end
end end
local name = vim.fn.getcwd():gsub(pattern, "%%")
return Config.options.dir .. name .. ".vim" return Config.options.dir .. name .. ".vim"
end end
function M.get_last()
local sessions = M.list()
table.sort(sessions, function(a, b)
return vim.loop.fs_stat(a).mtime.sec > vim.loop.fs_stat(b).mtime.sec
end)
return sessions[1]
end
function M.setup(opts) function M.setup(opts)
Config.setup(opts) Config.setup(opts)
M.start() M.start()
end end
function M.fire(event)
vim.api.nvim_exec_autocmds("User", {
pattern = "Persistence" .. event,
})
end
-- Check if a session is active
function M.active()
return M._active
end
function M.start() function M.start()
vim.cmd([[ M._active = true
augroup Persistence vim.api.nvim_create_autocmd("VimLeavePre", {
autocmd! group = vim.api.nvim_create_augroup("persistence", { clear = true }),
autocmd VimLeavePre * lua require("persistence").save() callback = function()
augroup end M.fire("SavePre")
]])
if Config.options.need > 0 then
local bufs = vim.tbl_filter(function(b)
if vim.bo[b].buftype ~= "" or vim.tbl_contains({ "gitcommit", "gitrebase", "jj" }, vim.bo[b].filetype) then
return false
end
return vim.api.nvim_buf_get_name(b) ~= ""
end, vim.api.nvim_list_bufs())
if #bufs < Config.options.need then
return
end
end
M.save()
M.fire("SavePost")
end,
})
end end
function M.stop() function M.stop()
vim.cmd([[ M._active = false
autocmd! Persistence pcall(vim.api.nvim_del_augroup_by_name, "persistence")
augroup! Persistence
]])
end end
function M.save() function M.save()
local tmp = vim.o.sessionoptions vim.cmd("mks! " .. e(M.current()))
vim.o.sessionoptions = table.concat(Config.options.options, ",")
vim.cmd("mks! " .. e(M.get_current()))
vim.o.sessionoptions = tmp
end end
function M.load(opt) ---@param opts? { last?: boolean }
opt = opt or {} function M.load(opts)
local sfile = opt.last and M.get_last() or M.get_current() opts = opts or {}
if sfile and vim.fn.filereadable(sfile) ~= 0 then ---@type string
vim.cmd("silent! source " .. e(sfile)) local file
if opts.last then
file = M.last()
else
file = M.current()
if vim.fn.filereadable(file) == 0 then
file = M.current({ branch = false })
end
end
if file and vim.fn.filereadable(file) ~= 0 then
M.fire("LoadPre")
vim.cmd("silent! source " .. e(file))
M.fire("LoadPost")
end end
end end
---@return string[]
function M.list() function M.list()
return vim.fn.glob(Config.options.dir .. "*.vim", true, true) local sessions = vim.fn.glob(Config.options.dir .. "*.vim", true, true)
table.sort(sessions, function(a, b)
return uv.fs_stat(a).mtime.sec > uv.fs_stat(b).mtime.sec
end)
return sessions
end
function M.last()
return M.list()[1]
end
function M.select()
---@type { session: string, dir: string, branch?: string }[]
local items = {}
local have = {} ---@type table<string, boolean>
for _, session in ipairs(M.list()) do
if uv.fs_stat(session) then
local file = session:sub(#Config.options.dir + 1, -5)
local dir, branch = unpack(vim.split(file, "%%", { plain = true }))
dir = dir:gsub("%%", "/")
if jit.os:find("Windows") then
dir = dir:gsub("^(%w)/", "%1:/")
end
if not have[dir] then
have[dir] = true
items[#items + 1] = { session = session, dir = dir, branch = branch }
end
end
end
vim.ui.select(items, {
prompt = "Select a session: ",
format_item = function(item)
return vim.fn.fnamemodify(item.dir, ":p:~")
end,
}, function(item)
if item then
vim.fn.chdir(item.dir)
M.load()
end
end)
end
--- get current branch name
---@return string?
function M.branch()
if uv.fs_stat(".git") then
local ret = vim.fn.systemlist("git branch --show-current")[1]
return vim.v.shell_error == 0 and ret or nil
end
end end
return M return M

View File

@ -1 +1,4 @@
std="lua51+vim" std="vim"
[lints]
mixed_table="allow"

View File

@ -1,3 +1,6 @@
indent_type = "Spaces" indent_type = "Spaces"
indent_width = 2 indent_width = 2
column_width = 120 column_width = 120
[sort_requires]
enabled = true

View File

@ -1,2 +1,21 @@
[selene]
base = "lua51"
name = "vim"
[vim] [vim]
any = true any = true
[jit]
any = true
[assert]
any = true
[describe]
any = true
[it]
any = true
[before_each.args]
any = true