Refresh generated nvim config
This commit is contained in:
2
config/neovim/store/lazy-plugins/dashboard-nvim/.github/FUNDING.yml
vendored
Normal file
2
config/neovim/store/lazy-plugins/dashboard-nvim/.github/FUNDING.yml
vendored
Normal file
@ -0,0 +1,2 @@
|
||||
github: glepnir
|
||||
custom: ['https://www.paypal.me/bobbyhub']
|
||||
24
config/neovim/store/lazy-plugins/dashboard-nvim/.github/ISSUE_TEMPLATE/bug_report.md
vendored
Normal file
24
config/neovim/store/lazy-plugins/dashboard-nvim/.github/ISSUE_TEMPLATE/bug_report.md
vendored
Normal file
@ -0,0 +1,24 @@
|
||||
---
|
||||
name: Bug report
|
||||
about: Create a report to help us improve
|
||||
title: ''
|
||||
labels: ''
|
||||
assignees: ''
|
||||
|
||||
---
|
||||
|
||||
**Describe the bug**
|
||||
A clear and concise description of what the bug is.
|
||||
|
||||
**To Reproduce**
|
||||
Steps to reproduce the behavior:
|
||||
1. Go to '...'
|
||||
2. Click on '....'
|
||||
3. Scroll down to '....'
|
||||
4. See error
|
||||
|
||||
**Expected behavior**
|
||||
A clear and concise description of what you expected to happen.
|
||||
|
||||
**Screenshots**
|
||||
If applicable, add screenshots to help explain your problem.
|
||||
20
config/neovim/store/lazy-plugins/dashboard-nvim/.github/ISSUE_TEMPLATE/feature_request.md
vendored
Normal file
20
config/neovim/store/lazy-plugins/dashboard-nvim/.github/ISSUE_TEMPLATE/feature_request.md
vendored
Normal file
@ -0,0 +1,20 @@
|
||||
---
|
||||
name: Feature request
|
||||
about: Suggest an idea for this project
|
||||
title: ''
|
||||
labels: ''
|
||||
assignees: ''
|
||||
|
||||
---
|
||||
|
||||
**Is your feature request related to a problem? Please describe.**
|
||||
A clear and concise description of what the problem is. Ex. I'm always frustrated when [...]
|
||||
|
||||
**Describe the solution you'd like**
|
||||
A clear and concise description of what you want to happen.
|
||||
|
||||
**Describe alternatives you've considered**
|
||||
A clear and concise description of any alternative solutions or features you've considered.
|
||||
|
||||
**Additional context**
|
||||
Add any other context or screenshots about the feature request here.
|
||||
38
config/neovim/store/lazy-plugins/dashboard-nvim/.github/workflows/ci.yml
vendored
Normal file
38
config/neovim/store/lazy-plugins/dashboard-nvim/.github/workflows/ci.yml
vendored
Normal file
@ -0,0 +1,38 @@
|
||||
name: ci
|
||||
|
||||
on:
|
||||
push:
|
||||
branches:
|
||||
- master
|
||||
|
||||
pull_request:
|
||||
branches:
|
||||
- master
|
||||
|
||||
jobs:
|
||||
lint:
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- uses: actions/checkout@v3
|
||||
- name: Stylua
|
||||
uses: JohnnyMorganz/stylua-action@v1.1.2
|
||||
with:
|
||||
token: ${{ secrets.GITHUB_TOKEN }}
|
||||
args: --check .
|
||||
|
||||
docs:
|
||||
runs-on: ubuntu-latest
|
||||
name: pandoc to vimdoc
|
||||
steps:
|
||||
- uses: actions/checkout@v3
|
||||
- name: panvimdoc
|
||||
uses: kdheepak/panvimdoc@main
|
||||
with:
|
||||
vimdoc: dashboard
|
||||
version: Nvim 0.8.0
|
||||
- uses: stefanzweifel/git-auto-commit-action@v4
|
||||
with:
|
||||
commit_message: 'chore(doc): auto generate docs'
|
||||
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>"
|
||||
@ -0,0 +1,6 @@
|
||||
column_width = 100
|
||||
line_endings = "Unix"
|
||||
indent_type = "Spaces"
|
||||
indent_width = 2
|
||||
quote_style = "AutoPreferSingle"
|
||||
call_parentheses = "Always"
|
||||
21
config/neovim/store/lazy-plugins/dashboard-nvim/LICENSE
Normal file
21
config/neovim/store/lazy-plugins/dashboard-nvim/LICENSE
Normal file
@ -0,0 +1,21 @@
|
||||
MIT License
|
||||
|
||||
Copyright (c) 2020 StephenHuan
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights
|
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the Software is
|
||||
furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in all
|
||||
copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
SOFTWARE.
|
||||
250
config/neovim/store/lazy-plugins/dashboard-nvim/README.md
Normal file
250
config/neovim/store/lazy-plugins/dashboard-nvim/README.md
Normal file
@ -0,0 +1,250 @@
|
||||
<h1 align="center">
|
||||
Fancy and Blazing Fast start screen plugin of neovim
|
||||
</h1>
|
||||
|
||||
| <center>Hyper</center> | <center>Doom</center> |
|
||||
| --- | --- |
|
||||
| <center><img src="https://user-images.githubusercontent.com/41671631/215015845-b13343c4-427e-45d6-9f92-267ab909eff1.png" width=80% height=80%/></center>|<center> <img src="https://user-images.githubusercontent.com/41671631/214518543-d7d6afbf-f405-4a6f-a505-568c5a101e92.png" width=80% height=80%/> </center>|
|
||||
|
||||
# Feature
|
||||
|
||||
- Low memory usage. dashboard does not store the all user configs in memory like header etc these string will take some memory. now it will be clean after you open a file. you can still use dashboard command to open a new one , then dashboard will read the config from cache.
|
||||
- Blazing fast
|
||||
|
||||
|
||||
# Install
|
||||
|
||||
- Lazy.nvim
|
||||
|
||||
```lua
|
||||
{
|
||||
'nvimdev/dashboard-nvim',
|
||||
event = 'VimEnter',
|
||||
config = function()
|
||||
require('dashboard').setup {
|
||||
-- config
|
||||
}
|
||||
end,
|
||||
dependencies = { {'nvim-tree/nvim-web-devicons'}}
|
||||
}
|
||||
```
|
||||
|
||||
- Packer
|
||||
|
||||
```lua
|
||||
use {
|
||||
'nvimdev/dashboard-nvim',
|
||||
event = 'VimEnter',
|
||||
config = function()
|
||||
require('dashboard').setup {
|
||||
-- config
|
||||
}
|
||||
end,
|
||||
requires = {'nvim-tree/nvim-web-devicons'}
|
||||
}
|
||||
```
|
||||
|
||||
# Configuration
|
||||
|
||||
## Options
|
||||
|
||||
```lua
|
||||
theme = 'hyper' -- theme is doom and hyper default is hyper
|
||||
disable_move -- default is false disable move keymap for hyper
|
||||
shortcut_type -- shorcut type 'letter' or 'number'
|
||||
change_to_vcs_root -- default is false,for open file in hyper mru. it will change to the root of vcs
|
||||
config = {}, -- config used for theme
|
||||
hide = {
|
||||
statusline -- hide statusline default is true
|
||||
tabline -- hide the tabline
|
||||
winbar -- hide winbar
|
||||
},
|
||||
preview = {
|
||||
command -- preview command
|
||||
file_path -- preview file path
|
||||
file_height -- preview file height
|
||||
file_width -- preview file width
|
||||
},
|
||||
```
|
||||
|
||||
## Theme config
|
||||
|
||||
the `config` field is used for theme. general field
|
||||
|
||||
```lua
|
||||
config = {
|
||||
header -- type is table def
|
||||
week_header = {
|
||||
enable --boolean use a week header
|
||||
concat --concat string after time string line
|
||||
append --table append after time string line
|
||||
},
|
||||
disable_move -- boolean default is false disable move key
|
||||
}
|
||||
```
|
||||
|
||||
### Hyper
|
||||
|
||||
when use `hyper` theme the available options in `config` is
|
||||
|
||||
```lua
|
||||
config = {
|
||||
shortcut = {
|
||||
-- action can be a function type
|
||||
{ desc = string, group = 'highlight group', key = 'shortcut key', action = 'action when you press key' },
|
||||
},
|
||||
packages = { enable = true }, -- show how many plugins neovim loaded
|
||||
-- limit how many projects list, action when you press key or enter it will run this action.
|
||||
-- action can be a functino type, e.g.
|
||||
-- action = func(path) vim.cmd('Telescope find_files cwd=' .. path) end
|
||||
project = { enable = true, limit = 8, icon = 'your icon', label = '', action = 'Telescope find_files cwd=' },
|
||||
mru = { limit = 10, icon = 'your icon', label = '', cwd_only = false },
|
||||
footer = {}, -- footer
|
||||
}
|
||||
```
|
||||
|
||||
### Doom
|
||||
|
||||
when use `doom` theme the available options in `config` is
|
||||
|
||||
```lua
|
||||
config = {
|
||||
center = {
|
||||
{
|
||||
icon = '',
|
||||
icon_hl = 'group',
|
||||
desc = 'description',
|
||||
desc_hl = 'group',
|
||||
key = 'shortcut key in dashboard buffer not keymap !!',
|
||||
key_hl = 'group',
|
||||
key_format = ' [%s]', -- `%s` will be substituted with value of `key`
|
||||
action = '',
|
||||
},
|
||||
},
|
||||
footer = {},
|
||||
}
|
||||
```
|
||||
|
||||
notice if you don't link config every highlight group. you can ignore this key.
|
||||
dashboard will use default highlight group like `DashboardKey/Icon/Desc` instead
|
||||
|
||||
### Commands
|
||||
|
||||
- `Dashboard` open dashboard
|
||||
- `DbProjectDelete count` delete project in cache works for hyper theme. count is number
|
||||
- `DashboardUpdateFooter` updates the content of the Footer
|
||||
|
||||
### Highlight
|
||||
|
||||
all highlight groups
|
||||
|
||||
```
|
||||
-- General
|
||||
DashboardHeader DashboardFooter
|
||||
-- Hyper theme
|
||||
DashboardProjectTitle DashboardProjectTitleIcon DashboardProjectIcon
|
||||
DashboardMruTitle DashboardMruIcon DashboardFiles DashboardShortCutIcon
|
||||
-- Doome theme
|
||||
DashboardDesc DashboardKey DashboardIcon DashboardShortCut
|
||||
```
|
||||
|
||||
### Example config
|
||||
|
||||
example config of screenshot
|
||||
|
||||
<details>
|
||||
<summary> Hyper </summary>
|
||||
|
||||
```lua
|
||||
db.setup({
|
||||
theme = 'hyper',
|
||||
config = {
|
||||
week_header = {
|
||||
enable = true,
|
||||
},
|
||||
shortcut = {
|
||||
{ desc = ' Update', group = '@property', action = 'Lazy update', key = 'u' },
|
||||
{
|
||||
icon = ' ',
|
||||
icon_hl = '@variable',
|
||||
desc = 'Files',
|
||||
group = 'Label',
|
||||
action = 'Telescope find_files',
|
||||
key = 'f',
|
||||
},
|
||||
{
|
||||
desc = ' Apps',
|
||||
group = 'DiagnosticHint',
|
||||
action = 'Telescope app',
|
||||
key = 'a',
|
||||
},
|
||||
{
|
||||
desc = ' dotfiles',
|
||||
group = 'Number',
|
||||
action = 'Telescope dotfiles',
|
||||
key = 'd',
|
||||
},
|
||||
},
|
||||
},
|
||||
})
|
||||
```
|
||||
</details>
|
||||
|
||||
<details>
|
||||
<summary> Doom </summary>
|
||||
|
||||
```lua
|
||||
db.setup({
|
||||
theme = 'doom',
|
||||
config = {
|
||||
header = {}, --your header
|
||||
center = {
|
||||
{
|
||||
icon = ' ',
|
||||
icon_hl = 'Title',
|
||||
desc = 'Find File ',
|
||||
desc_hl = 'String',
|
||||
key = 'b',
|
||||
keymap = 'SPC f f',
|
||||
key_hl = 'Number',
|
||||
key_format = ' %s', -- remove default surrounding `[]`
|
||||
action = 'lua print(2)'
|
||||
},
|
||||
{
|
||||
icon = ' ',
|
||||
desc = 'Find Dotfiles',
|
||||
key = 'f',
|
||||
keymap = 'SPC f d',
|
||||
key_format = ' %s', -- remove default surrounding `[]`
|
||||
action = 'lua print(3)'
|
||||
},
|
||||
},
|
||||
footer = {} --your footer
|
||||
}
|
||||
})
|
||||
```
|
||||
</details
|
||||
|
||||
### Changed
|
||||
|
||||
- Removed Session as a start screen plugin speed is first.if you want use session you can take a
|
||||
look at [glepnir/dbsession.nvim](https://github.com/glepnir/dbsession.nvim)
|
||||
- Removed Ueberzug script, as the Ueberzug author has deleted the repository.
|
||||
|
||||
### TODO
|
||||
|
||||
- I will write a plugin to implement some popular terminal evaluators image protocol then I think
|
||||
can make it work with dashboard
|
||||
|
||||
# Backers
|
||||
|
||||
[@RakerZh](https://github.com/RakerZh)
|
||||
|
||||
# Donate
|
||||
|
||||
If you'd like to support my work financially, buy me a drink through Github Sponsor or [](https://paypal.me/bobbyhub)
|
||||
|
||||
|
||||
# LICENSE
|
||||
|
||||
MIT
|
||||
@ -0,0 +1,289 @@
|
||||
*dashboard.txt* For Nvim 0.8.0 Last change: 2024 May 17
|
||||
|
||||
==============================================================================
|
||||
Table of Contents *dashboard-table-of-contents*
|
||||
|
||||
1. Feature |dashboard-feature|
|
||||
2. Install |dashboard-install|
|
||||
3. Configuration |dashboard-configuration|
|
||||
- Options |dashboard-configuration-options|
|
||||
- Theme config |dashboard-configuration-theme-config|
|
||||
4. Backers |dashboard-backers|
|
||||
5. Donate |dashboard-donate|
|
||||
6. LICENSE |dashboard-license|
|
||||
7. Links |dashboard-links|
|
||||
Fancy and Blazing Fast start screen plugin of neovim ----------------------------------- -----------------------------------
|
||||
|
||||
|
||||
----------------------------------- -----------------------------------
|
||||
|
||||
==============================================================================
|
||||
1. Feature *dashboard-feature*
|
||||
|
||||
- Low memory usage. dashboard does not store the all user configs in memory like header etc these string will take some memory. now it will be clean after you open a file. you can still use dashboard command to open a new one , then dashboard will read the config from cache.
|
||||
- Blazing fast
|
||||
|
||||
|
||||
==============================================================================
|
||||
2. Install *dashboard-install*
|
||||
|
||||
- Lazy.nvim
|
||||
|
||||
>lua
|
||||
{
|
||||
'nvimdev/dashboard-nvim',
|
||||
event = 'VimEnter',
|
||||
config = function()
|
||||
require('dashboard').setup {
|
||||
-- config
|
||||
}
|
||||
end,
|
||||
dependencies = { {'nvim-tree/nvim-web-devicons'}}
|
||||
}
|
||||
<
|
||||
|
||||
- Packer
|
||||
|
||||
>lua
|
||||
use {
|
||||
'nvimdev/dashboard-nvim',
|
||||
event = 'VimEnter',
|
||||
config = function()
|
||||
require('dashboard').setup {
|
||||
-- config
|
||||
}
|
||||
end,
|
||||
requires = {'nvim-tree/nvim-web-devicons'}
|
||||
}
|
||||
<
|
||||
|
||||
|
||||
==============================================================================
|
||||
3. Configuration *dashboard-configuration*
|
||||
|
||||
|
||||
OPTIONS *dashboard-configuration-options*
|
||||
|
||||
>lua
|
||||
theme = 'hyper' -- theme is doom and hyper default is hyper
|
||||
disable_move -- default is false disable move keymap for hyper
|
||||
shortcut_type -- shorcut type 'letter' or 'number'
|
||||
change_to_vcs_root -- default is false,for open file in hyper mru. it will change to the root of vcs
|
||||
config = {}, -- config used for theme
|
||||
hide = {
|
||||
statusline -- hide statusline default is true
|
||||
tabline -- hide the tabline
|
||||
winbar -- hide winbar
|
||||
},
|
||||
preview = {
|
||||
command -- preview command
|
||||
file_path -- preview file path
|
||||
file_height -- preview file height
|
||||
file_width -- preview file width
|
||||
},
|
||||
<
|
||||
|
||||
|
||||
THEME CONFIG *dashboard-configuration-theme-config*
|
||||
|
||||
the `config` field is used for theme. general field
|
||||
|
||||
>lua
|
||||
config = {
|
||||
header -- type is table def
|
||||
week_header = {
|
||||
enable --boolean use a week header
|
||||
concat --concat string after time string line
|
||||
append --table append after time string line
|
||||
},
|
||||
disable_move -- boolean default is false disable move key
|
||||
}
|
||||
<
|
||||
|
||||
|
||||
HYPER ~
|
||||
|
||||
when use `hyper` theme the available options in `config` is
|
||||
|
||||
>lua
|
||||
config = {
|
||||
shortcut = {
|
||||
-- action can be a function type
|
||||
{ desc = string, group = 'highlight group', key = 'shortcut key', action = 'action when you press key' },
|
||||
},
|
||||
packages = { enable = true }, -- show how many plugins neovim loaded
|
||||
-- limit how many projects list, action when you press key or enter it will run this action.
|
||||
-- action can be a functino type, e.g.
|
||||
-- action = func(path) vim.cmd('Telescope find_files cwd=' .. path) end
|
||||
project = { enable = true, limit = 8, icon = 'your icon', label = '', action = 'Telescope find_files cwd=' },
|
||||
mru = { limit = 10, icon = 'your icon', label = '', cwd_only = false },
|
||||
footer = {}, -- footer
|
||||
}
|
||||
<
|
||||
|
||||
|
||||
DOOM ~
|
||||
|
||||
when use `doom` theme the available options in `config` is
|
||||
|
||||
>lua
|
||||
config = {
|
||||
center = {
|
||||
{
|
||||
icon = '',
|
||||
icon_hl = 'group',
|
||||
desc = 'description',
|
||||
desc_hl = 'group',
|
||||
key = 'shortcut key in dashboard buffer not keymap !!',
|
||||
key_hl = 'group',
|
||||
key_format = ' [%s]', -- `%s` will be substituted with value of `key`
|
||||
action = '',
|
||||
},
|
||||
},
|
||||
footer = {},
|
||||
}
|
||||
<
|
||||
|
||||
notice if you don’t link config every highlight group. you can ignore this
|
||||
key. dashboard will use default highlight group like `DashboardKey/Icon/Desc`
|
||||
instead
|
||||
|
||||
|
||||
COMMANDS ~
|
||||
|
||||
- `Dashboard` open dashboard
|
||||
- `DbProjectDelete count` delete project in cache works for hyper theme. count is number
|
||||
- `DashboardUpdateFooter` updates the content of the Footer
|
||||
|
||||
|
||||
HIGHLIGHT ~
|
||||
|
||||
all highlight groups
|
||||
|
||||
>
|
||||
-- General
|
||||
DashboardHeader DashboardFooter
|
||||
-- Hyper theme
|
||||
DashboardProjectTitle DashboardProjectTitleIcon DashboardProjectIcon
|
||||
DashboardMruTitle DashboardMruIcon DashboardFiles DashboardShortCutIcon
|
||||
-- Doome theme
|
||||
DashboardDesc DashboardKey DashboardIcon DashboardShortCut
|
||||
<
|
||||
|
||||
|
||||
EXAMPLE CONFIG ~
|
||||
|
||||
example config of screenshot
|
||||
|
||||
Hyper ~
|
||||
|
||||
>lua
|
||||
db.setup({
|
||||
theme = 'hyper',
|
||||
config = {
|
||||
week_header = {
|
||||
enable = true,
|
||||
},
|
||||
shortcut = {
|
||||
{ desc = ' Update', group = '@property', action = 'Lazy update', key = 'u' },
|
||||
{
|
||||
icon = ' ',
|
||||
icon_hl = '@variable',
|
||||
desc = 'Files',
|
||||
group = 'Label',
|
||||
action = 'Telescope find_files',
|
||||
key = 'f',
|
||||
},
|
||||
{
|
||||
desc = ' Apps',
|
||||
group = 'DiagnosticHint',
|
||||
action = 'Telescope app',
|
||||
key = 'a',
|
||||
},
|
||||
{
|
||||
desc = ' dotfiles',
|
||||
group = 'Number',
|
||||
action = 'Telescope dotfiles',
|
||||
key = 'd',
|
||||
},
|
||||
},
|
||||
},
|
||||
})
|
||||
<
|
||||
|
||||
Doom ~
|
||||
|
||||
>lua
|
||||
db.setup({
|
||||
theme = 'doom',
|
||||
config = {
|
||||
header = {}, --your header
|
||||
center = {
|
||||
{
|
||||
icon = ' ',
|
||||
icon_hl = 'Title',
|
||||
desc = 'Find File ',
|
||||
desc_hl = 'String',
|
||||
key = 'b',
|
||||
keymap = 'SPC f f',
|
||||
key_hl = 'Number',
|
||||
key_format = ' %s', -- remove default surrounding `[]`
|
||||
action = 'lua print(2)'
|
||||
},
|
||||
{
|
||||
icon = ' ',
|
||||
desc = 'Find Dotfiles',
|
||||
key = 'f',
|
||||
keymap = 'SPC f d',
|
||||
key_format = ' %s', -- remove default surrounding `[]`
|
||||
action = 'lua print(3)'
|
||||
},
|
||||
},
|
||||
footer = {} --your footer
|
||||
}
|
||||
})
|
||||
<
|
||||
|
||||
</details
|
||||
|
||||
|
||||
CHANGED ~
|
||||
|
||||
- Removed Session as a start screen plugin speed is first.if you want use session you can take a
|
||||
look at glepnir/dbsession.nvim <https://github.com/glepnir/dbsession.nvim>
|
||||
- Removed Ueberzug script, as the Ueberzug author has deleted the repository.
|
||||
|
||||
|
||||
TODO ~
|
||||
|
||||
- I will write a plugin to implement some popular terminal evaluators image protocol then I think
|
||||
can make it work with dashboard
|
||||
|
||||
|
||||
==============================================================================
|
||||
4. Backers *dashboard-backers*
|
||||
|
||||
@RakerZh <https://github.com/RakerZh>
|
||||
|
||||
|
||||
==============================================================================
|
||||
5. Donate *dashboard-donate*
|
||||
|
||||
If you’d like to support my work financially, buy me a drink through Github
|
||||
Sponsor or <https://paypal.me/bobbyhub>
|
||||
|
||||
|
||||
==============================================================================
|
||||
6. LICENSE *dashboard-license*
|
||||
|
||||
MIT
|
||||
|
||||
==============================================================================
|
||||
7. Links *dashboard-links*
|
||||
|
||||
1. *@RakerZh*:
|
||||
2. **: https://img.shields.io/badge/PayPal-00457C?style=for-the-badge&logo=paypal&logoColor=white
|
||||
|
||||
Generated by panvimdoc <https://github.com/kdheepak/panvimdoc>
|
||||
|
||||
vim:tw=78:ts=8:noet:ft=help:norl:
|
||||
11
config/neovim/store/lazy-plugins/dashboard-nvim/doc/tags
Normal file
11
config/neovim/store/lazy-plugins/dashboard-nvim/doc/tags
Normal file
@ -0,0 +1,11 @@
|
||||
dashboard-backers dashboard.txt /*dashboard-backers*
|
||||
dashboard-configuration dashboard.txt /*dashboard-configuration*
|
||||
dashboard-configuration-options dashboard.txt /*dashboard-configuration-options*
|
||||
dashboard-configuration-theme-config dashboard.txt /*dashboard-configuration-theme-config*
|
||||
dashboard-donate dashboard.txt /*dashboard-donate*
|
||||
dashboard-feature dashboard.txt /*dashboard-feature*
|
||||
dashboard-install dashboard.txt /*dashboard-install*
|
||||
dashboard-license dashboard.txt /*dashboard-license*
|
||||
dashboard-links dashboard.txt /*dashboard-links*
|
||||
dashboard-table-of-contents dashboard.txt /*dashboard-table-of-contents*
|
||||
dashboard.txt dashboard.txt /*dashboard.txt*
|
||||
@ -0,0 +1,59 @@
|
||||
local api, lsp, uv = vim.api, vim.lsp, vim.loop
|
||||
local au = {}
|
||||
local get_lsp_clients = vim.fn.has('nvim-0.10') == 1 and vim.lsp.get_clients
|
||||
or lsp.get_active_clients
|
||||
|
||||
function au.register_lsp_root(path)
|
||||
api.nvim_create_autocmd('VimLeavePre', {
|
||||
callback = function()
|
||||
local projects = {}
|
||||
for _, client in pairs(get_lsp_clients() or {}) do
|
||||
local root_dir = client.config.root_dir
|
||||
if root_dir and not vim.tbl_contains(projects, root_dir) then
|
||||
table.insert(projects, root_dir)
|
||||
end
|
||||
|
||||
for _, folder in pairs(client.workspace_folders or {}) do
|
||||
if not vim.tbl_contains(projects, folder.name) then
|
||||
table.insert(projects, folder.name)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
if #projects == 0 then
|
||||
return
|
||||
end
|
||||
|
||||
-- callback hell holy shit but simply than write a async await lib
|
||||
-- also I don't link to add a thirdpart plugin. this is just a small code
|
||||
uv.fs_open(path, 'r+', 384, function(err, fd)
|
||||
assert(not err, err)
|
||||
uv.fs_fstat(fd, function(err, stat)
|
||||
assert(not err, err)
|
||||
uv.fs_read(fd, stat.size, 0, function(err, data)
|
||||
assert(not err, err)
|
||||
local before = assert(loadstring(data))
|
||||
local plist = before()
|
||||
if plist and #plist > 10 then
|
||||
plist = vim.list_slice(plist, 10)
|
||||
end
|
||||
plist = vim.tbl_filter(function(k)
|
||||
return not vim.tbl_contains(projects, k)
|
||||
end, plist or {})
|
||||
plist = vim.list_extend(plist, projects)
|
||||
local dump = 'return ' .. vim.inspect(plist)
|
||||
uv.fs_write(fd, dump, 0, function(err, _)
|
||||
assert(not err, err)
|
||||
uv.fs_ftruncate(fd, #dump, function(err, _)
|
||||
assert(not err, err)
|
||||
uv.fs_close(fd)
|
||||
end)
|
||||
end)
|
||||
end)
|
||||
end)
|
||||
end)
|
||||
end,
|
||||
})
|
||||
end
|
||||
|
||||
return au
|
||||
@ -0,0 +1,278 @@
|
||||
local api, fn = vim.api, vim.fn
|
||||
local utils = require('dashboard.utils')
|
||||
local ctx = {}
|
||||
local db = {}
|
||||
|
||||
db.__index = db
|
||||
db.__newindex = function(t, k, v)
|
||||
rawset(t, k, v)
|
||||
end
|
||||
|
||||
local function clean_ctx()
|
||||
for k, _ in pairs(ctx) do
|
||||
ctx[k] = nil
|
||||
end
|
||||
end
|
||||
|
||||
local function cache_dir()
|
||||
local dir = utils.path_join(vim.fn.stdpath('cache'), 'dashboard')
|
||||
if fn.isdirectory(dir) == 0 then
|
||||
fn.mkdir(dir, 'p')
|
||||
end
|
||||
return dir
|
||||
end
|
||||
|
||||
local function cache_path()
|
||||
local dir = cache_dir()
|
||||
return utils.path_join(dir, 'cache')
|
||||
end
|
||||
|
||||
local function conf_cache_path()
|
||||
return utils.path_join(cache_dir(), 'conf')
|
||||
end
|
||||
|
||||
local function default_options()
|
||||
return {
|
||||
theme = 'hyper',
|
||||
disable_move = false,
|
||||
shortcut_type = 'letter',
|
||||
buffer_name = 'Dashboard',
|
||||
change_to_vcs_root = false,
|
||||
config = {
|
||||
week_header = {
|
||||
enable = false,
|
||||
concat = nil,
|
||||
append = nil,
|
||||
},
|
||||
},
|
||||
hide = {
|
||||
statusline = true,
|
||||
tabline = true,
|
||||
},
|
||||
preview = {
|
||||
command = '',
|
||||
file_path = nil,
|
||||
file_height = 0,
|
||||
file_width = 0,
|
||||
},
|
||||
}
|
||||
end
|
||||
|
||||
local function buf_local()
|
||||
local opts = {
|
||||
['bufhidden'] = 'wipe',
|
||||
['colorcolumn'] = '',
|
||||
['foldcolumn'] = '0',
|
||||
['matchpairs'] = '',
|
||||
['buflisted'] = false,
|
||||
['cursorcolumn'] = false,
|
||||
['cursorline'] = false,
|
||||
['list'] = false,
|
||||
['number'] = false,
|
||||
['relativenumber'] = false,
|
||||
['spell'] = false,
|
||||
['swapfile'] = false,
|
||||
['readonly'] = false,
|
||||
['filetype'] = 'dashboard',
|
||||
['wrap'] = false,
|
||||
['signcolumn'] = 'no',
|
||||
['winbar'] = '',
|
||||
}
|
||||
for opt, val in pairs(opts) do
|
||||
vim.opt_local[opt] = val
|
||||
end
|
||||
if fn.has('nvim-0.9') == 1 then
|
||||
vim.opt_local.stc = ''
|
||||
end
|
||||
end
|
||||
|
||||
function db:new_file()
|
||||
vim.cmd('enew')
|
||||
if self.user_laststatus_value then
|
||||
vim.opt_local.laststatus = self.user_laststatus_value
|
||||
self.user_laststatus_value = nil
|
||||
end
|
||||
|
||||
if self.user_tabline_value then
|
||||
vim.opt_local.showtabline = self.user_showtabline_value
|
||||
self.user_showtabline_value = nil
|
||||
end
|
||||
end
|
||||
|
||||
-- cache the user options value restore after leave the dahsboard buffer
|
||||
-- or use DashboardNewFile command
|
||||
function db:cache_ui_options(opts)
|
||||
if opts.hide.statusline then
|
||||
---@diagnostic disable-next-line: param-type-mismatch
|
||||
self.user_laststatus_value = vim.opt.laststatus:get()
|
||||
vim.opt.laststatus = 0
|
||||
end
|
||||
if opts.hide.tabline then
|
||||
---@diagnostic disable-next-line: param-type-mismatch
|
||||
self.user_tabline_value = vim.opt.showtabline:get()
|
||||
vim.opt.showtabline = 0
|
||||
end
|
||||
end
|
||||
|
||||
function db:restore_options()
|
||||
if self.user_cursor_line then
|
||||
vim.opt.cursorline = self.user_cursor_line
|
||||
self.user_cursor_line = nil
|
||||
end
|
||||
|
||||
if self.user_laststatus_value then
|
||||
vim.opt.laststatus = tonumber(self.user_laststatus_value)
|
||||
self.user_laststatus_value = nil
|
||||
end
|
||||
|
||||
if self.user_tabline_value then
|
||||
vim.opt.showtabline = tonumber(self.user_tabline_value)
|
||||
self.user_tabline_value = nil
|
||||
end
|
||||
end
|
||||
|
||||
function db:cache_opts()
|
||||
if not self.opts then
|
||||
return
|
||||
end
|
||||
local uv = vim.loop
|
||||
local path = conf_cache_path()
|
||||
if self.opts.config.shortcut then
|
||||
for _, item in pairs(self.opts.config.shortcut) do
|
||||
if type(item.action) == 'function' then
|
||||
---@diagnostic disable-next-line: param-type-mismatch
|
||||
local dump = assert(string.dump(item.action))
|
||||
item.action = dump
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
if self.opts.config.project and type(self.opts.config.project.action) == 'function' then
|
||||
---@diagnostic disable-next-line: param-type-mismatch
|
||||
local dump = assert(string.dump(self.opts.config.project.action))
|
||||
self.opts.config.project.action = dump
|
||||
end
|
||||
|
||||
if self.opts.config.center then
|
||||
for _, item in pairs(self.opts.config.center) do
|
||||
if type(item.action) == 'function' then
|
||||
---@diagnostic disable-next-line: param-type-mismatch
|
||||
local dump = assert(string.dump(item.action))
|
||||
item.action = dump
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
if self.opts.config.footer and type(self.opts.config.footer) == 'function' then
|
||||
---@diagnostic disable-next-line: param-type-mismatch
|
||||
local dump = assert(string.dump(self.opts.config.footer))
|
||||
self.opts.config.footer = dump
|
||||
end
|
||||
|
||||
local dump = vim.json.encode(self.opts)
|
||||
uv.fs_open(path, 'w+', tonumber('664', 8), function(err, fd)
|
||||
assert(not err, err)
|
||||
---@diagnostic disable-next-line: redefined-local
|
||||
uv.fs_write(fd, dump, 0, function(err, _)
|
||||
assert(not err, err)
|
||||
uv.fs_close(fd)
|
||||
end)
|
||||
end)
|
||||
end
|
||||
|
||||
function db:get_opts(callback)
|
||||
utils.async_read(
|
||||
conf_cache_path(),
|
||||
vim.schedule_wrap(function(data)
|
||||
if not data or #data == 0 then
|
||||
return
|
||||
end
|
||||
local obj = vim.json.decode(data)
|
||||
if obj then
|
||||
callback(obj)
|
||||
end
|
||||
end)
|
||||
)
|
||||
end
|
||||
|
||||
function db:load_theme(opts)
|
||||
local config = vim.tbl_extend('force', opts.config, {
|
||||
path = cache_path(),
|
||||
bufnr = self.bufnr,
|
||||
winid = self.winid,
|
||||
confirm_key = opts.confirm_key or nil,
|
||||
shortcut_type = opts.shortcut_type,
|
||||
change_to_vcs_root = opts.change_to_vcs_root,
|
||||
})
|
||||
|
||||
if #opts.preview.command > 0 then
|
||||
config = vim.tbl_extend('force', config, opts.preview)
|
||||
end
|
||||
|
||||
require('dashboard.theme.' .. opts.theme)(config)
|
||||
self:cache_ui_options(opts)
|
||||
|
||||
api.nvim_create_autocmd('VimResized', {
|
||||
buffer = self.bufnr,
|
||||
callback = function()
|
||||
require('dashboard.theme.' .. opts.theme)(config)
|
||||
vim.bo[self.bufnr].modifiable = false
|
||||
end,
|
||||
})
|
||||
|
||||
api.nvim_create_autocmd('BufEnter', {
|
||||
callback = function(opt)
|
||||
local bufs = api.nvim_list_bufs()
|
||||
bufs = vim.tbl_filter(function(k)
|
||||
return vim.bo[k].filetype == 'dashboard'
|
||||
end, bufs)
|
||||
if #bufs == 0 then
|
||||
self:cache_opts()
|
||||
self:restore_options()
|
||||
clean_ctx()
|
||||
pcall(api.nvim_del_autocmd, opt.id)
|
||||
end
|
||||
end,
|
||||
desc = '[Dashboard] clean dashboard data reduce memory',
|
||||
})
|
||||
end
|
||||
|
||||
-- create dashboard instance
|
||||
function db:instance()
|
||||
local mode = api.nvim_get_mode().mode
|
||||
if mode == 'i' or not vim.bo.modifiable then
|
||||
return
|
||||
end
|
||||
|
||||
if not vim.o.hidden and vim.bo.modified then
|
||||
--save before open
|
||||
vim.cmd.write()
|
||||
return
|
||||
end
|
||||
|
||||
if not utils.buf_is_empty(0) then
|
||||
self.bufnr = api.nvim_create_buf(false, true)
|
||||
else
|
||||
self.bufnr = api.nvim_get_current_buf()
|
||||
end
|
||||
|
||||
self.winid = api.nvim_get_current_win()
|
||||
api.nvim_win_set_buf(self.winid, self.bufnr)
|
||||
|
||||
self.user_cursor_line = vim.opt.cursorline:get()
|
||||
buf_local()
|
||||
if self.opts then
|
||||
self:load_theme(self.opts)
|
||||
else
|
||||
self:get_opts(function(obj)
|
||||
self:load_theme(obj)
|
||||
end)
|
||||
end
|
||||
end
|
||||
|
||||
function db.setup(opts)
|
||||
opts = opts or {}
|
||||
ctx.opts = vim.tbl_deep_extend('force', default_options(), opts)
|
||||
end
|
||||
|
||||
return setmetatable(ctx, db)
|
||||
@ -0,0 +1,138 @@
|
||||
local api = vim.api
|
||||
local db = require('dashboard')
|
||||
|
||||
local view = {}
|
||||
|
||||
function view:open_window(opt)
|
||||
local row = math.floor(opt.height / 5)
|
||||
local col = math.floor((vim.o.columns - opt.width) / 2)
|
||||
|
||||
local opts = {
|
||||
relative = 'editor',
|
||||
row = row,
|
||||
col = col,
|
||||
width = opt.width,
|
||||
height = opt.height,
|
||||
style = 'minimal',
|
||||
noautocmd = true,
|
||||
}
|
||||
|
||||
self.bufnr = api.nvim_create_buf(false, true)
|
||||
api.nvim_buf_set_option(self.bufnr, 'filetype', 'dashboardpreview')
|
||||
self.winid = api.nvim_open_win(self.bufnr, false, opts)
|
||||
if vim.fn.has('nvim-0.8') == 1 then
|
||||
local normal = api.nvim_get_hl_by_name('Normal', true)
|
||||
pcall(api.nvim_set_hl, 0, 'DashboardPreview', normal)
|
||||
else
|
||||
api.nvim_set_hl(0, 'DashboardPreview', { bg = 'none' })
|
||||
end
|
||||
api.nvim_win_set_option(self.winid, 'winhl', 'Normal:DashboardPreview')
|
||||
return { self.bufnr, self.winid }
|
||||
end
|
||||
|
||||
function view:close_preview_window()
|
||||
if self.bufnr and api.nvim_buf_is_loaded(self.bufnr) then
|
||||
api.nvim_buf_delete(self.bufnr, { force = true })
|
||||
self.bufnr = nil
|
||||
end
|
||||
|
||||
if self.winid and api.nvim_win_is_valid(self.winid) then
|
||||
api.nvim_win_close(self.winid, true)
|
||||
self.winid = nil
|
||||
end
|
||||
end
|
||||
|
||||
function view:preview_events()
|
||||
local group =
|
||||
api.nvim_create_augroup('DashboardClosePreview' .. self.preview_bufnr, { clear = true })
|
||||
|
||||
--refresh the preview window col position.
|
||||
local function refresh_preview_wincol()
|
||||
if not self.preview_winid or not api.nvim_win_is_valid(self.preview_winid) then
|
||||
return
|
||||
end
|
||||
|
||||
local winconfig = api.nvim_win_get_config(self.preview_winid)
|
||||
local cur_width = api.nvim_win_get_width(self.main_winid)
|
||||
if cur_width ~= self.win_width then
|
||||
local wins = api.nvim_list_wins()
|
||||
if #wins == 2 then
|
||||
local scol = bit.rshift(vim.o.columns, 1) - bit.rshift(winconfig.width, 1)
|
||||
winconfig.col[false] = scol
|
||||
api.nvim_win_set_config(self.preview_winid, winconfig)
|
||||
self.win_width = cur_width
|
||||
return
|
||||
end
|
||||
|
||||
if #wins == 3 then
|
||||
local new_win = vim.tbl_filter(function(k)
|
||||
return k ~= self.main_winid and k ~= self.preview_winid
|
||||
end, wins)[1]
|
||||
winconfig.col[false] = winconfig.col[false] + api.nvim_win_get_width(new_win)
|
||||
api.nvim_win_set_config(self.preview_winid, winconfig)
|
||||
self.win_width = cur_width
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
local function winresized()
|
||||
api.nvim_create_autocmd('WinResized', {
|
||||
group = group,
|
||||
callback = function()
|
||||
refresh_preview_wincol()
|
||||
end,
|
||||
desc = ' Dashboard preview window resized for nvim 0.9',
|
||||
})
|
||||
end
|
||||
|
||||
api.nvim_create_autocmd('VimResized', {
|
||||
group = group,
|
||||
callback = function()
|
||||
refresh_preview_wincol()
|
||||
end,
|
||||
})
|
||||
|
||||
if vim.fn.has('nvim-0.9') == 1 then
|
||||
winresized()
|
||||
else
|
||||
---@deprecated when 0.9 version release remove
|
||||
api.nvim_create_autocmd('BufEnter', {
|
||||
group = group,
|
||||
callback = function()
|
||||
refresh_preview_wincol()
|
||||
end,
|
||||
desc = 'dashboard preview window resize for neovim 0.8+ version',
|
||||
})
|
||||
end
|
||||
end
|
||||
|
||||
function view:open_preview(opt)
|
||||
self.preview_bufnr, self.preview_winid = unpack(view:open_window(opt))
|
||||
|
||||
api.nvim_buf_call(self.preview_bufnr, function()
|
||||
vim.fn.termopen(opt.cmd, {
|
||||
on_exit = function() end,
|
||||
})
|
||||
end)
|
||||
self.main_winid = api.nvim_get_current_win()
|
||||
self.win_width = api.nvim_win_get_width(self.main_winid)
|
||||
|
||||
api.nvim_create_autocmd('BufWipeout', {
|
||||
buffer = db.bufnr,
|
||||
callback = function()
|
||||
if self.winid and api.nvim_win_is_valid(self.preview_winid) then
|
||||
api.nvim_win_close(self.preview_winid, true)
|
||||
self.preview_winid = nil
|
||||
self.preview_bufnr = nil
|
||||
self.main_winid = nil
|
||||
self.win_width = nil
|
||||
end
|
||||
end,
|
||||
once = true,
|
||||
desc = 'make preview have same lifetime with dashboard buffer',
|
||||
})
|
||||
|
||||
self:preview_events()
|
||||
end
|
||||
|
||||
return view
|
||||
@ -0,0 +1,225 @@
|
||||
local api, keymap = vim.api, vim.keymap
|
||||
local utils = require('dashboard.utils')
|
||||
|
||||
local function generate_center(config)
|
||||
local lines = {}
|
||||
local center = config.center
|
||||
or {
|
||||
{ desc = 'Please config your own center section', key = 'p' },
|
||||
}
|
||||
|
||||
local counts = {}
|
||||
for _, item in pairs(center) do
|
||||
local count = item.keymap and #item.keymap or 0
|
||||
local line = (item.icon or '') .. item.desc
|
||||
|
||||
if item.key then
|
||||
line = line .. (' '):rep(#item.key + 4)
|
||||
count = count + #item.key + 3
|
||||
local desc = 'Dashboard-action: ' .. item.desc:gsub('^%s+', '')
|
||||
keymap.set('n', item.key, function()
|
||||
if type(item.action) == 'string' then
|
||||
local dump = loadstring(item.action)
|
||||
if not dump then
|
||||
vim.cmd(item.action)
|
||||
else
|
||||
dump()
|
||||
end
|
||||
elseif type(item.action) == 'function' then
|
||||
item.action()
|
||||
end
|
||||
end, { buffer = config.bufnr, nowait = true, silent = true, desc = desc })
|
||||
end
|
||||
|
||||
if item.keymap then
|
||||
line = line .. (' '):rep(#item.keymap)
|
||||
end
|
||||
|
||||
table.insert(lines, line)
|
||||
table.insert(lines, '')
|
||||
table.insert(counts, count)
|
||||
table.insert(counts, 0)
|
||||
end
|
||||
|
||||
lines = utils.element_align(lines)
|
||||
lines = utils.center_align(lines)
|
||||
for i, count in ipairs(counts) do
|
||||
lines[i] = lines[i]:sub(1, #lines[i] - count)
|
||||
end
|
||||
|
||||
local first_line = api.nvim_buf_line_count(config.bufnr)
|
||||
api.nvim_buf_set_lines(config.bufnr, first_line, -1, false, lines)
|
||||
|
||||
if not config.center then
|
||||
return
|
||||
end
|
||||
|
||||
local ns = api.nvim_create_namespace('DashboardDoom')
|
||||
local seed = 0
|
||||
local pos_map = {}
|
||||
for i = 1, #lines do
|
||||
if lines[i]:find('%w') then
|
||||
local idx = i == 1 and i or i - seed
|
||||
seed = seed + 1
|
||||
pos_map[i] = idx
|
||||
local _, scol = lines[i]:find('%s+')
|
||||
local ecol = scol + (config.center[idx].icon and #config.center[idx].icon or 0)
|
||||
|
||||
if config.center[idx].icon then
|
||||
api.nvim_buf_add_highlight(
|
||||
config.bufnr,
|
||||
0,
|
||||
config.center[idx].icon_hl or 'DashboardIcon',
|
||||
first_line + i - 1,
|
||||
0,
|
||||
ecol
|
||||
)
|
||||
end
|
||||
|
||||
api.nvim_buf_add_highlight(
|
||||
config.bufnr,
|
||||
0,
|
||||
config.center[idx].desc_hl or 'DashboardDesc',
|
||||
first_line + i - 1,
|
||||
ecol,
|
||||
-1
|
||||
)
|
||||
|
||||
if config.center[idx].key then
|
||||
local virt_tbl = {}
|
||||
if config.center[idx].keymap then
|
||||
table.insert(virt_tbl, { config.center[idx].keymap, 'DashboardShortCut' })
|
||||
end
|
||||
table.insert(virt_tbl, {
|
||||
string.format(config.center[idx].key_format or ' [%s]', config.center[idx].key),
|
||||
config.center[idx].key_hl or 'DashboardKey',
|
||||
})
|
||||
api.nvim_buf_set_extmark(config.bufnr, ns, first_line + i - 1, 0, {
|
||||
virt_text_pos = 'eol',
|
||||
virt_text = virt_tbl,
|
||||
})
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
local line = api.nvim_buf_get_lines(config.bufnr, first_line, first_line + 1, false)[1]
|
||||
local col = line:find('%w')
|
||||
local col_width = api.nvim_strwidth(line:sub(1, col))
|
||||
col = col and col - 1 or 9999
|
||||
api.nvim_win_set_cursor(config.winid, { first_line + 1, col })
|
||||
|
||||
local bottom = api.nvim_buf_line_count(config.bufnr)
|
||||
vim.defer_fn(function()
|
||||
local before = 0
|
||||
if api.nvim_get_current_buf() ~= config.bufnr then
|
||||
return
|
||||
end
|
||||
api.nvim_create_autocmd('CursorMoved', {
|
||||
buffer = config.bufnr,
|
||||
callback = function()
|
||||
local buf = api.nvim_win_get_buf(0)
|
||||
if vim.api.nvim_buf_get_option(buf, 'filetype') ~= 'dashboard' then
|
||||
return
|
||||
end
|
||||
|
||||
local curline = api.nvim_win_get_cursor(0)[1]
|
||||
if curline < first_line + 1 then
|
||||
curline = bottom - 1
|
||||
elseif curline > bottom - 1 then
|
||||
curline = first_line + 1
|
||||
elseif not api.nvim_get_current_line():find('%w') then
|
||||
curline = curline + (before > curline and -1 or 1)
|
||||
end
|
||||
before = curline
|
||||
|
||||
-- FIX: #422: In Lua the length of a string is the numbers of bytes not
|
||||
-- the number of characters.
|
||||
local curline_str = api.nvim_buf_get_lines(config.bufnr, curline - 1, curline, false)[1]
|
||||
local delta = col_width - api.nvim_strwidth(curline_str:sub(1, col + 1))
|
||||
api.nvim_win_set_cursor(config.winid, { curline, col + delta })
|
||||
end,
|
||||
})
|
||||
end, 0)
|
||||
|
||||
keymap.set('n', config.confirm_key or '<CR>', function()
|
||||
local curline = api.nvim_win_get_cursor(0)[1]
|
||||
local index = pos_map[curline - first_line]
|
||||
if index and config.center[index].action then
|
||||
if type(config.center[index].action) == 'string' then
|
||||
local dump = loadstring(config.center[index].action)
|
||||
if not dump then
|
||||
vim.cmd(config.center[index].action)
|
||||
else
|
||||
dump()
|
||||
end
|
||||
elseif type(config.center[index].action) == 'function' then
|
||||
config.center[index].action()
|
||||
else
|
||||
print('Error with action, check your config')
|
||||
end
|
||||
end
|
||||
end, { buffer = config.bufnr, nowait = true, silent = true })
|
||||
end
|
||||
|
||||
local function generate_footer(config)
|
||||
local first_line = api.nvim_buf_line_count(config.bufnr)
|
||||
local package_manager_stats = utils.get_package_manager_stats()
|
||||
local footer = {}
|
||||
if package_manager_stats.name == 'lazy' then
|
||||
footer = {
|
||||
'',
|
||||
'',
|
||||
'Startuptime: ' .. package_manager_stats.time .. ' ms',
|
||||
'Plugins: '
|
||||
.. package_manager_stats.loaded
|
||||
.. ' loaded / '
|
||||
.. package_manager_stats.count
|
||||
.. ' installed',
|
||||
}
|
||||
else
|
||||
footer = {
|
||||
'',
|
||||
'neovim loaded ' .. package_manager_stats.count .. ' plugins',
|
||||
}
|
||||
end
|
||||
if config.footer then
|
||||
if type(config.footer) == 'function' then
|
||||
footer = config.footer()
|
||||
elseif type(config.footer) == 'string' then
|
||||
local dump = loadstring(config.footer)
|
||||
if dump then
|
||||
footer = dump()
|
||||
end
|
||||
elseif type(config.footer) == 'table' then
|
||||
footer = config.footer
|
||||
end
|
||||
end
|
||||
api.nvim_buf_set_lines(config.bufnr, first_line, -1, false, utils.center_align(footer))
|
||||
for i = 1, #footer do
|
||||
api.nvim_buf_add_highlight(config.bufnr, 0, 'DashboardFooter', first_line + i - 1, 0, -1)
|
||||
end
|
||||
|
||||
utils.add_update_footer_command(config.bufnr, footer)
|
||||
end
|
||||
|
||||
---@private
|
||||
local function theme_instance(config)
|
||||
require('dashboard.theme.header').generate_header(config)
|
||||
generate_center(config)
|
||||
generate_footer(config)
|
||||
api.nvim_set_option_value('modifiable', false, { buf = config.bufnr })
|
||||
api.nvim_set_option_value('modified', false, { buf = config.bufnr })
|
||||
--defer until next event loop
|
||||
vim.schedule(function()
|
||||
api.nvim_exec_autocmds('User', {
|
||||
pattern = 'DashboardLoaded',
|
||||
modeline = false,
|
||||
})
|
||||
end)
|
||||
end
|
||||
|
||||
return setmetatable({}, {
|
||||
__call = function(_, t)
|
||||
return theme_instance(t)
|
||||
end,
|
||||
})
|
||||
@ -0,0 +1,135 @@
|
||||
local api = vim.api
|
||||
local utils = require('dashboard.utils')
|
||||
|
||||
local function week_ascii_text()
|
||||
return {
|
||||
['Monday'] = {
|
||||
'',
|
||||
'███╗ ███╗ ██████╗ ███╗ ██╗██████╗ █████╗ ██╗ ██╗',
|
||||
'████╗ ████║██╔═══██╗████╗ ██║██╔══██╗██╔══██╗╚██╗ ██╔╝',
|
||||
'██╔████╔██║██║ ██║██╔██╗ ██║██║ ██║███████║ ╚████╔╝ ',
|
||||
'██║╚██╔╝██║██║ ██║██║╚██╗██║██║ ██║██╔══██║ ╚██╔╝ ',
|
||||
'██║ ╚═╝ ██║╚██████╔╝██║ ╚████║██████╔╝██║ ██║ ██║ ',
|
||||
'╚═╝ ╚═╝ ╚═════╝ ╚═╝ ╚═══╝╚═════╝ ╚═╝ ╚═╝ ╚═╝ ',
|
||||
'',
|
||||
},
|
||||
['Tuesday'] = {
|
||||
'',
|
||||
'████████╗██╗ ██╗███████╗███████╗██████╗ █████╗ ██╗ ██╗',
|
||||
'╚══██╔══╝██║ ██║██╔════╝██╔════╝██╔══██╗██╔══██╗╚██╗ ██╔╝',
|
||||
' ██║ ██║ ██║█████╗ ███████╗██║ ██║███████║ ╚████╔╝ ',
|
||||
' ██║ ██║ ██║██╔══╝ ╚════██║██║ ██║██╔══██║ ╚██╔╝ ',
|
||||
' ██║ ╚██████╔╝███████╗███████║██████╔╝██║ ██║ ██║ ',
|
||||
' ╚═╝ ╚═════╝ ╚══════╝╚══════╝╚═════╝ ╚═╝ ╚═╝ ╚═╝ ',
|
||||
'',
|
||||
},
|
||||
['Wednesday'] = {
|
||||
'',
|
||||
'██╗ ██╗███████╗██████╗ ███╗ ██╗███████╗███████╗██████╗ █████╗ ██╗ ██╗',
|
||||
'██║ ██║██╔════╝██╔══██╗████╗ ██║██╔════╝██╔════╝██╔══██╗██╔══██╗╚██╗ ██╔╝',
|
||||
'██║ █╗ ██║█████╗ ██║ ██║██╔██╗ ██║█████╗ ███████╗██║ ██║███████║ ╚████╔╝ ',
|
||||
'██║███╗██║██╔══╝ ██║ ██║██║╚██╗██║██╔══╝ ╚════██║██║ ██║██╔══██║ ╚██╔╝ ',
|
||||
'╚███╔███╔╝███████╗██████╔╝██║ ╚████║███████╗███████║██████╔╝██║ ██║ ██║ ',
|
||||
' ╚══╝╚══╝ ╚══════╝╚═════╝ ╚═╝ ╚═══╝╚══════╝╚══════╝╚═════╝ ╚═╝ ╚═╝ ╚═╝ ',
|
||||
'',
|
||||
},
|
||||
['Thursday'] = {
|
||||
'',
|
||||
'████████╗██╗ ██╗██╗ ██╗██████╗ ███████╗██████╗ █████╗ ██╗ ██╗',
|
||||
'╚══██╔══╝██║ ██║██║ ██║██╔══██╗██╔════╝██╔══██╗██╔══██╗╚██╗ ██╔╝',
|
||||
' ██║ ███████║██║ ██║██████╔╝███████╗██║ ██║███████║ ╚████╔╝ ',
|
||||
' ██║ ██╔══██║██║ ██║██╔══██╗╚════██║██║ ██║██╔══██║ ╚██╔╝ ',
|
||||
' ██║ ██║ ██║╚██████╔╝██║ ██║███████║██████╔╝██║ ██║ ██║ ',
|
||||
' ╚═╝ ╚═╝ ╚═╝ ╚═════╝ ╚═╝ ╚═╝╚══════╝╚═════╝ ╚═╝ ╚═╝ ╚═╝ ',
|
||||
'',
|
||||
},
|
||||
['Friday'] = {
|
||||
'',
|
||||
'███████╗██████╗ ██╗██████╗ █████╗ ██╗ ██╗',
|
||||
'██╔════╝██╔══██╗██║██╔══██╗██╔══██╗╚██╗ ██╔╝',
|
||||
'█████╗ ██████╔╝██║██║ ██║███████║ ╚████╔╝ ',
|
||||
'██╔══╝ ██╔══██╗██║██║ ██║██╔══██║ ╚██╔╝ ',
|
||||
'██║ ██║ ██║██║██████╔╝██║ ██║ ██║ ',
|
||||
'╚═╝ ╚═╝ ╚═╝╚═╝╚═════╝ ╚═╝ ╚═╝ ╚═╝ ',
|
||||
'',
|
||||
},
|
||||
['Saturday'] = {
|
||||
'',
|
||||
'███████╗ █████╗ ████████╗██╗ ██╗██████╗ ██████╗ █████╗ ██╗ ██╗',
|
||||
'██╔════╝██╔══██╗╚══██╔══╝██║ ██║██╔══██╗██╔══██╗██╔══██╗╚██╗ ██╔╝',
|
||||
'███████╗███████║ ██║ ██║ ██║██████╔╝██║ ██║███████║ ╚████╔╝ ',
|
||||
'╚════██║██╔══██║ ██║ ██║ ██║██╔══██╗██║ ██║██╔══██║ ╚██╔╝ ',
|
||||
'███████║██║ ██║ ██║ ╚██████╔╝██║ ██║██████╔╝██║ ██║ ██║ ',
|
||||
'╚══════╝╚═╝ ╚═╝ ╚═╝ ╚═════╝ ╚═╝ ╚═╝╚═════╝ ╚═╝ ╚═╝ ╚═╝ ',
|
||||
'',
|
||||
},
|
||||
['Sunday'] = {
|
||||
'',
|
||||
'███████╗██╗ ██╗███╗ ██╗██████╗ █████╗ ██╗ ██╗',
|
||||
'██╔════╝██║ ██║████╗ ██║██╔══██╗██╔══██╗╚██╗ ██╔╝',
|
||||
'███████╗██║ ██║██╔██╗ ██║██║ ██║███████║ ╚████╔╝ ',
|
||||
'╚════██║██║ ██║██║╚██╗██║██║ ██║██╔══██║ ╚██╔╝ ',
|
||||
'███████║╚██████╔╝██║ ╚████║██████╔╝██║ ██║ ██║ ',
|
||||
'╚══════╝ ╚═════╝ ╚═╝ ╚═══╝╚═════╝ ╚═╝ ╚═╝ ╚═╝ ',
|
||||
'',
|
||||
},
|
||||
}
|
||||
end
|
||||
|
||||
local function default_header()
|
||||
return {
|
||||
'',
|
||||
' ██████╗ █████╗ ███████╗██╗ ██╗██████╗ ██████╗ █████╗ ██████╗ ██████╗ ',
|
||||
' ██╔══██╗██╔══██╗██╔════╝██║ ██║██╔══██╗██╔═══██╗██╔══██╗██╔══██╗██╔══██╗ ',
|
||||
' ██║ ██║███████║███████╗███████║██████╔╝██║ ██║███████║██████╔╝██║ ██║ ',
|
||||
' ██║ ██║██╔══██║╚════██║██╔══██║██╔══██╗██║ ██║██╔══██║██╔══██╗██║ ██║ ',
|
||||
' ██████╔╝██║ ██║███████║██║ ██║██████╔╝╚██████╔╝██║ ██║██║ ██║██████╔╝ ',
|
||||
' ╚═════╝ ╚═╝ ╚═╝╚══════╝╚═╝ ╚═╝╚═════╝ ╚═════╝ ╚═╝ ╚═╝╚═╝ ╚═╝╚═════╝ ',
|
||||
'',
|
||||
}
|
||||
end
|
||||
|
||||
local function week_header(concat, append)
|
||||
local week = week_ascii_text()
|
||||
local daysoftheweek =
|
||||
{ 'Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday' }
|
||||
local day = daysoftheweek[os.date('*t').wday]
|
||||
local tbl = week[day]
|
||||
table.insert(tbl, os.date('%Y-%m-%d %H:%M:%S ') .. (concat or ''))
|
||||
if append then
|
||||
vim.list_extend(tbl, append)
|
||||
end
|
||||
table.insert(tbl, '')
|
||||
return tbl
|
||||
end
|
||||
|
||||
local function generate_header(config)
|
||||
if not vim.bo[config.bufnr].modifiable then
|
||||
vim.bo[config.bufnr].modifiable = true
|
||||
end
|
||||
if not config.command then
|
||||
local header = config.week_header
|
||||
and config.week_header.enable
|
||||
and week_header(config.week_header.concat, config.week_header.append)
|
||||
or (config.header or default_header())
|
||||
api.nvim_buf_set_lines(config.bufnr, 0, -1, false, utils.center_align(header))
|
||||
|
||||
for i, _ in ipairs(header) do
|
||||
vim.api.nvim_buf_add_highlight(config.bufnr, 0, 'DashboardHeader', i - 1, 0, -1)
|
||||
end
|
||||
return
|
||||
end
|
||||
|
||||
local empty_table = utils.generate_empty_table(config.file_height + 4)
|
||||
api.nvim_buf_set_lines(config.bufnr, 0, -1, false, utils.center_align(empty_table))
|
||||
local preview = require('dashboard.preview')
|
||||
preview:open_preview({
|
||||
width = config.file_width,
|
||||
height = config.file_height,
|
||||
cmd = config.command .. ' ' .. config.file_path,
|
||||
})
|
||||
end
|
||||
|
||||
return {
|
||||
generate_header = generate_header,
|
||||
}
|
||||
@ -0,0 +1,533 @@
|
||||
local api, keymap, uv = vim.api, vim.keymap, vim.loop
|
||||
local utils = require('dashboard.utils')
|
||||
local ns = api.nvim_create_namespace('dashboard')
|
||||
|
||||
local function gen_shortcut(config)
|
||||
local shortcut = config.shortcut
|
||||
or {
|
||||
{ desc = '[ Github]', group = 'DashboardShortCut' },
|
||||
{ desc = '[ glepnir]', group = 'DashboardShortCut' },
|
||||
{ desc = '[ 0.2.3]', group = 'DashboardShortCut' },
|
||||
}
|
||||
|
||||
if vim.tbl_isempty(shortcut) then
|
||||
shortcut = {}
|
||||
end
|
||||
|
||||
local lines = ''
|
||||
for _, item in pairs(shortcut) do
|
||||
local str = item.icon and item.icon .. item.desc or item.desc
|
||||
if item.key then
|
||||
str = str .. '[' .. item.key .. ']'
|
||||
end
|
||||
lines = lines .. ' ' .. str
|
||||
end
|
||||
|
||||
local first_line = api.nvim_buf_line_count(config.bufnr)
|
||||
api.nvim_buf_set_lines(config.bufnr, first_line, -1, false, utils.center_align({ lines }))
|
||||
|
||||
local line = api.nvim_buf_get_lines(config.bufnr, first_line, -1, false)[1]
|
||||
local start = line:find('[^%s]') - 1
|
||||
for _, item in pairs(shortcut) do
|
||||
local _end = start + (item.icon and #(item.icon .. item.desc) or #item.desc)
|
||||
if item.key then
|
||||
_end = _end + api.nvim_strwidth(item.key) + 2
|
||||
keymap.set('n', item.key, function()
|
||||
if type(item.action) == 'string' then
|
||||
local dump = loadstring(item.action)
|
||||
if not dump then
|
||||
vim.cmd(item.action)
|
||||
else
|
||||
dump()
|
||||
end
|
||||
elseif type(item.action) == 'function' then
|
||||
item.action()
|
||||
end
|
||||
end, { buffer = config.bufnr, nowait = true, silent = true })
|
||||
end
|
||||
|
||||
api.nvim_buf_add_highlight(
|
||||
config.bufnr,
|
||||
0,
|
||||
item.group or 'DashboardShortCut',
|
||||
first_line,
|
||||
start,
|
||||
_end
|
||||
)
|
||||
|
||||
if item.icon then
|
||||
api.nvim_buf_add_highlight(
|
||||
config.bufnr,
|
||||
0,
|
||||
item.icon_hl or 'DashboardShortCutIcon',
|
||||
first_line,
|
||||
start,
|
||||
start + #item.icon
|
||||
)
|
||||
end
|
||||
start = _end + 2
|
||||
end
|
||||
end
|
||||
|
||||
local function load_packages(config)
|
||||
local packages = config.packages or {
|
||||
enable = true,
|
||||
}
|
||||
if not packages.enable then
|
||||
return
|
||||
end
|
||||
|
||||
local package_manager_stats = utils.get_package_manager_stats()
|
||||
local lines = {}
|
||||
if package_manager_stats.name == 'lazy' then
|
||||
lines = {
|
||||
'',
|
||||
'Startuptime: ' .. package_manager_stats.time .. ' ms',
|
||||
'Plugins: '
|
||||
.. package_manager_stats.loaded
|
||||
.. ' loaded / '
|
||||
.. package_manager_stats.count
|
||||
.. ' installed',
|
||||
}
|
||||
else
|
||||
lines = {
|
||||
'',
|
||||
'neovim loaded ' .. package_manager_stats.count .. ' plugins',
|
||||
}
|
||||
end
|
||||
|
||||
local first_line = api.nvim_buf_line_count(config.bufnr)
|
||||
api.nvim_buf_set_lines(config.bufnr, first_line, -1, false, utils.center_align(lines))
|
||||
|
||||
for i, _ in pairs(lines) do
|
||||
api.nvim_buf_add_highlight(config.bufnr, 0, 'Comment', first_line + i - 1, 0, -1)
|
||||
end
|
||||
end
|
||||
|
||||
local function reverse(tbl)
|
||||
for i = 1, math.floor(#tbl / 2) do
|
||||
tbl[i], tbl[#tbl - i + 1] = tbl[#tbl - i + 1], tbl[i]
|
||||
end
|
||||
end
|
||||
|
||||
local function project_list(config, callback)
|
||||
config.project = vim.tbl_extend('force', {
|
||||
limit = 8,
|
||||
enable = true,
|
||||
icon = ' ',
|
||||
icon_hl = 'DashboardRecentProjectIcon',
|
||||
action = 'Telescope find_files cwd=',
|
||||
label = ' Recent Projects:',
|
||||
}, config.project or {})
|
||||
|
||||
local function read_project(data)
|
||||
local res = {}
|
||||
data = string.gsub(data, '%z', '')
|
||||
local dump = assert(loadstring(data))
|
||||
local list = dump()
|
||||
if list then
|
||||
list = vim.list_slice(list, #list - config.project.limit)
|
||||
end
|
||||
for _, dir in ipairs(list or {}) do
|
||||
dir = dir:gsub(vim.env.HOME, '~')
|
||||
table.insert(res, (' '):rep(3) .. ' ' .. dir)
|
||||
end
|
||||
|
||||
if #res == 0 then
|
||||
table.insert(res, (' '):rep(3) .. ' empty project')
|
||||
else
|
||||
reverse(res)
|
||||
end
|
||||
|
||||
table.insert(res, 1, config.project.icon .. config.project.label)
|
||||
table.insert(res, 1, '')
|
||||
table.insert(res, '')
|
||||
return res
|
||||
end
|
||||
|
||||
utils.async_read(
|
||||
config.path,
|
||||
vim.schedule_wrap(function(data)
|
||||
local res = {}
|
||||
if config.project.enable then
|
||||
res = read_project(data)
|
||||
end
|
||||
callback(res)
|
||||
end)
|
||||
)
|
||||
end
|
||||
|
||||
local function mru_list(config)
|
||||
config.mru = vim.tbl_extend('force', {
|
||||
icon = ' ',
|
||||
limit = 10,
|
||||
icon_hl = 'DashboardMruIcon',
|
||||
label = ' Most Recent Files:',
|
||||
cwd_only = false,
|
||||
}, config.mru or {})
|
||||
|
||||
local list = {
|
||||
config.mru.icon .. config.mru.label,
|
||||
}
|
||||
|
||||
local groups = {}
|
||||
local mlist = utils.get_mru_list()
|
||||
|
||||
if config.mru.cwd_only then
|
||||
local cwd = uv.cwd()
|
||||
mlist = vim.tbl_filter(function(file)
|
||||
local file_dir = vim.fn.fnamemodify(file, ':p:h')
|
||||
if file_dir and cwd then
|
||||
return file_dir:find(cwd, 1, true) == 1
|
||||
end
|
||||
end, mlist)
|
||||
end
|
||||
|
||||
for _, file in pairs(vim.list_slice(mlist, 1, config.mru.limit)) do
|
||||
local filename = vim.fn.fnamemodify(file, ':t')
|
||||
local icon, group = utils.get_icon(filename)
|
||||
icon = icon or ' '
|
||||
if config.mru.cwd_only then
|
||||
file = vim.fn.fnamemodify(file, ':.')
|
||||
elseif not utils.is_win then
|
||||
file = vim.fn.fnamemodify(file, ':~')
|
||||
end
|
||||
file = icon .. ' ' .. file
|
||||
table.insert(groups, { #icon, group })
|
||||
table.insert(list, (' '):rep(3) .. file)
|
||||
end
|
||||
|
||||
if #list == 1 then
|
||||
table.insert(list, (' '):rep(3) .. ' empty files')
|
||||
end
|
||||
return list, groups
|
||||
end
|
||||
|
||||
local function shuffle_table(table)
|
||||
for i = #table, 2, -1 do
|
||||
local j = math.random(i)
|
||||
table[i], table[j] = table[j], table[i]
|
||||
end
|
||||
end
|
||||
|
||||
local function letter_hotkey(config)
|
||||
-- Reserve j, k keys to move up and down.
|
||||
local list = { 106, 107 }
|
||||
|
||||
for _, item in pairs(config.shortcut or {}) do
|
||||
if item.key then
|
||||
table.insert(list, item.key:byte())
|
||||
end
|
||||
end
|
||||
|
||||
math.randomseed(os.time())
|
||||
|
||||
-- Create key table, fill it with unused characters.
|
||||
local unused_keys = {}
|
||||
-- a - z
|
||||
for key = 97, 122 do
|
||||
if not vim.tbl_contains(list, key) then
|
||||
table.insert(unused_keys, key)
|
||||
end
|
||||
end
|
||||
|
||||
shuffle_table(unused_keys)
|
||||
|
||||
local unused_uppercase_keys = {}
|
||||
-- A - Z
|
||||
for key = 65, 90 do
|
||||
if not vim.tbl_contains(list, key) then
|
||||
table.insert(unused_uppercase_keys, key)
|
||||
end
|
||||
end
|
||||
|
||||
shuffle_table(unused_uppercase_keys)
|
||||
|
||||
-- Push shuffled uppercase keys after the lowercase ones
|
||||
for _, key in pairs(unused_uppercase_keys) do
|
||||
table.insert(unused_keys, key)
|
||||
end
|
||||
|
||||
local fallback_hotkey = 0
|
||||
|
||||
return function()
|
||||
if #unused_keys ~= 0 then
|
||||
-- Pop an unused key to use it as a hotkey.
|
||||
local key = table.remove(unused_keys, 1)
|
||||
return string.char(key)
|
||||
else
|
||||
-- All keys are already used. Fallback to the number generation.
|
||||
fallback_hotkey = fallback_hotkey + 1
|
||||
return fallback_hotkey
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
local function number_hotkey()
|
||||
local start = 0
|
||||
return function()
|
||||
start = start + 1
|
||||
return start
|
||||
end
|
||||
end
|
||||
|
||||
local function gen_hotkey(config)
|
||||
if config.shortcut_type == 'number' then
|
||||
return number_hotkey()
|
||||
end
|
||||
return letter_hotkey(config)
|
||||
end
|
||||
|
||||
local function map_key(config, key, content)
|
||||
keymap.set('n', key, function()
|
||||
local text = content or api.nvim_get_current_line()
|
||||
local scol = utils.is_win and text:find('%w') or text:find('%p')
|
||||
local path = nil
|
||||
|
||||
if scol ~= nil then -- scol == nil if pressing enter in empty space
|
||||
if text:sub(scol, scol + 1) ~= '~/' then -- is relative path
|
||||
scol = math.min(text:find('%w'), text:find('%p'))
|
||||
end
|
||||
text = text:sub(scol)
|
||||
path = text:sub(1, text:find('%w(%s+)$'))
|
||||
path = vim.fs.normalize(path)
|
||||
end
|
||||
|
||||
if path == nil then
|
||||
vim.cmd('enew')
|
||||
elseif vim.fn.isdirectory(path) == 1 then
|
||||
vim.cmd('lcd ' .. path)
|
||||
if type(config.project.action) == 'function' then
|
||||
config.project.action(path)
|
||||
elseif type(config.project.action) == 'string' then
|
||||
local dump = loadstring(config.project.action)
|
||||
if not dump then
|
||||
vim.cmd(config.project.action .. path)
|
||||
else
|
||||
dump(path)
|
||||
end
|
||||
end
|
||||
else
|
||||
vim.cmd('edit ' .. vim.fn.fnameescape(path))
|
||||
local root = utils.get_vcs_root()
|
||||
if not config.change_to_vcs_root then
|
||||
return
|
||||
end
|
||||
if #root > 0 then
|
||||
vim.cmd('lcd ' .. vim.fn.fnamemodify(root[#root], ':h'))
|
||||
else
|
||||
vim.cmd('lcd ' .. vim.fn.fnamemodify(path, ':h'))
|
||||
end
|
||||
end
|
||||
end, { buffer = config.bufnr, silent = true, nowait = true })
|
||||
end
|
||||
|
||||
local function gen_center(plist, config)
|
||||
local mlist, mgroups = mru_list(config)
|
||||
local plist_len = #plist
|
||||
if plist_len == 0 then
|
||||
plist[#plist + 1] = ''
|
||||
plist_len = 1
|
||||
end
|
||||
---@diagnostic disable-next-line: param-type-mismatch
|
||||
vim.list_extend(plist, mlist)
|
||||
local max_len = utils.get_max_len(plist)
|
||||
if max_len <= 40 then
|
||||
local fill = (' '):rep(math.floor(vim.o.columns / 4))
|
||||
for i, v in pairs(plist) do
|
||||
plist[i] = v .. fill
|
||||
end
|
||||
end
|
||||
|
||||
plist = utils.element_align(plist)
|
||||
plist = utils.center_align(plist)
|
||||
local first_line = api.nvim_buf_line_count(config.bufnr)
|
||||
api.nvim_buf_set_lines(config.bufnr, first_line, -1, false, plist)
|
||||
|
||||
local start_col = plist[plist_len + 2]:find('[^%s]') - 1
|
||||
local _, scol = plist[2]:find('%S')
|
||||
|
||||
local hotkey = gen_hotkey(config)
|
||||
|
||||
api.nvim_buf_add_highlight(config.bufnr, 0, 'DashboardProjectTitle', first_line + 1, 0, -1)
|
||||
api.nvim_buf_add_highlight(
|
||||
config.bufnr,
|
||||
0,
|
||||
'DashboardProjectTitleIcon',
|
||||
first_line + 1,
|
||||
0,
|
||||
scol + #config.project.icon
|
||||
)
|
||||
|
||||
for i = 3, plist_len do
|
||||
api.nvim_buf_add_highlight(
|
||||
config.bufnr,
|
||||
0,
|
||||
'DashboardProjectIcon',
|
||||
first_line + i - 1,
|
||||
0,
|
||||
start_col + 3
|
||||
)
|
||||
api.nvim_buf_add_highlight(
|
||||
config.bufnr,
|
||||
0,
|
||||
'DashboardFiles',
|
||||
first_line + i - 1,
|
||||
start_col + 3,
|
||||
-1
|
||||
)
|
||||
local text = api.nvim_buf_get_lines(config.bufnr, first_line + i - 1, first_line + i, false)[1]
|
||||
if text and text:find('%w') and not text:find('empty') then
|
||||
local key = tostring(hotkey())
|
||||
api.nvim_buf_set_extmark(config.bufnr, ns, first_line + i - 1, 0, {
|
||||
virt_text = { { key, 'DashboardShortCut' } },
|
||||
virt_text_pos = 'eol',
|
||||
})
|
||||
map_key(config, key, text)
|
||||
end
|
||||
end
|
||||
|
||||
-- initialize the cursor pos
|
||||
api.nvim_win_set_cursor(config.winid, { first_line + 3, start_col + 4 })
|
||||
|
||||
api.nvim_buf_add_highlight(config.bufnr, 0, 'DashboardMruTitle', first_line + plist_len, 0, -1)
|
||||
api.nvim_buf_add_highlight(
|
||||
config.bufnr,
|
||||
0,
|
||||
'DashboardMruIcon',
|
||||
first_line + plist_len,
|
||||
0,
|
||||
scol + #config.mru.icon
|
||||
)
|
||||
|
||||
for i, data in pairs(mgroups) do
|
||||
local len, group = unpack(data)
|
||||
api.nvim_buf_add_highlight(
|
||||
config.bufnr,
|
||||
0,
|
||||
group,
|
||||
first_line + i + plist_len,
|
||||
start_col,
|
||||
start_col + len
|
||||
)
|
||||
api.nvim_buf_add_highlight(
|
||||
config.bufnr,
|
||||
0,
|
||||
'DashboardFiles',
|
||||
first_line + i + plist_len,
|
||||
start_col + len,
|
||||
-1
|
||||
)
|
||||
|
||||
local text = api.nvim_buf_get_lines(
|
||||
config.bufnr,
|
||||
first_line + i + plist_len,
|
||||
first_line + i + plist_len + 1,
|
||||
false
|
||||
)[1]
|
||||
if text and text:find('%w') then
|
||||
local key = tostring(hotkey())
|
||||
api.nvim_buf_set_extmark(config.bufnr, ns, first_line + i + plist_len, 0, {
|
||||
virt_text = { { key, 'DashboardShortCut' } },
|
||||
virt_text_pos = 'eol',
|
||||
})
|
||||
map_key(config, key, text)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
local function gen_footer(config)
|
||||
local footer = {
|
||||
'',
|
||||
' 🚀 Sharp tools make good work.',
|
||||
}
|
||||
|
||||
if type(config.footer) == 'string' then
|
||||
local dump = loadstring(config.footer)
|
||||
if dump then
|
||||
footer = dump()
|
||||
end
|
||||
elseif type(config.footer) == 'function' then
|
||||
footer = config.footer()
|
||||
elseif type(config.footer) == 'table' then
|
||||
footer = config.footer
|
||||
end
|
||||
|
||||
local first_line = api.nvim_buf_line_count(config.bufnr)
|
||||
api.nvim_buf_set_lines(config.bufnr, first_line, -1, false, utils.center_align(footer))
|
||||
|
||||
---@diagnostic disable-next-line: param-type-mismatch
|
||||
for i, _ in pairs(footer) do
|
||||
api.nvim_buf_add_highlight(config.bufnr, 0, 'DashboardFooter', first_line + i - 1, 0, -1)
|
||||
end
|
||||
|
||||
utils.add_update_footer_command(config.bufnr, footer)
|
||||
end
|
||||
|
||||
local function project_delete()
|
||||
api.nvim_create_user_command('DbProjectDelete', function(args)
|
||||
local path = utils.path_join(vim.fn.stdpath('cache'), 'dashboard', 'cache')
|
||||
utils.async_read(
|
||||
path,
|
||||
vim.schedule_wrap(function(data)
|
||||
local dump = assert(loadstring(data))
|
||||
local list = dump()
|
||||
local count = tonumber(args.args)
|
||||
if vim.tbl_count(list) < count then
|
||||
return
|
||||
end
|
||||
list = vim.list_slice(list, count + 1)
|
||||
local str = string.dump(assert(loadstring('return ' .. vim.inspect(list))))
|
||||
local handle = io.open(path, 'w+')
|
||||
if not handle then
|
||||
return
|
||||
end
|
||||
handle:write(str)
|
||||
handle:close()
|
||||
end)
|
||||
)
|
||||
end, {
|
||||
nargs = '+',
|
||||
})
|
||||
end
|
||||
|
||||
local function theme_instance(config)
|
||||
project_list(config, function(plist)
|
||||
if not api.nvim_buf_is_valid(config.bufnr) then
|
||||
return
|
||||
end
|
||||
if config.disable_move then
|
||||
utils.disable_move_key(config.bufnr)
|
||||
end
|
||||
require('dashboard.theme.header').generate_header(config)
|
||||
if not config.shortcut or not vim.tbl_isempty(config.shortcut) then
|
||||
gen_shortcut(config)
|
||||
end
|
||||
load_packages(config)
|
||||
gen_center(plist, config)
|
||||
gen_footer(config)
|
||||
map_key(config, config.confirm_key or '<CR>')
|
||||
require('dashboard.events').register_lsp_root(config.path)
|
||||
local size = math.floor(vim.o.lines / 2)
|
||||
- math.ceil(api.nvim_buf_line_count(config.bufnr) / 2)
|
||||
- 2
|
||||
local fill = utils.generate_empty_table(size)
|
||||
api.nvim_buf_set_lines(config.bufnr, 0, 0, false, fill)
|
||||
vim.bo[config.bufnr].modifiable = false
|
||||
vim.bo[config.bufnr].modified = false
|
||||
--defer until next event loop
|
||||
vim.schedule(function()
|
||||
api.nvim_exec_autocmds('User', {
|
||||
pattern = 'DashboardLoaded',
|
||||
modeline = false,
|
||||
})
|
||||
end)
|
||||
project_delete()
|
||||
end)
|
||||
end
|
||||
|
||||
return setmetatable({}, {
|
||||
__call = function(_, t)
|
||||
theme_instance(t)
|
||||
end,
|
||||
})
|
||||
@ -0,0 +1,198 @@
|
||||
local uv = vim.loop
|
||||
local utils = {}
|
||||
|
||||
utils.is_win = uv.os_uname().version:match('Windows')
|
||||
|
||||
function utils.path_join(...)
|
||||
local path_sep = utils.is_win and '\\' or '/'
|
||||
return table.concat({ ... }, path_sep)
|
||||
end
|
||||
|
||||
function utils.element_align(tbl)
|
||||
local lens = {}
|
||||
vim.tbl_map(function(k)
|
||||
table.insert(lens, vim.api.nvim_strwidth(k))
|
||||
end, tbl)
|
||||
table.sort(lens)
|
||||
local max = lens[#lens]
|
||||
local res = {}
|
||||
for _, item in pairs(tbl) do
|
||||
local len = vim.api.nvim_strwidth(item)
|
||||
local times = math.floor((max - len) / vim.api.nvim_strwidth(' '))
|
||||
item = item .. (' '):rep(times)
|
||||
table.insert(res, item)
|
||||
end
|
||||
return res
|
||||
end
|
||||
|
||||
function utils.get_max_len(contents)
|
||||
vim.validate({
|
||||
contents = { contents, 't' },
|
||||
})
|
||||
local cells = {}
|
||||
for _, v in pairs(contents) do
|
||||
table.insert(cells, vim.api.nvim_strwidth(v))
|
||||
end
|
||||
table.sort(cells)
|
||||
return cells[#cells]
|
||||
end
|
||||
|
||||
-- draw the graphics into the screen center
|
||||
function utils.center_align(tbl)
|
||||
vim.validate({
|
||||
tbl = { tbl, 'table' },
|
||||
})
|
||||
local function fill_sizes(lines)
|
||||
local fills = {}
|
||||
for _, line in pairs(lines) do
|
||||
table.insert(fills, math.floor((vim.o.columns - vim.api.nvim_strwidth(line)) / 2))
|
||||
end
|
||||
return fills
|
||||
end
|
||||
|
||||
local centered_lines = {}
|
||||
local fills = fill_sizes(tbl)
|
||||
|
||||
for i = 1, #tbl do
|
||||
local fill_line = (' '):rep(fills[i]) .. tbl[i]
|
||||
table.insert(centered_lines, fill_line)
|
||||
end
|
||||
|
||||
return centered_lines
|
||||
end
|
||||
|
||||
function utils.get_icon(filename)
|
||||
local ok, devicons = pcall(require, 'nvim-web-devicons')
|
||||
if not ok then
|
||||
vim.notify('[dashboard.nvim] not found nvim-web-devicons')
|
||||
return nil
|
||||
end
|
||||
return devicons.get_icon(filename, nil, { default = true })
|
||||
end
|
||||
|
||||
function utils.read_project_cache(path)
|
||||
local fd = assert(uv.fs_open(path, 'r', tonumber('644', 8)))
|
||||
local stat = uv.fs_fstat(fd)
|
||||
local chunk = uv.fs_read(fd, stat.size, 0)
|
||||
local dump = assert(loadstring(chunk))
|
||||
return dump()
|
||||
end
|
||||
|
||||
function utils.async_read(path, callback)
|
||||
uv.fs_open(path, 'a+', 438, function(err, fd)
|
||||
assert(not err, err)
|
||||
uv.fs_fstat(fd, function(err, stat)
|
||||
assert(not err, err)
|
||||
uv.fs_read(fd, stat.size, 0, function(err, data)
|
||||
assert(not err, err)
|
||||
uv.fs_close(fd, function(err)
|
||||
assert(not err, err)
|
||||
callback(data)
|
||||
end)
|
||||
end)
|
||||
end)
|
||||
end)
|
||||
end
|
||||
|
||||
function utils.disable_move_key(bufnr)
|
||||
local keys = { 'w', 'f', 'b', 'h', 'j', 'k', 'l', '<Up>', '<Down>', '<Left>', '<Right>' }
|
||||
vim.tbl_map(function(k)
|
||||
vim.keymap.set('n', k, '<Nop>', { buffer = bufnr })
|
||||
end, keys)
|
||||
end
|
||||
|
||||
--- return the most recently files list
|
||||
function utils.get_mru_list()
|
||||
local mru = {}
|
||||
for _, file in pairs(vim.v.oldfiles or {}) do
|
||||
if file and vim.fn.filereadable(file) == 1 then
|
||||
table.insert(mru, file)
|
||||
end
|
||||
end
|
||||
return mru
|
||||
end
|
||||
|
||||
function utils.get_package_manager_stats()
|
||||
local package_manager_stats = { name = '', count = 0, loaded = 0, time = 0 }
|
||||
---@diagnostic disable-next-line: undefined-global
|
||||
if packer_plugins then
|
||||
package_manager_stats.name = 'packer'
|
||||
---@diagnostic disable-next-line: undefined-global
|
||||
package_manager_stats.count = #vim.tbl_keys(packer_plugins)
|
||||
end
|
||||
local status, lazy = pcall(require, 'lazy')
|
||||
if status then
|
||||
package_manager_stats.name = 'lazy'
|
||||
package_manager_stats.loaded = lazy.stats().loaded
|
||||
package_manager_stats.count = lazy.stats().count
|
||||
package_manager_stats.time = lazy.stats().startuptime
|
||||
end
|
||||
return package_manager_stats
|
||||
end
|
||||
|
||||
--- generate an empty table by length
|
||||
function utils.generate_empty_table(length)
|
||||
local empty_tbl = {}
|
||||
if length == 0 then
|
||||
return empty_tbl
|
||||
end
|
||||
|
||||
for _ = 1, length do
|
||||
table.insert(empty_tbl, '')
|
||||
end
|
||||
return empty_tbl
|
||||
end
|
||||
|
||||
function utils.generate_truncateline(cells)
|
||||
local char = '┉'
|
||||
return char:rep(math.floor(cells / vim.api.nvim_strwidth(char)))
|
||||
end
|
||||
|
||||
function utils.get_vcs_root(buf)
|
||||
buf = buf or 0
|
||||
local path = vim.fn.fnamemodify(vim.api.nvim_buf_get_name(buf), ':p:h')
|
||||
local patterns = { '.git', '.hg', '.bzr', '.svn' }
|
||||
for _, pattern in pairs(patterns) do
|
||||
local root = vim.fs.find(pattern, { path = path, upward = true, stop = vim.env.HOME })
|
||||
if root then
|
||||
return root
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
local index = 0
|
||||
function utils.gen_bufname(prefix)
|
||||
index = index + 1
|
||||
return prefix .. '-' .. index
|
||||
end
|
||||
|
||||
function utils.buf_is_empty(bufnr)
|
||||
bufnr = bufnr or 0
|
||||
return vim.api.nvim_buf_line_count(0) == 1
|
||||
and vim.api.nvim_buf_get_lines(0, 0, -1, false)[1] == ''
|
||||
end
|
||||
|
||||
local last_footer_size = nil
|
||||
function utils.add_update_footer_command(bufnr, footer)
|
||||
vim.api.nvim_create_user_command('DashboardUpdateFooter', function(args)
|
||||
if last_footer_size == nil then
|
||||
last_footer_size = #footer
|
||||
end
|
||||
|
||||
local first_line = vim.api.nvim_buf_line_count(bufnr)
|
||||
vim.bo[bufnr].modifiable = true
|
||||
vim.api.nvim_buf_set_lines(
|
||||
bufnr,
|
||||
first_line - last_footer_size,
|
||||
-1,
|
||||
false,
|
||||
utils.center_align(args.fargs)
|
||||
)
|
||||
vim.bo[bufnr].modifiable = false
|
||||
vim.bo[bufnr].modified = false
|
||||
|
||||
last_footer_size = #args.fargs -- For future calculation of size
|
||||
end, { nargs = '*' })
|
||||
end
|
||||
|
||||
return utils
|
||||
@ -0,0 +1,27 @@
|
||||
-- version 0.2.3
|
||||
|
||||
local g = vim.api.nvim_create_augroup('dashboard', { clear = true })
|
||||
|
||||
vim.api.nvim_create_autocmd('StdinReadPre', {
|
||||
group = g,
|
||||
callback = function()
|
||||
vim.g.read_from_stdin = 1
|
||||
end,
|
||||
})
|
||||
|
||||
vim.api.nvim_create_autocmd('UIEnter', {
|
||||
group = g,
|
||||
callback = function()
|
||||
if
|
||||
vim.fn.argc() == 0
|
||||
and vim.api.nvim_buf_get_name(0) == ''
|
||||
and vim.g.read_from_stdin == nil
|
||||
then
|
||||
require('dashboard'):instance()
|
||||
end
|
||||
end,
|
||||
})
|
||||
|
||||
vim.api.nvim_create_user_command('Dashboard', function()
|
||||
require('dashboard'):instance()
|
||||
end, {})
|
||||
89
config/neovim/store/lazy-plugins/persistence.nvim/.github/ISSUE_TEMPLATE/bug_report.yml
vendored
Normal file
89
config/neovim/store/lazy-plugins/persistence.nvim/.github/ISSUE_TEMPLATE/bug_report.yml
vendored
Normal file
@ -0,0 +1,89 @@
|
||||
name: Bug Report
|
||||
description: File a bug/issue
|
||||
title: "bug: "
|
||||
labels: [bug]
|
||||
body:
|
||||
- type: markdown
|
||||
attributes:
|
||||
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.
|
||||
- type: checkboxes
|
||||
attributes:
|
||||
label: Did you check docs and existing issues?
|
||||
description: Make sure you checked all of the below before submitting an issue
|
||||
options:
|
||||
- label: I have read all the persistence.nvim docs
|
||||
required: true
|
||||
- label: I have searched the existing issues of persistence.nvim
|
||||
required: true
|
||||
- label: I have searched the existing issues of plugins related to this issue
|
||||
required: true
|
||||
- type: input
|
||||
attributes:
|
||||
label: "Neovim version (nvim -v)"
|
||||
placeholder: "0.8.0 commit db1b0ee3b30f"
|
||||
validations:
|
||||
required: true
|
||||
- type: input
|
||||
attributes:
|
||||
label: "Operating system/version"
|
||||
placeholder: "MacOS 11.5"
|
||||
validations:
|
||||
required: true
|
||||
- type: textarea
|
||||
attributes:
|
||||
label: Describe the bug
|
||||
description: A clear and concise description of what the bug is. Please include any related errors you see in Neovim.
|
||||
validations:
|
||||
required: true
|
||||
- type: textarea
|
||||
attributes:
|
||||
label: Steps To Reproduce
|
||||
description: Steps to reproduce the behavior.
|
||||
placeholder: |
|
||||
1.
|
||||
2.
|
||||
3.
|
||||
validations:
|
||||
required: true
|
||||
- type: textarea
|
||||
attributes:
|
||||
label: Expected Behavior
|
||||
description: A concise description of what you expected to happen.
|
||||
validations:
|
||||
required: true
|
||||
- type: textarea
|
||||
attributes:
|
||||
label: Repro
|
||||
description: Minimal `init.lua` to reproduce this issue. Save as `repro.lua` and run with `nvim -u repro.lua`
|
||||
value: |
|
||||
-- DO NOT change the paths and don't remove the colorscheme
|
||||
local root = vim.fn.fnamemodify("./.repro", ":p")
|
||||
|
||||
-- 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
|
||||
local lazypath = root .. "/plugins/lazy.nvim"
|
||||
if not vim.loop.fs_stat(lazypath) then
|
||||
vim.fn.system({ "git", "clone", "--filter=blob:none", "https://github.com/folke/lazy.nvim.git", lazypath, })
|
||||
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",
|
||||
})
|
||||
|
||||
vim.cmd.colorscheme("tokyonight")
|
||||
-- add anything else here
|
||||
render: Lua
|
||||
validations:
|
||||
required: false
|
||||
36
config/neovim/store/lazy-plugins/persistence.nvim/.github/ISSUE_TEMPLATE/feature_request.yml
vendored
Normal file
36
config/neovim/store/lazy-plugins/persistence.nvim/.github/ISSUE_TEMPLATE/feature_request.yml
vendored
Normal file
@ -0,0 +1,36 @@
|
||||
name: Feature Request
|
||||
description: Suggest a new feature
|
||||
title: "feature: "
|
||||
labels: [enhancement]
|
||||
body:
|
||||
- type: checkboxes
|
||||
attributes:
|
||||
label: Did you check the docs?
|
||||
description: Make sure you read all the docs before submitting a feature request
|
||||
options:
|
||||
- label: I have read all the persistence.nvim docs
|
||||
required: true
|
||||
- type: textarea
|
||||
validations:
|
||||
required: true
|
||||
attributes:
|
||||
label: Is your feature request related to a problem? Please describe.
|
||||
description: A clear and concise description of what the problem is. Ex. I'm always frustrated when [...]
|
||||
- type: textarea
|
||||
validations:
|
||||
required: true
|
||||
attributes:
|
||||
label: Describe the solution you'd like
|
||||
description: A clear and concise description of what you want to happen.
|
||||
- type: textarea
|
||||
validations:
|
||||
required: true
|
||||
attributes:
|
||||
label: Describe alternatives you've considered
|
||||
description: A clear and concise description of any alternative solutions or features you've considered.
|
||||
- type: textarea
|
||||
validations:
|
||||
required: false
|
||||
attributes:
|
||||
label: Additional context
|
||||
description: Add any other context or screenshots about the feature request here.
|
||||
72
config/neovim/store/lazy-plugins/persistence.nvim/.github/workflows/ci.yml
vendored
Normal file
72
config/neovim/store/lazy-plugins/persistence.nvim/.github/workflows/ci.yml
vendored
Normal file
@ -0,0 +1,72 @@
|
||||
name: CI
|
||||
on:
|
||||
push:
|
||||
pull_request:
|
||||
|
||||
jobs:
|
||||
tests:
|
||||
strategy:
|
||||
matrix:
|
||||
# os: [ubuntu-latest, windows-latest]
|
||||
os: [ubuntu-latest]
|
||||
runs-on: ${{ matrix.os }}
|
||||
steps:
|
||||
- uses: actions/checkout@v3
|
||||
- name: Install Neovim
|
||||
shell: bash
|
||||
run: |
|
||||
mkdir -p /tmp/nvim
|
||||
wget -q https://github.com/neovim/neovim/releases/download/nightly/nvim.appimage -O /tmp/nvim/nvim.appimage
|
||||
cd /tmp/nvim
|
||||
chmod a+x ./nvim.appimage
|
||||
./nvim.appimage --appimage-extract
|
||||
echo "/tmp/nvim/squashfs-root/usr/bin/" >> $GITHUB_PATH
|
||||
- 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@v3
|
||||
- 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
config/neovim/store/lazy-plugins/persistence.nvim/.gitignore
vendored
Normal file
8
config/neovim/store/lazy-plugins/persistence.nvim/.gitignore
vendored
Normal file
@ -0,0 +1,8 @@
|
||||
tt.*
|
||||
.tests
|
||||
doc/tags
|
||||
debug
|
||||
.repro
|
||||
foo.*
|
||||
*.log
|
||||
data
|
||||
@ -0,0 +1,61 @@
|
||||
# Changelog
|
||||
|
||||
## [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)
|
||||
|
||||
|
||||
### ⚠ BREAKING CHANGES
|
||||
|
||||
* save sessions in state instead of config
|
||||
|
||||
### Features
|
||||
|
||||
* added config options ([a39f3f1](https://github.com/folke/persistence.nvim/commit/a39f3f10c836709f9b6e009b20a1f028851c50e0))
|
||||
* inital version ([8b32094](https://github.com/folke/persistence.nvim/commit/8b32094309ee986066c219d2b4d88a4045fbcb8c))
|
||||
* save sessions in state instead of config ([c304745](https://github.com/folke/persistence.nvim/commit/c30474509666187181add6122e775f9978478c81))
|
||||
|
||||
|
||||
### Bug Fixes
|
||||
|
||||
* dont show errors when loading a session ([ad7fcd4](https://github.com/folke/persistence.nvim/commit/ad7fcd4fed0cecb9ae3c6cbc4a61801ef4e2466d))
|
||||
* properly escape session file names on Windows ([#7](https://github.com/folke/persistence.nvim/issues/7)) ([83af96b](https://github.com/folke/persistence.nvim/commit/83af96b1f205dddab066c96b029ceeee192b48d4))
|
||||
* renamed session to persistence in autocmds ([38203a1](https://github.com/folke/persistence.nvim/commit/38203a17a97d49bfcc938f171ecfa44f52dda08e))
|
||||
* vim.fn.has('win32') returns 0 or 1, not a boolean ([#8](https://github.com/folke/persistence.nvim/issues/8)) ([77cf5a6](https://github.com/folke/persistence.nvim/commit/77cf5a6ee162013b97237ff25450080401849f85))
|
||||
201
config/neovim/store/lazy-plugins/persistence.nvim/LICENSE
Normal file
201
config/neovim/store/lazy-plugins/persistence.nvim/LICENSE
Normal file
@ -0,0 +1,201 @@
|
||||
Apache License
|
||||
Version 2.0, January 2004
|
||||
http://www.apache.org/licenses/
|
||||
|
||||
TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
|
||||
|
||||
1. Definitions.
|
||||
|
||||
"License" shall mean the terms and conditions for use, reproduction,
|
||||
and distribution as defined by Sections 1 through 9 of this document.
|
||||
|
||||
"Licensor" shall mean the copyright owner or entity authorized by
|
||||
the copyright owner that is granting the License.
|
||||
|
||||
"Legal Entity" shall mean the union of the acting entity and all
|
||||
other entities that control, are controlled by, or are under common
|
||||
control with that entity. For the purposes of this definition,
|
||||
"control" means (i) the power, direct or indirect, to cause the
|
||||
direction or management of such entity, whether by contract or
|
||||
otherwise, or (ii) ownership of fifty percent (50%) or more of the
|
||||
outstanding shares, or (iii) beneficial ownership of such entity.
|
||||
|
||||
"You" (or "Your") shall mean an individual or Legal Entity
|
||||
exercising permissions granted by this License.
|
||||
|
||||
"Source" form shall mean the preferred form for making modifications,
|
||||
including but not limited to software source code, documentation
|
||||
source, and configuration files.
|
||||
|
||||
"Object" form shall mean any form resulting from mechanical
|
||||
transformation or translation of a Source form, including but
|
||||
not limited to compiled object code, generated documentation,
|
||||
and conversions to other media types.
|
||||
|
||||
"Work" shall mean the work of authorship, whether in Source or
|
||||
Object form, made available under the License, as indicated by a
|
||||
copyright notice that is included in or attached to the work
|
||||
(an example is provided in the Appendix below).
|
||||
|
||||
"Derivative Works" shall mean any work, whether in Source or Object
|
||||
form, that is based on (or derived from) the Work and for which the
|
||||
editorial revisions, annotations, elaborations, or other modifications
|
||||
represent, as a whole, an original work of authorship. For the purposes
|
||||
of this License, Derivative Works shall not include works that remain
|
||||
separable from, or merely link (or bind by name) to the interfaces of,
|
||||
the Work and Derivative Works thereof.
|
||||
|
||||
"Contribution" shall mean any work of authorship, including
|
||||
the original version of the Work and any modifications or additions
|
||||
to that Work or Derivative Works thereof, that is intentionally
|
||||
submitted to Licensor for inclusion in the Work by the copyright owner
|
||||
or by an individual or Legal Entity authorized to submit on behalf of
|
||||
the copyright owner. For the purposes of this definition, "submitted"
|
||||
means any form of electronic, verbal, or written communication sent
|
||||
to the Licensor or its representatives, including but not limited to
|
||||
communication on electronic mailing lists, source code control systems,
|
||||
and issue tracking systems that are managed by, or on behalf of, the
|
||||
Licensor for the purpose of discussing and improving the Work, but
|
||||
excluding communication that is conspicuously marked or otherwise
|
||||
designated in writing by the copyright owner as "Not a Contribution."
|
||||
|
||||
"Contributor" shall mean Licensor and any individual or Legal Entity
|
||||
on behalf of whom a Contribution has been received by Licensor and
|
||||
subsequently incorporated within the Work.
|
||||
|
||||
2. Grant of Copyright License. Subject to the terms and conditions of
|
||||
this License, each Contributor hereby grants to You a perpetual,
|
||||
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||
copyright license to reproduce, prepare Derivative Works of,
|
||||
publicly display, publicly perform, sublicense, and distribute the
|
||||
Work and such Derivative Works in Source or Object form.
|
||||
|
||||
3. Grant of Patent License. Subject to the terms and conditions of
|
||||
this License, each Contributor hereby grants to You a perpetual,
|
||||
worldwide, non-exclusive, no-charge, royalty-free, irrevocable
|
||||
(except as stated in this section) patent license to make, have made,
|
||||
use, offer to sell, sell, import, and otherwise transfer the Work,
|
||||
where such license applies only to those patent claims licensable
|
||||
by such Contributor that are necessarily infringed by their
|
||||
Contribution(s) alone or by combination of their Contribution(s)
|
||||
with the Work to which such Contribution(s) was submitted. If You
|
||||
institute patent litigation against any entity (including a
|
||||
cross-claim or counterclaim in a lawsuit) alleging that the Work
|
||||
or a Contribution incorporated within the Work constitutes direct
|
||||
or contributory patent infringement, then any patent licenses
|
||||
granted to You under this License for that Work shall terminate
|
||||
as of the date such litigation is filed.
|
||||
|
||||
4. Redistribution. You may reproduce and distribute copies of the
|
||||
Work or Derivative Works thereof in any medium, with or without
|
||||
modifications, and in Source or Object form, provided that You
|
||||
meet the following conditions:
|
||||
|
||||
(a) You must give any other recipients of the Work or
|
||||
Derivative Works a copy of this License; and
|
||||
|
||||
(b) You must cause any modified files to carry prominent notices
|
||||
stating that You changed the files; and
|
||||
|
||||
(c) You must retain, in the Source form of any Derivative Works
|
||||
that You distribute, all copyright, patent, trademark, and
|
||||
attribution notices from the Source form of the Work,
|
||||
excluding those notices that do not pertain to any part of
|
||||
the Derivative Works; and
|
||||
|
||||
(d) If the Work includes a "NOTICE" text file as part of its
|
||||
distribution, then any Derivative Works that You distribute must
|
||||
include a readable copy of the attribution notices contained
|
||||
within such NOTICE file, excluding those notices that do not
|
||||
pertain to any part of the Derivative Works, in at least one
|
||||
of the following places: within a NOTICE text file distributed
|
||||
as part of the Derivative Works; within the Source form or
|
||||
documentation, if provided along with the Derivative Works; or,
|
||||
within a display generated by the Derivative Works, if and
|
||||
wherever such third-party notices normally appear. The contents
|
||||
of the NOTICE file are for informational purposes only and
|
||||
do not modify the License. You may add Your own attribution
|
||||
notices within Derivative Works that You distribute, alongside
|
||||
or as an addendum to the NOTICE text from the Work, provided
|
||||
that such additional attribution notices cannot be construed
|
||||
as modifying the License.
|
||||
|
||||
You may add Your own copyright statement to Your modifications and
|
||||
may provide additional or different license terms and conditions
|
||||
for use, reproduction, or distribution of Your modifications, or
|
||||
for any such Derivative Works as a whole, provided Your use,
|
||||
reproduction, and distribution of the Work otherwise complies with
|
||||
the conditions stated in this License.
|
||||
|
||||
5. Submission of Contributions. Unless You explicitly state otherwise,
|
||||
any Contribution intentionally submitted for inclusion in the Work
|
||||
by You to the Licensor shall be under the terms and conditions of
|
||||
this License, without any additional terms or conditions.
|
||||
Notwithstanding the above, nothing herein shall supersede or modify
|
||||
the terms of any separate license agreement you may have executed
|
||||
with Licensor regarding such Contributions.
|
||||
|
||||
6. Trademarks. This License does not grant permission to use the trade
|
||||
names, trademarks, service marks, or product names of the Licensor,
|
||||
except as required for reasonable and customary use in describing the
|
||||
origin of the Work and reproducing the content of the NOTICE file.
|
||||
|
||||
7. Disclaimer of Warranty. Unless required by applicable law or
|
||||
agreed to in writing, Licensor provides the Work (and each
|
||||
Contributor provides its Contributions) on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
||||
implied, including, without limitation, any warranties or conditions
|
||||
of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
|
||||
PARTICULAR PURPOSE. You are solely responsible for determining the
|
||||
appropriateness of using or redistributing the Work and assume any
|
||||
risks associated with Your exercise of permissions under this License.
|
||||
|
||||
8. Limitation of Liability. In no event and under no legal theory,
|
||||
whether in tort (including negligence), contract, or otherwise,
|
||||
unless required by applicable law (such as deliberate and grossly
|
||||
negligent acts) or agreed to in writing, shall any Contributor be
|
||||
liable to You for damages, including any direct, indirect, special,
|
||||
incidental, or consequential damages of any character arising as a
|
||||
result of this License or out of the use or inability to use the
|
||||
Work (including but not limited to damages for loss of goodwill,
|
||||
work stoppage, computer failure or malfunction, or any and all
|
||||
other commercial damages or losses), even if such Contributor
|
||||
has been advised of the possibility of such damages.
|
||||
|
||||
9. Accepting Warranty or Additional Liability. While redistributing
|
||||
the Work or Derivative Works thereof, You may choose to offer,
|
||||
and charge a fee for, acceptance of support, warranty, indemnity,
|
||||
or other liability obligations and/or rights consistent with this
|
||||
License. However, in accepting such obligations, You may act only
|
||||
on Your own behalf and on Your sole responsibility, not on behalf
|
||||
of any other Contributor, and only if You agree to indemnify,
|
||||
defend, and hold each Contributor harmless for any liability
|
||||
incurred by, or claims asserted against, such Contributor by reason
|
||||
of your accepting any such warranty or additional liability.
|
||||
|
||||
END OF TERMS AND CONDITIONS
|
||||
|
||||
APPENDIX: How to apply the Apache License to your work.
|
||||
|
||||
To apply the Apache License to your work, attach the following
|
||||
boilerplate notice, with the fields enclosed by brackets "[]"
|
||||
replaced with your own identifying information. (Don't include
|
||||
the brackets!) The text should be enclosed in the appropriate
|
||||
comment syntax for the file format. We also recommend that a
|
||||
file or class name and description of purpose be included on the
|
||||
same "printed page" as the copyright notice for easier
|
||||
identification within third-party archives.
|
||||
|
||||
Copyright [yyyy] [name of copyright owner]
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
||||
61
config/neovim/store/lazy-plugins/persistence.nvim/README.md
Normal file
61
config/neovim/store/lazy-plugins/persistence.nvim/README.md
Normal file
@ -0,0 +1,61 @@
|
||||
# 💾 Persistence
|
||||
|
||||
**Persistence** is a simple lua plugin for automated session management.
|
||||
|
||||
## ✨ Features
|
||||
|
||||
- automatically saves the active session under `~/.local/state/nvim/sessions` on exit
|
||||
- simple API to restore the current or last session
|
||||
|
||||
## ⚡️ Requirements
|
||||
|
||||
- Neovim >= 0.7.2
|
||||
|
||||
## 📦 Installation
|
||||
|
||||
Install the plugin with your preferred package manager:
|
||||
|
||||
### [lazy.nvim](https://github.com/folke/lazy.nvim)
|
||||
|
||||
```lua
|
||||
-- Lua
|
||||
{
|
||||
"folke/persistence.nvim",
|
||||
event = "BufReadPre", -- this will only start session saving when an actual file was opened
|
||||
opts = {
|
||||
-- add any custom options here
|
||||
}
|
||||
}
|
||||
```
|
||||
|
||||
## ⚙️ Configuration
|
||||
|
||||
Persistence comes with the following defaults:
|
||||
|
||||
```lua
|
||||
{
|
||||
dir = vim.fn.expand(vim.fn.stdpath("state") .. "/sessions/"), -- directory where session files are saved
|
||||
options = { "buffers", "curdir", "tabpages", "winsize" }, -- sessionoptions used for saving
|
||||
pre_save = nil, -- a function to call before saving the session
|
||||
post_save = nil, -- a function to call after saving the session
|
||||
save_empty = false, -- don't save if there are no open file buffers
|
||||
pre_load = nil, -- a function to call before loading the session
|
||||
post_load = nil, -- a function to call after loading the session
|
||||
}
|
||||
```
|
||||
|
||||
## 🚀 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.
|
||||
|
||||
```lua
|
||||
-- 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>]], {})
|
||||
```
|
||||
@ -0,0 +1,85 @@
|
||||
*persistence.nvim.txt* For Neovim >= 0.8.0 Last change: 2024 May 16
|
||||
|
||||
==============================================================================
|
||||
Table of Contents *persistence.nvim-table-of-contents*
|
||||
|
||||
1. Persistence |persistence.nvim-persistence|
|
||||
- Features |persistence.nvim-persistence-features|
|
||||
- Requirements |persistence.nvim-persistence-requirements|
|
||||
- Installation |persistence.nvim-persistence-installation|
|
||||
- Configuration |persistence.nvim-persistence-configuration|
|
||||
- Usage |persistence.nvim-persistence-usage|
|
||||
|
||||
==============================================================================
|
||||
1. Persistence *persistence.nvim-persistence*
|
||||
|
||||
**Persistence** is a simple lua plugin for automated session management.
|
||||
|
||||
|
||||
FEATURES *persistence.nvim-persistence-features*
|
||||
|
||||
- automatically saves the active session under `~/.local/state/nvim/sessions` on exit
|
||||
- simple API to restore the current or last session
|
||||
|
||||
|
||||
REQUIREMENTS *persistence.nvim-persistence-requirements*
|
||||
|
||||
- Neovim >= 0.7.2
|
||||
|
||||
|
||||
INSTALLATION *persistence.nvim-persistence-installation*
|
||||
|
||||
Install the plugin with your preferred package manager:
|
||||
|
||||
|
||||
LAZY.NVIM ~
|
||||
|
||||
>lua
|
||||
-- Lua
|
||||
{
|
||||
"folke/persistence.nvim",
|
||||
event = "BufReadPre", -- this will only start session saving when an actual file was opened
|
||||
opts = {
|
||||
-- add any custom options here
|
||||
}
|
||||
}
|
||||
<
|
||||
|
||||
|
||||
CONFIGURATION *persistence.nvim-persistence-configuration*
|
||||
|
||||
Persistence comes with the following defaults:
|
||||
|
||||
>lua
|
||||
{
|
||||
dir = vim.fn.expand(vim.fn.stdpath("state") .. "/sessions/"), -- directory where session files are saved
|
||||
options = { "buffers", "curdir", "tabpages", "winsize" }, -- sessionoptions used for saving
|
||||
pre_save = nil, -- a function to call before saving the session
|
||||
post_save = nil, -- a function to call after saving the session
|
||||
save_empty = false, -- don't save if there are no open file buffers
|
||||
pre_load = nil, -- a function to call before loading the session
|
||||
post_load = nil, -- a function to call after loading the session
|
||||
}
|
||||
<
|
||||
|
||||
|
||||
USAGE *persistence.nvim-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.
|
||||
|
||||
>lua
|
||||
-- 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:
|
||||
@ -0,0 +1,8 @@
|
||||
persistence.nvim-persistence persistence.nvim.txt /*persistence.nvim-persistence*
|
||||
persistence.nvim-persistence-configuration persistence.nvim.txt /*persistence.nvim-persistence-configuration*
|
||||
persistence.nvim-persistence-features persistence.nvim.txt /*persistence.nvim-persistence-features*
|
||||
persistence.nvim-persistence-installation persistence.nvim.txt /*persistence.nvim-persistence-installation*
|
||||
persistence.nvim-persistence-requirements persistence.nvim.txt /*persistence.nvim-persistence-requirements*
|
||||
persistence.nvim-persistence-usage persistence.nvim.txt /*persistence.nvim-persistence-usage*
|
||||
persistence.nvim-table-of-contents persistence.nvim.txt /*persistence.nvim-table-of-contents*
|
||||
persistence.nvim.txt persistence.nvim.txt /*persistence.nvim.txt*
|
||||
@ -0,0 +1,22 @@
|
||||
local M = {}
|
||||
|
||||
---@class PersistenceOptions
|
||||
---@field pre_save? fun()
|
||||
---@field post_save? fun()
|
||||
---@field pre_load? fun()
|
||||
---@field post_load? fun()
|
||||
local defaults = {
|
||||
dir = vim.fn.expand(vim.fn.stdpath("state") .. "/sessions/"), -- directory where session files are saved
|
||||
options = { "buffers", "curdir", "tabpages", "winsize", "skiprtp" }, -- sessionoptions used for saving
|
||||
save_empty = false, -- don't save if there are no open file buffers
|
||||
}
|
||||
|
||||
---@type PersistenceOptions
|
||||
M.options = {}
|
||||
|
||||
function M.setup(opts)
|
||||
M.options = vim.tbl_deep_extend("force", {}, defaults, opts or {})
|
||||
vim.fn.mkdir(M.options.dir, "p")
|
||||
end
|
||||
|
||||
return M
|
||||
@ -0,0 +1,99 @@
|
||||
local Config = require("persistence.config")
|
||||
|
||||
local M = {}
|
||||
---@type string?
|
||||
M.current = nil
|
||||
|
||||
local e = vim.fn.fnameescape
|
||||
|
||||
function M.get_current()
|
||||
local pattern = "/"
|
||||
if vim.fn.has("win32") == 1 then
|
||||
pattern = "[\\:]"
|
||||
end
|
||||
local name = vim.fn.getcwd():gsub(pattern, "%%")
|
||||
return Config.options.dir .. name .. ".vim"
|
||||
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)
|
||||
Config.setup(opts)
|
||||
M.start()
|
||||
end
|
||||
|
||||
function M.start()
|
||||
M.current = M.get_current()
|
||||
vim.api.nvim_create_autocmd("VimLeavePre", {
|
||||
group = vim.api.nvim_create_augroup("persistence", { clear = true }),
|
||||
callback = function()
|
||||
if Config.options.pre_save then
|
||||
Config.options.pre_save()
|
||||
end
|
||||
|
||||
if not Config.options.save_empty then
|
||||
local bufs = vim.tbl_filter(function(b)
|
||||
if vim.bo[b].buftype ~= "" then
|
||||
return false
|
||||
end
|
||||
if vim.bo[b].filetype == "gitcommit" then
|
||||
return false
|
||||
end
|
||||
if vim.bo[b].filetype == "gitrebase" then
|
||||
return false
|
||||
end
|
||||
return vim.api.nvim_buf_get_name(b) ~= ""
|
||||
end, vim.api.nvim_list_bufs())
|
||||
if #bufs == 0 then
|
||||
return
|
||||
end
|
||||
end
|
||||
|
||||
M.save()
|
||||
|
||||
if type(Config.options.post_save) == "function" then
|
||||
Config.options.post_save()
|
||||
end
|
||||
end,
|
||||
})
|
||||
end
|
||||
|
||||
function M.stop()
|
||||
M.current = nil
|
||||
pcall(vim.api.nvim_del_augroup_by_name, "persistence")
|
||||
end
|
||||
|
||||
function M.save()
|
||||
local tmp = vim.o.sessionoptions
|
||||
vim.o.sessionoptions = table.concat(Config.options.options, ",")
|
||||
vim.cmd("mks! " .. e(M.current or M.get_current()))
|
||||
vim.o.sessionoptions = tmp
|
||||
end
|
||||
|
||||
function M.load(opt)
|
||||
opt = opt or {}
|
||||
local sfile = opt.last and M.get_last() or M.get_current()
|
||||
if sfile and vim.fn.filereadable(sfile) ~= 0 then
|
||||
if type(Config.options.pre_load) == "function" then
|
||||
Config.options.pre_load()
|
||||
end
|
||||
|
||||
vim.cmd("silent! source " .. e(sfile))
|
||||
|
||||
if type(Config.options.post_load) == "function" then
|
||||
Config.options.post_load()
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
function M.list()
|
||||
return vim.fn.glob(Config.options.dir .. "*.vim", true, true)
|
||||
end
|
||||
|
||||
return M
|
||||
@ -0,0 +1 @@
|
||||
std="lua51+vim"
|
||||
@ -0,0 +1,3 @@
|
||||
indent_type = "Spaces"
|
||||
indent_width = 2
|
||||
column_width = 120
|
||||
@ -0,0 +1,2 @@
|
||||
[vim]
|
||||
any = true
|
||||
Reference in New Issue
Block a user