-
-
Notifications
You must be signed in to change notification settings - Fork 295
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Yash Shinde
committed
Oct 30, 2023
1 parent
0d355c1
commit ff0d1d4
Showing
4 changed files
with
180 additions
and
106 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,119 @@ | ||
{ | ||
pkgs, | ||
config, | ||
lib, | ||
... | ||
}: | ||
with lib; let | ||
cfg = config.plugins.conform-nvim; | ||
helpers = import ../helpers.nix {inherit lib;}; | ||
in { | ||
options.plugins.conform-nvim = | ||
helpers.extraOptionsOptions | ||
// { | ||
enable = mkEnableOption "conform-nvim"; | ||
|
||
package = helpers.mkPackageOption "conform-nvim" pkgs.vimPlugins.conform-nvim; | ||
|
||
formattersByFt = | ||
helpers.defaultNullOpts.mkNullable (types.attrsOf types.anything) | ||
"see documentation" | ||
'' | ||
```nix | ||
# Map of filetype to formatters | ||
formattersByFt = | ||
{ | ||
lua = [ "stylua" ]; | ||
# Conform will run multiple formatters sequentially | ||
python = [ "isort" "black" ]; | ||
# Use a sub-list to run only the first available formatter | ||
javascript = [ [ "prettierd" "prettier" ] ]; | ||
# Use the "*" filetype to run formatters on all filetypes. | ||
"*" = [ "codespell" ]; | ||
# Use the "_" filetype to run formatters on filetypes that don't | ||
# have other formatters configured. | ||
"_" = [ "trim_whitespace" ]; | ||
}; | ||
``` | ||
''; | ||
|
||
formatOnSave = | ||
helpers.defaultNullOpts.mkNullable (types.submodule { | ||
options = { | ||
lspFallback = mkOption { | ||
type = types.bool; | ||
default = true; | ||
description = "See :help conform.format for details."; | ||
}; | ||
timeoutMs = mkOption { | ||
type = types.int; | ||
default = 500; | ||
description = "See :help conform.format for details."; | ||
}; | ||
}; | ||
}) | ||
"see documentation" | ||
'' | ||
If this is set, Conform will run the formatter on save. | ||
It will pass the table to conform.format(). | ||
This can also be a function that returns the table. | ||
See :help conform.format for details. | ||
''; | ||
|
||
formatAfterSave = | ||
helpers.defaultNullOpts.mkNullable (types.submodule { | ||
options = { | ||
lspFallback = mkOption { | ||
type = types.bool; | ||
default = true; | ||
description = "See :help conform.format for details."; | ||
}; | ||
}; | ||
}) | ||
"see documentation" | ||
'' | ||
If this is set, Conform will run the formatter asynchronously after save. | ||
It will pass the table to conform.format(). | ||
This can also be a function that returns the table. | ||
''; | ||
|
||
logLevel = | ||
helpers.defaultNullOpts.mkEnumFirstDefault | ||
["ERROR" "DEBUG" "INFO" "TRACE" "WARN" "OFF"] | ||
"Set the log level. Use `:ConformInfo` to see the location of the log file."; | ||
|
||
notifyOnError = | ||
helpers.defaultNullOpts.mkBool true | ||
"Conform will notify you when a formatter errors"; | ||
|
||
formatters = | ||
helpers.defaultNullOpts.mkNullable (types.attrsOf types.anything) | ||
"see documentation" | ||
"Custom formatters and changes to built-in formatters"; | ||
}; | ||
|
||
config = let | ||
setupOptions = with cfg; | ||
{ | ||
formatters_by_ft = formattersByFt; | ||
format_on_save = helpers.ifNonNull' formatOnSave { | ||
lsp_fallback = formatOnSave.lspFallback; | ||
timeout_ms = formatOnSave.timeoutMs; | ||
}; | ||
format_after_save = helpers.ifNonNull' formatOnSave { | ||
lsp_fallback = formatOnSave.lspFallback; | ||
}; | ||
log_level = helpers.ifNonNull' logLevel (helpers.mkRaw "vim.log.levels.${logLevel}"); | ||
notify_on_error = notifyOnError; | ||
formatters = formatters; | ||
} | ||
// cfg.extraOptions; | ||
in | ||
mkIf cfg.enable { | ||
extraPlugins = [cfg.package]; | ||
|
||
extraConfigLua = '' | ||
require("conform").setup(${helpers.toLuaObject setupOptions}) | ||
''; | ||
}; | ||
} |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,61 @@ | ||
{ | ||
empty = { | ||
plugins.conform-nvim.enable = true; | ||
}; | ||
|
||
default = { | ||
plugins.conform-nvim = { | ||
enable = true; | ||
formattersByFt = { | ||
lua = ["stylua"]; | ||
python = ["isort" "black"]; | ||
javascript = [["prettierd" "prettier"]]; | ||
"*" = ["codespell"]; | ||
"_" = ["trimWhitespace"]; | ||
}; | ||
formatOnSave = { | ||
lspFallback = true; | ||
timeoutMs = 500; | ||
}; | ||
formatAfterSave = { | ||
lspFallback = true; | ||
}; | ||
logLevel = "ERROR"; | ||
notifyOnError = true; | ||
formatters = { | ||
myFormatter = { | ||
command = "myCmd"; | ||
args = ["--stdin-from-filename" "$FILENAME"]; | ||
rangeArgs = '' | ||
function(ctx) | ||
return { "--line-start", ctx.range.start[1], "--line-end", ctx.range["end"][1] } | ||
end; | ||
''; | ||
stdin = true; | ||
cwd = '' | ||
require("conform.util").rootFile({ ".editorconfig", "package.json" }); | ||
''; | ||
requireCwd = true; | ||
condition = '' | ||
function(ctx) | ||
return vim.fs.basename(ctx.filename) ~= "README.md" | ||
end; | ||
''; | ||
exitCodes = [0 1]; | ||
env = { | ||
VAR = "value"; | ||
}; | ||
"inherit" = true; | ||
prependArgs = ["--use-tabs"]; | ||
}; | ||
otherFormatter = '' | ||
function(bufnr) | ||
return { | ||
command = "myCmd"; | ||
} | ||
end; | ||
''; | ||
}; | ||
}; | ||
}; | ||
} |
This file was deleted.
Oops, something went wrong.