pandoc: add new module
Add a module for pandoc that provides the following: 1. Setting default configuration options. 2. Installing templates. 3. Installing citation styles.
This commit is contained in:
parent
e622c5d836
commit
c47c350f65
3
.github/CODEOWNERS
vendored
3
.github/CODEOWNERS
vendored
|
@ -176,6 +176,9 @@
|
||||||
|
|
||||||
/modules/programs/openssh.nix @rycee
|
/modules/programs/openssh.nix @rycee
|
||||||
|
|
||||||
|
/modules/programs/pandoc.nix @kirelagin
|
||||||
|
/tests/modules/programs/pandoc @kirelagin
|
||||||
|
|
||||||
/modules/programs/password-store.nix @pacien
|
/modules/programs/password-store.nix @pacien
|
||||||
|
|
||||||
/modules/programs/pazi.nix @marsam
|
/modules/programs/pazi.nix @marsam
|
||||||
|
|
|
@ -2380,6 +2380,13 @@ in
|
||||||
A new module is available: 'programs.tint2'.
|
A new module is available: 'programs.tint2'.
|
||||||
'';
|
'';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
time = "2022-01-22T17:39:20+00:00";
|
||||||
|
message = ''
|
||||||
|
A new module is available: 'programs.pandoc'.
|
||||||
|
'';
|
||||||
|
}
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -117,6 +117,7 @@ let
|
||||||
./programs/octant.nix
|
./programs/octant.nix
|
||||||
./programs/offlineimap.nix
|
./programs/offlineimap.nix
|
||||||
./programs/opam.nix
|
./programs/opam.nix
|
||||||
|
./programs/pandoc.nix
|
||||||
./programs/password-store.nix
|
./programs/password-store.nix
|
||||||
./programs/pazi.nix
|
./programs/pazi.nix
|
||||||
./programs/pet.nix
|
./programs/pet.nix
|
||||||
|
|
104
modules/programs/pandoc.nix
Normal file
104
modules/programs/pandoc.nix
Normal file
|
@ -0,0 +1,104 @@
|
||||||
|
{ config, lib, pkgs, ... }:
|
||||||
|
|
||||||
|
let
|
||||||
|
|
||||||
|
cfg = config.programs.pandoc;
|
||||||
|
|
||||||
|
inherit (lib) literalExpression mkEnableOption mkIf mkOption types;
|
||||||
|
|
||||||
|
jsonFormat = pkgs.formats.json { };
|
||||||
|
|
||||||
|
makeTemplateFile = name: file:
|
||||||
|
lib.nameValuePair "pandoc/templates/${name}" { source = file; };
|
||||||
|
|
||||||
|
getFileName = file:
|
||||||
|
# This is actually safe here, since it is just a file name
|
||||||
|
builtins.unsafeDiscardStringContext (baseNameOf file);
|
||||||
|
|
||||||
|
makeCslFile = file:
|
||||||
|
lib.nameValuePair "pandoc/csl/${getFileName file}" { source = file; };
|
||||||
|
|
||||||
|
in {
|
||||||
|
meta.maintainers = [ lib.maintainers.kirelagin ];
|
||||||
|
|
||||||
|
options.programs.pandoc = {
|
||||||
|
enable = mkEnableOption "pandoc";
|
||||||
|
|
||||||
|
package = mkOption {
|
||||||
|
type = types.package;
|
||||||
|
default = pkgs.pandoc;
|
||||||
|
defaultText = literalExpression "pkgs.pandoc";
|
||||||
|
description = "The pandoc package to use.";
|
||||||
|
};
|
||||||
|
|
||||||
|
# We wrap the executable to pass some arguments
|
||||||
|
finalPackage = mkOption {
|
||||||
|
type = types.package;
|
||||||
|
readOnly = true;
|
||||||
|
description = "Resulting package.";
|
||||||
|
};
|
||||||
|
|
||||||
|
defaults = mkOption {
|
||||||
|
type = jsonFormat.type;
|
||||||
|
default = { };
|
||||||
|
example = literalExpression ''
|
||||||
|
{
|
||||||
|
metadata = {
|
||||||
|
author = "John Doe";
|
||||||
|
};
|
||||||
|
pdf-engine = "xelatex";
|
||||||
|
citeproc = true;
|
||||||
|
}
|
||||||
|
'';
|
||||||
|
description = ''
|
||||||
|
Options to set by default.
|
||||||
|
These will be converted to JSON and written to a defaults
|
||||||
|
file (see Default files in pandoc documentation).
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
defaultsFile = mkOption {
|
||||||
|
type = types.path;
|
||||||
|
readOnly = true;
|
||||||
|
description = "Resulting defaults file.";
|
||||||
|
};
|
||||||
|
|
||||||
|
templates = mkOption {
|
||||||
|
type = types.attrsOf types.path;
|
||||||
|
default = { };
|
||||||
|
example = literalExpression ''
|
||||||
|
{
|
||||||
|
"default.latex" = path/to/your/template;
|
||||||
|
}
|
||||||
|
'';
|
||||||
|
description = "Custom templates.";
|
||||||
|
};
|
||||||
|
|
||||||
|
citationStyles = mkOption {
|
||||||
|
type = types.listOf types.path;
|
||||||
|
default = [ ];
|
||||||
|
example = literalExpression "[ path/to/file.csl ]";
|
||||||
|
description = "List of .csl files to install.";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
config = mkIf cfg.enable {
|
||||||
|
programs.pandoc = {
|
||||||
|
defaultsFile = jsonFormat.generate "hm.json" cfg.defaults;
|
||||||
|
|
||||||
|
finalPackage = pkgs.symlinkJoin {
|
||||||
|
name = "pandoc-with-defaults";
|
||||||
|
paths = [ cfg.package ];
|
||||||
|
nativeBuildInputs = [ pkgs.makeWrapper ];
|
||||||
|
postBuild = ''
|
||||||
|
wrapProgram "$out/bin/pandoc" \
|
||||||
|
--add-flags '--defaults "${cfg.defaultsFile}"'
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
home.packages = [ cfg.finalPackage ];
|
||||||
|
xdg.dataFile = lib.mapAttrs' makeTemplateFile cfg.templates
|
||||||
|
// lib.listToAttrs (map makeCslFile cfg.citationStyles);
|
||||||
|
};
|
||||||
|
}
|
|
@ -86,6 +86,7 @@ import nmt {
|
||||||
./modules/programs/nix-index
|
./modules/programs/nix-index
|
||||||
./modules/programs/nnn
|
./modules/programs/nnn
|
||||||
./modules/programs/nushell
|
./modules/programs/nushell
|
||||||
|
./modules/programs/pandoc
|
||||||
./modules/programs/pet
|
./modules/programs/pet
|
||||||
./modules/programs/powerline-go
|
./modules/programs/powerline-go
|
||||||
./modules/programs/qutebrowser
|
./modules/programs/qutebrowser
|
||||||
|
|
18
tests/modules/programs/pandoc/csl.nix
Normal file
18
tests/modules/programs/pandoc/csl.nix
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
{ config, ... }:
|
||||||
|
|
||||||
|
{
|
||||||
|
programs.pandoc = {
|
||||||
|
enable = true;
|
||||||
|
|
||||||
|
citationStyles = [ ./example.csl ];
|
||||||
|
};
|
||||||
|
|
||||||
|
test.stubs.pandoc = import ./stub.nix;
|
||||||
|
|
||||||
|
nmt.script = ''
|
||||||
|
assertFileExists home-files/.local/share/pandoc/csl/example.csl
|
||||||
|
assertFileContent home-files/.local/share/pandoc/csl/example.csl \
|
||||||
|
${./example.csl}
|
||||||
|
'';
|
||||||
|
}
|
||||||
|
|
5
tests/modules/programs/pandoc/default.nix
Normal file
5
tests/modules/programs/pandoc/default.nix
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
{
|
||||||
|
pandoc-citation-styles = ./csl.nix;
|
||||||
|
pandoc-defaults = ./defaults.nix;
|
||||||
|
pandoc-templates = ./templates.nix;
|
||||||
|
}
|
7
tests/modules/programs/pandoc/defaults-expected.json
Normal file
7
tests/modules/programs/pandoc/defaults-expected.json
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
{
|
||||||
|
"citeproc": true,
|
||||||
|
"metadata": {
|
||||||
|
"author": "John Doe"
|
||||||
|
},
|
||||||
|
"pdf-engine": "xelatex"
|
||||||
|
}
|
30
tests/modules/programs/pandoc/defaults.nix
Normal file
30
tests/modules/programs/pandoc/defaults.nix
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
{ config, lib, ... }:
|
||||||
|
|
||||||
|
let cfg = config.programs.pandoc;
|
||||||
|
|
||||||
|
in {
|
||||||
|
config = lib.mkIf config.test.enableBig {
|
||||||
|
programs.pandoc = {
|
||||||
|
enable = true;
|
||||||
|
|
||||||
|
defaults = {
|
||||||
|
metadata = { author = "John Doe"; };
|
||||||
|
pdf-engine = "xelatex";
|
||||||
|
citeproc = true;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
nmt.script = ''
|
||||||
|
assertFileContent ${cfg.defaultsFile} ${./defaults-expected.json}
|
||||||
|
|
||||||
|
# Test that defaults are set by looking at the metadata for an empty file
|
||||||
|
# (it should contain the author that we set in defaults).
|
||||||
|
output=$(mktemp)
|
||||||
|
${cfg.finalPackage}/bin/pandoc --standalone \
|
||||||
|
-f markdown /dev/null \
|
||||||
|
-t native -o "$output"
|
||||||
|
assertFileContent "$output" ${./output-expected}
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
12
tests/modules/programs/pandoc/example.csl
Normal file
12
tests/modules/programs/pandoc/example.csl
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<style xmlns="http://purl.org/net/xbiblio/csl" version="1.0" default-locale="en-US">
|
||||||
|
<info>
|
||||||
|
<title>A trivial CSL style for tests</title>
|
||||||
|
<id>https://github.com/nix-community/home-manager/tree/master/tests/modules/tools/pandoc/example.csl</id>
|
||||||
|
<link href="https://github.com/nix-community/home-manager/tree/master/tests/modules/tools/pandoc/example.csl" rel="self"/>
|
||||||
|
<link href=""https://www.zotero.org/styles/association-for-computing-machinery rel="independent-parent"/>
|
||||||
|
<link href="http://aem.asm.org/" rel="documentation"/>
|
||||||
|
<category citation-format="numeric"/>
|
||||||
|
<category field="engineering"/>
|
||||||
|
</info>
|
||||||
|
</style>
|
2
tests/modules/programs/pandoc/output-expected
Normal file
2
tests/modules/programs/pandoc/output-expected
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
Pandoc (Meta {unMeta = fromList [("author",MetaString "John Doe")]})
|
||||||
|
[]
|
10
tests/modules/programs/pandoc/stub.nix
Normal file
10
tests/modules/programs/pandoc/stub.nix
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
{
|
||||||
|
name = "pandoc-stub";
|
||||||
|
outPath = null;
|
||||||
|
buildScript = ''
|
||||||
|
mkdir -p "$out"/bin
|
||||||
|
pandoc="$out"/bin/pandoc
|
||||||
|
echo 'Stub to make the wrapper happy' > "$pandoc"
|
||||||
|
chmod a+x "$pandoc"
|
||||||
|
'';
|
||||||
|
}
|
9
tests/modules/programs/pandoc/template.latex
Normal file
9
tests/modules/programs/pandoc/template.latex
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
\documentclass[a4paper]{scrartcl}
|
||||||
|
|
||||||
|
$if(title)$\title{$title$}$endif$
|
||||||
|
$if(author)$\author{$for(author)$$author$$sep$ \and $endfor$}$endif$
|
||||||
|
|
||||||
|
\begin{document}
|
||||||
|
\maketitle
|
||||||
|
$body$
|
||||||
|
\end{document}
|
18
tests/modules/programs/pandoc/templates.nix
Normal file
18
tests/modules/programs/pandoc/templates.nix
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
{ config, ... }:
|
||||||
|
|
||||||
|
{
|
||||||
|
programs.pandoc = {
|
||||||
|
enable = true;
|
||||||
|
|
||||||
|
templates = { "default.latex" = ./template.latex; };
|
||||||
|
};
|
||||||
|
|
||||||
|
test.stubs.pandoc = import ./stub.nix;
|
||||||
|
|
||||||
|
nmt.script = ''
|
||||||
|
assertFileExists home-files/.local/share/pandoc/templates/default.latex
|
||||||
|
assertFileContent home-files/.local/share/pandoc/templates/default.latex \
|
||||||
|
${./template.latex}
|
||||||
|
'';
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue