You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

21 lines
279 B

# My temp files
time_cost.txt
tags
# Backup files
.doom_releases
.doom_backup_hash
# editor artifacts
*~
*.swp
# OS files
.DS_Store
# Doom Nvim Contrib files
fix(docker,lsp,core): Dockerfile, lsp warning and preserve_edit_pos (#371) * chore(.gitignore): contribute got renamed to tools delete packer_compiled.lua: this should not be commited! Signed-off-by: Edwin Török <edwin@etorok.net> * chore(Dockerfile): add luacheck/stylua * chore(init.lua): fix luacheck warnings Delete dead code Signed-off-by: Edwin Török <edwin@etorok.net> * chore(contribute): do not move branch in detached HEAD state When rebasing / bisecting / etc. the worktree would be in a detached HEAD state. Do not checkout the branch because this would unexpectedly move the currently checked out commit. Especially important if we want to compare performance one-by-one by rebasing in edit mode. Signed-off-by: Edwin Török <edwin@etorok.net> * chore: fix contribute/start_docker pacman was stopping and asking a question, needs noconfirm flag. Directories mounted as volumes need to be created on first use. 'make' needs to be installed otherwise nvim-treesitter fails to compile the treesitter parsers and hangs at 'Compiling' (sync_install=true can be used to show actual error). Signed-off-by: Edwin Török <edwin@etorok.net> * fix(preserve_edit_pos): do not jump to last position in git commit/rebase buffers See ':h last-position-jump' The commit message will likely be different each time, although the filename will be the same (`COMMIT_EDITMSG`). Signed-off-by: Edwin Török <edwin@etorok.net> * fix(lsp): do not use deprecated vim.lsp.diagnostic APIs Use the vim.diagnostic API instead, see :h deprecated. Otherwise a message is printed on every use that they are deprecated. Signed-off-by: Edwin Török <edwin@etorok.net>
2 years ago
tools/doom-nvim-contrib
tools/local-share-nvim
tools/workspace
# User modules
user/modules/*
feat(modules): make modules very granular These changes have been discussed in #233. As a side note, I ran stylua and luacheck over the repo. * From everyone's perpective - The module structure has been flattened out, removing the category grouping. Beyond less iteration scopes, this may help with, in the future, allowing the user to write and enable custom modules in $DOOMDIR. * From the user's perpective - `doom_config.lua` works via overrides now, it can change defaults on the global `doom` before everything gets actually configured. - `doom_modules.lua` just returns the actual thing it's supposed to, without {return value}.source. More on that next. - Instead of each config file returning a source key with its file location, the handlers for each config file actively search for them. This is described in the respective files inside `lua/doom/core/config`, but it's basicaly a check for two special paths falling back to runtimepath. - `doom_userplugins.lua` is removed in favor of having its functionality in `doom_config.lua`. To add a standalone package, add its packer spec to `doom.packages` (this is a map-like table of package names to packer specs). - To override the spec of a module package, change the keys in `doom.packages[package_name_without_author]`. Special attrs: `config` is run after the built-in config. - To change settings and behavior, override keys in `doom[module]`, or just `doom.*` for some core features. - To add standalone bindings, add them to `doom.binds`. This is passed to nest along with the modules' binds. `doom.binds` overrides anything you don't like in modules, you can safely replace the bind. - To add standalone autocmds, add them to `doom.autocmds[augroup_name]`. The structure is as passed to `utils.create_augroups`, so: ```lua doom.autocmds[group_name] = { { event1, pattern1, cmd1 }, ... } ``` - You shouldn't override any tables, like `doom.autocmds` or `doom.packages`, only the leaves, else you remove all that is already there. We could use metatables to avoid this in the future. - The `config.nvim` table is no longer used, most of its functionality is spread elsewhere, like autocmds. For variables and options, just use vim.opt.*, vim.g.* etc. in `doom_config.lua` - Settings can also be appended to in `doom_config.lua`, because defaults are prepopulated. * From a maintainer's perpective - Most things are grouped under the `doom` global, which is populated and overriden early in `init.lua`. The exception is enabled modules, which you still need to require `doom.core.config.modules` to get. However, do so sparingly, and only if you truly mean to iterate over enabled modules disregarding user overrides (they may have removed a particular package or reset binds). - Modules are defined in the following folder structure inside `lua/doom/modules`: `<module>/{init.lua,packages.lua,binds.lua,autocmds.lua}`. init.lua and packages.lua are required, even if empty. - `init.lua` returns: defaults under a `defaults` key; config functions under `packer_config[package_name]`. It can access the doom global only inside the configs. - `packages.lua` returns: a map of package names to package specs, with no `config` or `disable` keys present. Most things should be lazy-loaded, preferably with the `cmd` and `module` keys. It cannot access the doom global. - `autocmds.lua` returns: a list of autocmds to be applied under the group `doom_{module}`. It can use the `doom` global to add things conditionally. - `binds.lua` returns: the keyconfig to be passed to nest. It can use the `doom` global to add things conditionally. What's left: - Implement lsp wrapping. - Document the individual modules. - Write a migration script.
3 years ago
# Editor files
.luarc.json