pandoc/test/command/4186.md
John MacFarlane 7a9832166e Add text wrapping to HTML output.
Previously the HTML writer was exceptional in not being
sensitive to the `--wrap` option.  With this change `--wrap`
now works for HTML. The default (as with other formats) is
automatic wrapping to 72 columns.

A new internal module, T.P.Writers.Blaze, exports `layoutMarkup`.
This converts a blaze Html structure into a doclayout Doc Text.

In addition, we now add a line break between an `img` tag
and the associated `figcaption`.

Note: Output is never wrapped in `writeHtmlStringForEPUB`.
This accords with previous behavior since previously the HTML
writer was insensitive to `--wrap` settings.  There's no real
need to wrap HTML inside a zipped container.

Note that the contents of script, textarea, and pre tags are
always laid out with the `flush` combinator, so that unwanted
spaces won't be introduced if these occur in an indented context
in a template.

Closes #7764.
2021-12-22 09:45:02 -08:00

2.5 KiB

% pandoc -f org -t native
#+begin_example -i
    This should retain the four leading spaces
#+end_example
^D
[ CodeBlock
    ( "" , [ "example" ] , [] )
    "    This should retain the four leading spaces\n"
]
% pandoc -f org -t html
- depth 1
  #+name: bob
  #+begin_example -i
    Vertical alignment is four spaces beyond the appearance of the word "depth".
  #+end_example
       - depth 2
         #+begin_example
                          Vertically aligned with the second appearance of the word "depth".
         #+end_example
              #+begin_example -i
    Vertical alignment is four spaces beyond the second
    appearance of the word "depth".
    The "begin" portion is a component of
    this deeper list element, so that guarantees
    that the entire block must be a component of the
    inner list element.
    #+end_example
         Still inside the inner list element
   #+name: carrie
                         #+begin_example
                           This belongs to the outer list element, and is aligned accordingly, since the NAME attribute is not indented deeply enough. It is not enough for the BEGIN alone to be aligned deeply if the block is meant to have a NAME.
                           #+end_example
                 Still in the shallower list element since the preceding example
                 block forced the deeper list element to terminate.
Outside all lists.
^D
<ul>
<li><p>depth 1</p>
<pre id="bob" class="example"><code>    Vertical alignment is four spaces beyond the appearance of the word &quot;depth&quot;.
</code></pre>
<ul>
<li><p>depth 2</p>
<pre class="example"><code>Vertically aligned with the second appearance of the word &quot;depth&quot;.
</code></pre>
<pre class="example"><code>    Vertical alignment is four spaces beyond the second
    appearance of the word &quot;depth&quot;.
    The &quot;begin&quot; portion is a component of
    this deeper list element, so that guarantees
    that the entire block must be a component of the
    inner list element.
</code></pre>
<p>Still inside the inner list element</p></li>
</ul>
<pre id="carrie" class="example"><code>This belongs to the outer list element, and is aligned accordingly, since the NAME attribute is not indented deeply enough. It is not enough for the BEGIN alone to be aligned deeply if the block is meant to have a NAME.
</code></pre>
<p>Still in the shallower list element since the preceding example block
forced the deeper list element to terminate.</p></li>
</ul>
<p>Outside all lists.</p>