From 576bff92b60d2f8707d74f0ddcef13dec35032e3 Mon Sep 17 00:00:00 2001 From: Alejandro Soto Date: Thu, 17 Mar 2022 15:57:31 -0600 Subject: pkgs/scripts: add merge-pdfs --- pkgs/scripts/default.nix | 1 + pkgs/scripts/merge-pdfs.nix | 34 ++++++++++++++++++++++++++++++++++ 2 files changed, 35 insertions(+) create mode 100755 pkgs/scripts/merge-pdfs.nix (limited to 'pkgs/scripts') diff --git a/pkgs/scripts/default.nix b/pkgs/scripts/default.nix index dc37056..18900f6 100644 --- a/pkgs/scripts/default.nix +++ b/pkgs/scripts/default.nix @@ -4,5 +4,6 @@ symlinkJoin { paths = [ (callPackage ./clip.nix { toPDF = false; }) (callPackage ./clip.nix { toPDF = true; }) + (callPackage ./merge-pdfs.nix {}) ]; } diff --git a/pkgs/scripts/merge-pdfs.nix b/pkgs/scripts/merge-pdfs.nix new file mode 100755 index 0000000..584505a --- /dev/null +++ b/pkgs/scripts/merge-pdfs.nix @@ -0,0 +1,34 @@ +{ writeShellScriptBin, pdftk, ... }: +writeShellScriptBin "merge-pdfs" '' + set -e + export PATH="$PATH:${pdftk}/bin" + + if [ $# -lt 3 ]; then + echo "Usage: $0 " >&2 + exit 1 + fi + + OUTPUT="$1" + shift + + WORKDIR="$HOME/vtmp/merge-pdfs.$$" + BOOKMARKS="$WORKDIR/bookmarks.txt" + FMT="BookmarkBegin + BookmarkTitle: %s + BookmarkLevel: 1 + BookmarkPageNumber: 1 + " + + mkdir "$WORKDIR" + + N=0 + for SOURCE in "$@"; do + BASE="$(basename "$SOURCE")" + printf "$FMT" "''${BASE%.*}" >"$BOOKMARKS" + pdftk "$SOURCE" update_info "$BOOKMARKS" output "$WORKDIR/"$(printf "%04d" $N).pdf + N=$((N+1)) + done + + pdftk "$WORKDIR"/*.pdf cat output "$OUTPUT" + rm -r "$WORKDIR" +'' -- cgit v1.2.3