NAME
String::Tagged::Markdown
- parse and emit text with Markdown inline formatting
SYNOPSIS
my
$st
= String::Tagged::Markdown->parse_markdown(
$markdown
);
# Conforms to the String::Tagged::Formatting API
String::Tagged::Terminal->new_from_formatting(
$st
->as_formatting
)->say_to_terminal;
DESCRIPTION
This subclass of String::Tagged handles text that contains inline markers to give formatting hints, in the style used by Markdown. For example, text wrapped in double-asterisks indicates it should be bold (as **bold**
), or single-asterisks to indicate italics (as *italics*
).
This module does not provide a full Markdown parser, but it does handle enough of the simple inline markers that it could be used to handle Markdown-style formatting hints of small paragraphs of text.
TAGS
This module provides the following tags.
bold, italic, strike, fixed
Boolean values indicating bold, italics, strike-through or fixed-width.
link
String value indicating a link. The value itself is the link target.
CONSTRUCTORS
parse_markdown
$st
= String::Tagged::Markdown->parse_markdown(
$str
);
Parses a text string containing Markdown-like formatting as described above.
Recognises the following kinds of inline text markers:
*
*bold
**
*italic
*
~~strike~~
`fixed`
[
link
](target)
backslashes escape any special characters as \*
In addition, within `fixed`
width spans, the other formatting markers are not recognised and are interpreted literally. To include literal backticks inside a `fixed`
width span, use multiple backticks and a space to surround the sequence. Any sequence of fewer backticks within the sequence is interpreted literally. A single space on each side immediately within the outer backticks will be stripped, if present.
`` fixed width
with
`literal backticks` inside it ``
HTML entities - such as &
, –
or Ӓ
are decoded, but only when not inside `fixed`
spans.
new_from_formatting
$st
= String::Tagged::Markdown->new_from_formatting(
$fmt
,
%args
)
Returns a new instance by convertig String::Tagged::Formatting standard tags.
The bold
, italic
, strike
and link
tags are preserved. monospace
is renamed to fixed
.
Supports the following extra named arguments:
-
Optionally provides additional tag conversion callbacks, as defined by "clone" in String::Tagged.
METHODS
build_markdown
$str
=
$st
->build_markdown;
Returns a plain text string containing Markdown-like inline formatting markers to format the tags in the given instance. Uses the notation given in the "parse_markdown" method above.
Non-ASCII Unicode characters are not generally emitted as HTML entities; though &
and
are generated for convenience.
as_formatting
$fmt
=
$st
->as_formatting(
%args
);
Returns a new String::Tagged
instance tagged with String::Tagged::Formatting standard tags.
The bold
, italic
, strike
and link
tags are preserved, fixed
is renamed to monospace
.
Supports the following extra named arguments:
-
Optionally provides additional tag conversion callbacks, as defined by "clone" in String::Tagged.
TODO
Fine-grained control of what HTML entities are generated on output.
AUTHOR
Paul Evans <leonerd@leonerd.org.uk>