—package
Pod::Elemental::Element::Pod5::Region 0.103006;
# ABSTRACT: a region of Pod (this role likely to be removed)
use
Moose;
with
qw(
Pod::Elemental::Node
Pod::Elemental::Command
)
;
#pod =head1 WARNING
#pod
#pod This class is somewhat sketchy and may be refactored somewhat in the future,
#pod specifically to refactor its similarities to
#pod L<Pod::Elemental::Element::Nested>.
#pod
#pod =head1 OVERVIEW
#pod
#pod A Pod5::Region element represents a region marked by a C<=for> command or a
#pod pair of C<=begin> and C<=end> commands. It may have content of its own as well
#pod as child paragraphs.
#pod
#pod Its C<as_pod_string> method will emit either a C<=begin/=end>-enclosed string
#pod or a C<=for> command, based on whichever is permissible.
#pod
#pod =cut
#pod =attr format_name
#pod
#pod This is the format to which the region was targeted.
#pod
#pod B<Note!> The format name should I<not> include the leading colon to indicate a
#pod pod paragraph. For that, see C<L</is_pod>>.
#pod
#pod =cut
has
format_name
=> (
is
=>
'ro'
,
isa
=> FormatName,
required
=> 1);
#pod =attr is_pod
#pod
#pod If true, this region contains pod (ordinary or verbatim) paragraphs, as opposed
#pod to data paragraphs. This will generally result from the document originating
#pod in a C<=begin> block with a colon-prefixed target identifier:
#pod
#pod =begin :html
#pod
#pod This is still a verbatim paragraph.
#pod
#pod =end :html
#pod
#pod =cut
has
is_pod
=> (
is
=>
'ro'
,
isa
=> Bool,
required
=> 1,
default
=> 1);
sub
command {
'begin'
}
sub
closing_command {
'end'
}
sub
_display_as_for {
my
(
$self
) =
@_
;
# Everything after "=for target" becomes the lone child paragraph, so there
# is nowhere to put the (technically illegal) content. -- rjbs, 2009-11-24
return
if
$self
->content =~ /\S/;
# We can't have more than one paragraph, because there'd be a blank, so we
# couldn't round trip. -- rjbs, 2009-11-24
return
if
@{
$self
->children } != 1;
my
$child
=
$self
->children->[0];
return
if
$child
->content =~ m{^\s*$}m;
my
$base
=
'Pod::Elemental::Element::Pod5::'
;
return
1
if
$self
->is_pod and
$child
->isa(
"${base}Ordinary"
);
return
1
if
!
$self
->is_pod and
$child
->isa(
"${base}Data"
);
return
;
}
sub
as_pod_string {
my
(
$self
) =
@_
;
my
$string
;
if
(
$self
->_display_as_for) {
$string
=
$self
->__as_pod_string_for(
$self
);
}
else
{
$string
=
$self
->__as_pod_string_begin(
$self
);
}
$string
=~ s/\n*\z//g;
return
$string
;
}
sub
__as_pod_string_begin {
my
(
$self
) =
@_
;
my
$content
=
$self
->content;
my
$colon
=
$self
->is_pod ?
':'
:
''
;
my
$string
=
sprintf
"=%s %s%s\n"
,
$self
->command,
$colon
.
$self
->format_name,
(
$content
=~ /\S/ ?
" $content\n"
:
"\n"
);
$string
.=
join
(
q{}
,
map
{
$_
->as_pod_string } @{
$self
->children });
$string
.=
"\n\n"
if
@{
$self
->children }
and
$self
->children->[-1]->isa(
'Pod::Elemental::Element::Pod5::Data'
);
# Pod5::$self->is_pod; # XXX: HACK!! -- rjbs, 2009-10-21
$string
.=
sprintf
"=%s %s"
,
$self
->closing_command,
$colon
.
$self
->format_name;
return
$string
;
}
sub
__as_pod_string_for {
my
(
$self
) =
@_
;
my
$content
=
$self
->content;
my
$colon
=
$self
->is_pod ?
':'
:
''
;
my
$string
=
sprintf
"=for %s %s"
,
$colon
.
$self
->format_name,
$self
->children->[0]->as_pod_string;
return
$string
;
}
sub
as_debug_string {
my
(
$self
) =
@_
;
my
$colon
=
$self
->is_pod ?
':'
:
''
;
my
$string
=
sprintf
"=%s %s"
,
$self
->command,
$colon
.
$self
->format_name;
return
$string
;
}
# BEGIN Autochomp Replacement
has
'+content'
=> (
coerce
=> 1,
isa
=> ChompedString);
# END Autochomp Replacement
__PACKAGE__->meta->make_immutable;
no
Moose;
1;
__END__
=pod
=encoding UTF-8
=head1 NAME
Pod::Elemental::Element::Pod5::Region - a region of Pod (this role likely to be removed)
=head1 VERSION
version 0.103006
=head1 OVERVIEW
A Pod5::Region element represents a region marked by a C<=for> command or a
pair of C<=begin> and C<=end> commands. It may have content of its own as well
as child paragraphs.
Its C<as_pod_string> method will emit either a C<=begin/=end>-enclosed string
or a C<=for> command, based on whichever is permissible.
=head1 PERL VERSION
This library should run on perls released even a long time ago. It should work
on any version of perl released in the last five years.
Although it may work on older versions of perl, no guarantee is made that the
minimum required version will not be increased. The version may be increased
for any reason, and there is no promise that patches will be accepted to lower
the minimum required perl.
=head1 ATTRIBUTES
=head2 format_name
This is the format to which the region was targeted.
B<Note!> The format name should I<not> include the leading colon to indicate a
pod paragraph. For that, see C<L</is_pod>>.
=head2 is_pod
If true, this region contains pod (ordinary or verbatim) paragraphs, as opposed
to data paragraphs. This will generally result from the document originating
in a C<=begin> block with a colon-prefixed target identifier:
=begin :html
This is still a verbatim paragraph.
=end :html
=head1 WARNING
This class is somewhat sketchy and may be refactored somewhat in the future,
specifically to refactor its similarities to
L<Pod::Elemental::Element::Nested>.
=head1 AUTHOR
Ricardo SIGNES <cpan@semiotic.systems>
=head1 COPYRIGHT AND LICENSE
This software is copyright (c) 2022 by Ricardo SIGNES.
This is free software; you can redistribute it and/or modify it under
the same terms as the Perl 5 programming language system itself.
=cut