Compare commits
2 commits
feat/extra
...
build/nix-
| Author | SHA1 | Date | |
|---|---|---|---|
| e76ace674f | |||
| 6f090fdcf3 |
6 changed files with 16 additions and 33 deletions
|
|
@ -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.
|
||||||
|
|
|
||||||
|
|
@ -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.
|
||||||
|
|
|
||||||
|
|
@ -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
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
}
|
});
|
||||||
);
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -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, ' '))
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -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)
|
||||||
|
|
|
||||||
|
|
@ -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')) }
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue