Text is mainly output in two inline text containers, paragraph
for
text in paragraph and preformatted
for text in preformatted
environments. The Texinfo code parsing makes sure that it is the case, to
simplify conversion to formats which allow text only in specific environments
such as HTML.
Formatted text may also be prepared based on information from Texinfo
elements tree while out of the inline containers. For example, @quotation
argument should in general be prepended to the first paragraph in @quotation
,
caption number is also typically prependended to the caption.
For that case, functions allow to register pending inline formatted content,
and get the content to be prepended in inline text containers.
Pending formatted content text is registered with
register_pending_formatted_inline_content
:
$content is the formatted content to be registered and output in the next inline container. $category is a indicator of the source of the formatted inline content, mostly used to cancel registered content if no inline container was seen.
For example
my $quotation_arg_to_prepend = $converter->convert_text($quotation_arg_element); $converter->register_pending_formatted_inline_content('quotation', $formatted_quotation_arg_to_prepend);
Pending formatted content can (and should) be cancelled when it is known that
there is no suitable inline container to be used to output the text. The
function is cancel_pending_formatted_inline_content
:
$cancelled_content =
$converter->cancel_pending_formatted_inline_content ($category)
¶Cancel the first $category pending formatted content text found.
Returns undef
if nothing was cancelled, and the cancelled
content otherwise.
Pending formatted content is gathered by calling get_pending_formatted_inline_content
.
In the default case, this is done in inline containers opening
code (see Type Tree Element Opening Functions).
$content =
$converter->get_pending_formatted_inline_content ()
¶Returns the concatenated pending content.
The inline containers get the content when they are opened, but are
converted after the formatting of their contents. Two additional functions
allow to associate pending content to an element,
associate_pending_formatted_inline_content
, and get the associated
content, get_associated_formatted_inline_content
.
associate_pending_formatted_inline_content
is normally called in inline
container opening code, right after
get_pending_formatted_inline_content
, while
get_associated_formatted_inline_content
is called in the inline
container conversion function (see Type Tree Element Conversion Functions).
Associate $content to the Texinfo tree element \%element.
$content =
$converter->get_associated_formatted_inline_content (\%element)
¶Get $content associated with the Texinfo tree element \%element.
Here is some inline container formatting code showing how those functions are used, with the paragraph type element formatting example completed:
sub _open_inline_container_type($$$) { my $self = shift; my $type = shift; my $element = shift; my $pending_formatted = $self->get_pending_formatted_inline_content(); if (defined($pending_formatted)) { $self->associate_pending_formatted_inline_content($element, $pending_formatted); } return ''; }
sub my_final_convert_paragraph_type($$$$) { my $converter = shift; my $type = shift; my $element = shift; my $content = shift; $content = '' if (!defined($content)); my $prepended = $converter->get_associated_formatted_inline_content($element); if ($converter->in_string()) { return $prepended.$content; }
my @contents = {$element->{'contents'}}; push @contents, {'text' => ' <code>HTML</code> text ', 'type' => '_converted'}; my $result = $converter->convert_tree({'type' => '_code', 'contents' => \@contents }); return "<p>".$prepended.$result."</p>"; }
texinfo_register_type_formatting('paragraph', \&my_final_convert_paragraph_type);