Compare commits

..

2 commits

Author SHA1 Message Date
e76ace674f merge: resolve conflict with origin/main 2026-03-05 11:04:53 -05:00
6f090fdcf3
build: split nix dev shell into default and presets
Problem: the single dev shell mixed dev tooling (linters, test runner)
with preset compiler tools, causing heavy rebuilds (e.g. Chromium for
`mermaid-cli`) for contributors who only need the dev tools.

Solution: extract dev tooling into a shared `devTools` list and expose
two shells — `default` for development and `presets` for running all
built-in preset compilers (`typst`, `texliveMedium`, `tectonic`,
`pandoc`, `asciidoctor`, `quarto`, `plantuml`, `mermaid-cli`).
2026-03-05 10:55:03 -05:00
6 changed files with 16 additions and 33 deletions

View file

@ -1,6 +1,6 @@
# preview.nvim # preview.nvim
**Universal previewer for Neovim** **Universal document previewer for Neovim**
An extensible framework for compiling and previewing _any_ documents (LaTeX, An extensible framework for compiling and previewing _any_ documents (LaTeX,
Typst, Markdown, etc.)—diagnostics included. Typst, Markdown, etc.)—diagnostics included.

View file

@ -68,10 +68,6 @@ Provider fields: ~
receives a |preview.Context| and receives a |preview.Context| and
returns a string[]. returns a string[].
{extra_args} (string[]|function) Appended to {args} after evaluation.
Useful for adding flags to a preset
without replacing its defaults.
{cwd} (string|function) Working directory. If a function, {cwd} (string|function) Working directory. If a function,
receives a |preview.Context|. receives a |preview.Context|.
Default: git root or file directory. Default: git root or file directory.

View file

@ -19,8 +19,7 @@
{ {
formatter = forEachSystem (pkgs: pkgs.nixfmt-tree); formatter = forEachSystem (pkgs: pkgs.nixfmt-tree);
devShells = forEachSystem ( devShells = forEachSystem (pkgs:
pkgs:
let let
devTools = [ devTools = [
(pkgs.luajit.withPackages ( (pkgs.luajit.withPackages (
@ -51,7 +50,6 @@
pkgs.mermaid-cli pkgs.mermaid-cli
]; ];
}; };
} });
);
}; };
} }

View file

@ -309,9 +309,6 @@ function M.compile(bufnr, name, provider, ctx, opts)
if provider.args then if provider.args then
vim.list_extend(cmd, eval_list(provider.args, resolved_ctx)) vim.list_extend(cmd, eval_list(provider.args, resolved_ctx))
end end
if provider.extra_args then
vim.list_extend(cmd, eval_list(provider.extra_args, resolved_ctx))
end
log.dbg('compiling buffer %d with provider "%s": %s', bufnr, name, table.concat(cmd, ' ')) log.dbg('compiling buffer %d with provider "%s": %s', bufnr, name, table.concat(cmd, ' '))

View file

@ -2,7 +2,6 @@
---@field ft? string ---@field ft? string
---@field cmd string[] ---@field cmd string[]
---@field args? string[]|fun(ctx: preview.Context): string[] ---@field args? string[]|fun(ctx: preview.Context): string[]
---@field extra_args? string[]|fun(ctx: preview.Context): string[]
---@field cwd? string|fun(ctx: preview.Context): string ---@field cwd? string|fun(ctx: preview.Context): string
---@field env? table<string, string> ---@field env? table<string, string>
---@field output? string|fun(ctx: preview.Context): string ---@field output? string|fun(ctx: preview.Context): string
@ -95,7 +94,6 @@ function M.setup(opts)
vim.validate(prefix .. '.cmd', provider.cmd, 'table') vim.validate(prefix .. '.cmd', provider.cmd, 'table')
vim.validate(prefix .. '.cmd[1]', provider.cmd[1], 'string') vim.validate(prefix .. '.cmd[1]', provider.cmd[1], 'string')
vim.validate(prefix .. '.args', provider.args, { 'table', 'function' }, true) vim.validate(prefix .. '.args', provider.args, { 'table', 'function' }, true)
vim.validate(prefix .. '.extra_args', provider.extra_args, { 'table', 'function' }, true)
vim.validate(prefix .. '.cwd', provider.cwd, { 'string', 'function' }, true) vim.validate(prefix .. '.cwd', provider.cwd, { 'string', 'function' }, true)
vim.validate(prefix .. '.output', provider.output, { 'string', 'function' }, true) vim.validate(prefix .. '.output', provider.output, { 'string', 'function' }, true)
vim.validate(prefix .. '.error_parser', provider.error_parser, 'function', true) vim.validate(prefix .. '.error_parser', provider.error_parser, 'function', true)

View file

@ -115,24 +115,6 @@ local function parse_asciidoctor(output)
return diagnostics return diagnostics
end end
---@param output string
---@return preview.Diagnostic[]
local function parse_mermaid(output)
local lnum = output:match('Parse error on line (%d+)')
if not lnum then
return {}
end
local msg = output:match('(Expecting .+)') or 'parse error'
return {
{
lnum = tonumber(lnum) - 1,
col = 0,
message = msg,
severity = vim.diagnostic.severity.ERROR,
},
}
end
---@type preview.ProviderConfig ---@type preview.ProviderConfig
M.typst = { M.typst = {
ft = 'typst', ft = 'typst',
@ -331,7 +313,19 @@ M.mermaid = {
return (ctx.file:gsub('%.mmd$', '.svg')) return (ctx.file:gsub('%.mmd$', '.svg'))
end, end,
error_parser = function(output) error_parser = function(output)
return parse_mermaid(output) local diagnostics = {}
for line in output:gmatch('[^\r\n]+') do
local lnum = line:match('^%s*Parse error on line (%d+)')
if lnum then
table.insert(diagnostics, {
lnum = tonumber(lnum) - 1,
col = 0,
message = line,
severity = vim.diagnostic.severity.ERROR,
})
end
end
return diagnostics
end, end,
clean = function(ctx) clean = function(ctx)
return { 'rm', '-f', (ctx.file:gsub('%.mmd$', '.svg')) } return { 'rm', '-f', (ctx.file:gsub('%.mmd$', '.svg')) }