about summary refs log tree commit diff
path: root/src/guile
diff options
context:
space:
mode:
Diffstat (limited to 'src/guile')
-rw-r--r--src/guile/skribilo/engine/lout.scm17
1 files changed, 16 insertions, 1 deletions
diff --git a/src/guile/skribilo/engine/lout.scm b/src/guile/skribilo/engine/lout.scm
index 5285c76..d2a34e2 100644
--- a/src/guile/skribilo/engine/lout.scm
+++ b/src/guile/skribilo/engine/lout.scm
@@ -630,6 +630,10 @@
 			 (paragraph-gap
 			  "\n//1.0vx @ParaIndent @Wide &{0i}\n")
 
+                         ;; Gap for the first paragraph within a container
+                         ;; (e.g., the first paragraph of a chapter).
+                         (first-paragraph-gap "\n@LP\n")
+
 			 ;; For multi-page tables, it may be
 			 ;; useful to set this to `#t'.  However,
 			 ;; this looks kind of buggy.
@@ -1528,7 +1532,18 @@
 			      (markup-markup (ast-parent n)))
 			 '(chapter section subsection subsubsection slide))))
    :before (lambda (n e)
-	     (let ((gap (engine-custom e 'paragraph-gap)))
+             (define (first-paragraph?)
+               ;; Return true if N is the first paragraph in this container.
+               (let* ((parent   (ast-parent n))
+                      (siblings (markup-body parent)))
+                 (and (pair? siblings)
+                      (eq? n (find (lambda (n)
+                                     (is-markup? n 'paragraph))
+                                   siblings)))))
+
+	     (let ((gap (if (first-paragraph?)
+                            (engine-custom e 'first-paragraph-gap)
+                            (engine-custom e 'paragraph-gap))))
 	       (display (if (string? gap) gap "\n@PP\n")))))
 
 ;*---------------------------------------------------------------------*/