Форматирование заголовка в функции Emacs для печати буфера в PDF с переносом строк - PullRequest
4 голосов
/ 16 сентября 2011

Руперт Сварбрик предложил следующие три функции для печати буфера Emacs в pdf, в который переносятся строки (обычно это не так при использовании ps-print* функций).

Проблема в этой функциив том, что для достижения этого переноса строки должна быть сделана копия текущего буфера.Это фактически лишает возможности ps-print-buffer-with-faces отображать правильный заголовок вверху каждой страницы в конечном PDF-файле.

В рамках своего решения Руперт Сварбрик написал функцию, которая сохраняет эту информацию.Получающийся заголовок, однако, всегда имеет вид HeaderLinesLeft

Кто может обнаружить ошибку?

(defun harden-newlines ()
  (interactive)
  "Make all the newlines in the buffer hard."
  (save-excursion
    (goto-char (point-min))
    (while (search-forward "\n" nil t)
      (backward-char)
      (put-text-property (point) (1+ (point)) 'hard t)
      (forward-char))))

(defun spool-buffer-given-name (name)
  (load "ps-print")
  (let ((tmp ps-left-header))
    (unwind-protect
        (progn
          (setq ps-left-header
                (list (lambda () name) 'ps-header-dirpart))
          (ps-spool-buffer-with-faces))
      (setf ps-left-header tmp))))

(defun print-to-pdf ()
  "Print the current file to /tmp/print.pdf"
  (interactive)
  (let ((wbuf (generate-new-buffer "*Wrapped*"))
        (sbuf (current-buffer)))
    (jit-lock-fontify-now)
    (save-current-buffer
      (set-buffer wbuf)
      (insert-buffer sbuf)
      (setq fill-column 95)
      (longlines-mode t)
      (harden-newlines)
      (message (buffer-name sbuf))
      (spool-buffer-given-name (buffer-name sbuf))
      (kill-buffer wbuf)
      (switch-to-buffer "*PostScript*")
      (write-file "/tmp/print.ps")
      (kill-buffer (current-buffer)))
    (call-process "ps2pdf14" nil nil nil
                  "/tmp/print.ps" "/tmp/print.pdf")
    (delete-file "/tmp/print.ps")
    (message "PDF saved to /tmp/print.pdf")))

1 Ответ

2 голосов
/ 18 декабря 2011

Попробуйте это:

(defun spool-buffer-given-name (name)
  (let ((ps-left-header (list (format "(%s)" name))))
    (ps-spool-buffer-with-faces)))

См. Документацию по переменной ps-left-header, что и объяснило мне выше.

Это аккуратная возможность; Я определенно буду использовать его вместо ps-print. Было бы хорошо, чтобы он действовал как C-u M-x ps-print-buffer-with-face; две отсутствующие функции - это имя каталога в заголовке и запрос пользователя к имени файла. Ни то, ни другое не сложно.

...