are supported
93
|
|
|
|
|
|
|
- Inline images ... can be done, let me know if you need them and I'll upload in the backend |
94
|
|
|
|
|
|
|
|
95
|
|
|
|
|
|
|
Questions or comments ? Email me: perltricks.com@gmail.com |
96
|
|
|
|
|
|
|
|
97
|
|
|
|
|
|
|
|
98
|
|
|
|
|
|
|
|
99
|
|
|
|
|
|
|
=cut |
100
|
|
|
|
|
|
|
|
101
|
|
|
|
|
|
|
=over 4 |
102
|
|
|
|
|
|
|
|
103
|
|
|
|
|
|
|
=cut |
104
|
|
|
|
|
|
|
|
105
|
0
|
0
|
|
0
|
|
0
|
sub _ponder_begin ( $self, $para, $curr_open, $paras ){ |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
106
|
|
|
|
|
|
|
# XXX this is such a messed up way to do this, but this is |
107
|
|
|
|
|
|
|
# not designed to be extended |
108
|
0
|
0
|
|
|
|
0
|
unless ($para->[2] =~ /^\s*(?:output)/) { |
109
|
0
|
|
|
|
|
0
|
return $self->SUPER::_ponder_begin($para,$curr_open,$paras); |
110
|
|
|
|
|
|
|
} |
111
|
|
|
|
|
|
|
|
112
|
0
|
|
|
|
|
0
|
my $content = join ' ', splice @$para, 2; |
113
|
0
|
|
|
|
|
0
|
$content =~ s/^\s+//s; |
114
|
0
|
|
|
|
|
0
|
$content =~ s/\s+$//s; |
115
|
|
|
|
|
|
|
|
116
|
0
|
|
|
|
|
0
|
my ($target, $title) = $content =~ m/^(\S+)\s*(.*)$/; |
117
|
0
|
|
|
|
|
0
|
$para->[1]{'target'} = $target; # without any ':' |
118
|
|
|
|
|
|
|
|
119
|
0
|
0
|
|
|
|
0
|
return 1 unless $self->{'accept_targets'}{$target}; |
120
|
|
|
|
|
|
|
|
121
|
0
|
|
|
|
|
0
|
$para->[0] = '=for'; # Just what we happen to call these, internally |
122
|
0
|
|
0
|
|
|
0
|
$para->[1]{'~really'} ||= '=begin'; |
123
|
0
|
|
|
|
|
0
|
$para->[1]{'~resolve'} = 1; |
124
|
|
|
|
|
|
|
|
125
|
0
|
|
|
|
|
0
|
push @$curr_open, $para; |
126
|
0
|
|
0
|
|
|
0
|
$self->{'content_seen'} ||= 1; |
127
|
|
|
|
|
|
|
|
128
|
0
|
|
|
|
|
0
|
$self->_handle_element_start( $target, $para->[1] ); |
129
|
|
|
|
|
|
|
|
130
|
0
|
|
|
|
|
0
|
return 1; |
131
|
|
|
|
|
|
|
} |
132
|
|
|
|
|
|
|
|
133
|
0
|
0
|
|
0
|
0
|
0
|
sub begin_for ( $self, $attributes={} ) { |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
134
|
0
|
|
|
|
|
0
|
my $target = $attributes->{target}; |
135
|
0
|
|
|
|
|
0
|
my $method = 'start_' . $target; |
136
|
|
|
|
|
|
|
|
137
|
0
|
0
|
|
|
|
0
|
if( $self->can( $method ) ) { |
138
|
0
|
|
|
|
|
0
|
$self->$method(); |
139
|
|
|
|
|
|
|
} |
140
|
|
|
|
|
|
|
else { |
141
|
0
|
0
|
|
|
|
0
|
DEBUG > 1 and print "No method $method"; |
142
|
|
|
|
|
|
|
} |
143
|
|
|
|
|
|
|
} |
144
|
|
|
|
|
|
|
|
145
|
0
|
0
|
|
0
|
0
|
0
|
sub end_for ( $self, $attributes={} ) { |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
146
|
0
|
|
|
|
|
0
|
my $target = $attributes->{target}; |
147
|
0
|
|
|
|
|
0
|
my $method = 'end_' . $target; |
148
|
|
|
|
|
|
|
|
149
|
0
|
0
|
|
|
|
0
|
if( $self->can( $method ) ) { |
150
|
0
|
|
|
|
|
0
|
$self->$method(); |
151
|
|
|
|
|
|
|
} |
152
|
|
|
|
|
|
|
else { |
153
|
0
|
0
|
|
|
|
0
|
DEBUG > 1 and print "No method $method"; |
154
|
|
|
|
|
|
|
} |
155
|
|
|
|
|
|
|
} |
156
|
|
|
|
|
|
|
|
157
|
1
|
50
|
|
1
|
0
|
2
|
sub add_to_pad ( $self, $stuff ) { |
|
1
|
50
|
|
|
|
1
|
|
|
1
|
|
|
|
|
1
|
|
|
1
|
|
|
|
|
1
|
|
|
1
|
|
|
|
|
1
|
|
158
|
1
|
|
|
|
|
2
|
my $pad = $self->get_pad; |
159
|
0
|
|
|
|
|
0
|
$self->{$pad} .= $stuff; |
160
|
|
|
|
|
|
|
} |
161
|
|
|
|
|
|
|
|
162
|
0
|
0
|
|
0
|
0
|
0
|
sub clear_pad ( $self ) { |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
163
|
0
|
|
|
|
|
0
|
my $pad = $self->get_pad; |
164
|
0
|
|
|
|
|
0
|
$self->{$pad} = ''; |
165
|
|
|
|
|
|
|
} |
166
|
|
|
|
|
|
|
|
167
|
0
|
0
|
|
0
|
0
|
0
|
sub set_title ( $self, $title ) { $self->{title} = $title } |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
168
|
|
|
|
|
|
|
|
169
|
0
|
0
|
|
0
|
0
|
0
|
sub title ( $self ) { $self->{title} } |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
170
|
|
|
|
|
|
|
|
171
|
|
|
|
|
|
|
=item document_header |
172
|
|
|
|
|
|
|
|
173
|
|
|
|
|
|
|
The empty string. We don't worry about that here. The blogging |
174
|
|
|
|
|
|
|
platform adds that. |
175
|
|
|
|
|
|
|
|
176
|
|
|
|
|
|
|
=cut |
177
|
|
|
|
|
|
|
|
178
|
1
|
50
|
|
1
|
1
|
5
|
sub document_header ( $self ) { '' } |
|
1
|
50
|
|
|
|
2
|
|
|
1
|
|
|
|
|
1
|
|
|
1
|
|
|
|
|
1
|
|
|
1
|
|
|
|
|
2
|
|
179
|
|
|
|
|
|
|
|
180
|
|
|
|
|
|
|
=item document_footer |
181
|
|
|
|
|
|
|
|
182
|
|
|
|
|
|
|
The empty string. We don't worry about that here. The blogging |
183
|
|
|
|
|
|
|
platform adds that. |
184
|
|
|
|
|
|
|
|
185
|
|
|
|
|
|
|
=cut |
186
|
|
|
|
|
|
|
|
187
|
0
|
0
|
|
0
|
1
|
0
|
sub document_footer ( $self ) { '' } |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
188
|
|
|
|
|
|
|
|
189
|
|
|
|
|
|
|
=back |
190
|
|
|
|
|
|
|
|
191
|
|
|
|
|
|
|
=head2 The Pod::Simple mechanics |
192
|
|
|
|
|
|
|
|
193
|
|
|
|
|
|
|
Everything else is the same stuff from C. |
194
|
|
|
|
|
|
|
|
195
|
|
|
|
|
|
|
=over 4 |
196
|
|
|
|
|
|
|
|
197
|
|
|
|
|
|
|
=cut |
198
|
|
|
|
|
|
|
|
199
|
2
|
50
|
|
2
|
1
|
1003
|
sub new ( $class ) { |
|
2
|
50
|
|
|
|
5
|
|
|
2
|
|
|
|
|
4
|
|
|
2
|
|
|
|
|
2
|
|
200
|
2
|
|
|
|
|
15
|
my $self = $class->SUPER::new(); |
201
|
2
|
|
|
|
|
97
|
$self->accept_codes( qw( K ) ); |
202
|
2
|
|
|
|
|
38
|
$self->accept_targets( qw(code terminal output figure) ); |
203
|
2
|
|
|
|
|
54
|
$self->accept_directive_as_verbatim( qw(code terminal output) ); |
204
|
2
|
|
|
|
|
69
|
$self; |
205
|
|
|
|
|
|
|
} |
206
|
|
|
|
|
|
|
|
207
|
0
|
0
|
|
0
|
0
|
0
|
sub emit ( $self, $attributes={} ) { |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
208
|
|
|
|
|
|
|
|
209
|
0
|
0
|
|
|
|
0
|
if (defined $self->{'output_fh'}) |
210
|
|
|
|
|
|
|
{ |
211
|
0
|
|
|
|
|
0
|
print {$self->{'output_fh'}} $self->get_from_current_pad; |
|
0
|
|
|
|
|
0
|
|
212
|
|
|
|
|
|
|
} |
213
|
|
|
|
|
|
|
else |
214
|
|
|
|
|
|
|
{ |
215
|
0
|
|
|
|
|
0
|
print $self->get_from_current_pad; |
216
|
|
|
|
|
|
|
} |
217
|
0
|
|
|
|
|
0
|
$self->clear_pad; |
218
|
0
|
|
|
|
|
0
|
return; |
219
|
|
|
|
|
|
|
} |
220
|
|
|
|
|
|
|
|
221
|
1
|
50
|
|
1
|
0
|
2
|
sub get_pad ( $self, $attributes={} ) { |
|
1
|
50
|
|
|
|
4
|
|
|
1
|
50
|
|
|
|
1
|
|
|
1
|
|
|
|
|
1
|
|
|
1
|
|
|
|
|
1
|
|
222
|
1
|
|
|
|
|
2
|
$self->not_implemented; |
223
|
|
|
|
|
|
|
} |
224
|
|
|
|
|
|
|
|
225
|
0
|
0
|
|
0
|
0
|
0
|
sub get_from_current_pad ( $self ) { |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
226
|
0
|
|
|
|
|
0
|
my $pad = $self->get_pad; |
227
|
0
|
|
|
|
|
0
|
$self->{$pad}; |
228
|
|
|
|
|
|
|
} |
229
|
|
|
|
|
|
|
|
230
|
0
|
0
|
|
0
|
0
|
0
|
sub add_to_current_pad ( $self, $text ) { |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
231
|
0
|
|
|
|
|
0
|
my $pad = $self->get_pad; |
232
|
0
|
|
|
|
|
0
|
$self->{$pad} .= $text; |
233
|
|
|
|
|
|
|
} |
234
|
|
|
|
|
|
|
|
235
|
1
|
50
|
|
1
|
0
|
11
|
sub start_Document ( $self, $attributes={} ) { |
|
1
|
50
|
|
|
|
2
|
|
|
1
|
50
|
|
|
|
1
|
|
|
1
|
|
|
|
|
2
|
|
|
1
|
|
|
|
|
1
|
|
236
|
1
|
|
|
|
|
2
|
$self->{in_section} = []; |
237
|
1
|
|
|
|
|
3
|
$self->add_to_pad( $self->document_header ); |
238
|
0
|
|
|
|
|
0
|
$self->emit; |
239
|
|
|
|
|
|
|
} |
240
|
|
|
|
|
|
|
|
241
|
0
|
0
|
|
0
|
0
|
0
|
sub end_Document ( $self, $attributes={} ) { |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
242
|
0
|
|
|
|
|
0
|
$self->add_to_pad( $self->document_footer ); |
243
|
0
|
|
|
|
|
0
|
$self->emit; |
244
|
|
|
|
|
|
|
} |
245
|
|
|
|
|
|
|
|
246
|
0
|
0
|
|
0
|
0
|
0
|
sub start_head0 ( $self, $attributes={} ) { $self->_header_start( 0 ); } |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
247
|
0
|
0
|
|
0
|
0
|
0
|
sub end_head0 ( $self, $attributes={} ) { $self->_header_end( 0 ); } |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
248
|
|
|
|
|
|
|
|
249
|
0
|
0
|
|
0
|
0
|
0
|
sub end_head1 ( $self, $attributes={} ) { $self->_header_end( 1 ); } |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
250
|
0
|
0
|
|
0
|
0
|
0
|
sub start_head1 ( $self, $attributes={} ) { $self->_header_start( 1 ); } |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
251
|
|
|
|
|
|
|
|
252
|
0
|
0
|
|
0
|
0
|
0
|
sub end_head2 ( $self, $attributes={} ) { $self->_header_end( 2 ); } |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
253
|
0
|
0
|
|
0
|
0
|
0
|
sub start_head2 ( $self, $attributes={} ) { $self->_header_start( 2 ); } |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
254
|
|
|
|
|
|
|
|
255
|
0
|
0
|
|
0
|
0
|
0
|
sub start_head3 ( $self, $attributes={} ) { $self->_header_start( 3 ); } |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
256
|
0
|
0
|
|
0
|
0
|
0
|
sub end_head3 ( $self, $attributes={} ) { $self->_header_end( 3 ); } |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
257
|
|
|
|
|
|
|
|
258
|
|
|
|
|
|
|
=item * start_output |
259
|
|
|
|
|
|
|
|
260
|
|
|
|
|
|
|
=item * end_output |
261
|
|
|
|
|
|
|
|
262
|
|
|
|
|
|
|
These methods simple set flags and defer everything else to the |
263
|
|
|
|
|
|
|
verbatim handler. |
264
|
|
|
|
|
|
|
|
265
|
|
|
|
|
|
|
=cut |
266
|
|
|
|
|
|
|
|
267
|
0
|
0
|
|
0
|
1
|
0
|
sub start_output ( $self, $attributes={} ) { |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
268
|
0
|
|
|
|
|
0
|
$self->{'in_output'} = 1; |
269
|
|
|
|
|
|
|
} |
270
|
|
|
|
|
|
|
|
271
|
0
|
0
|
|
0
|
1
|
0
|
sub end_output ( $self, $attributes={} ) { |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
272
|
0
|
|
|
|
|
0
|
$self->{'in_output'} = 0; |
273
|
|
|
|
|
|
|
} |
274
|
|
|
|
|
|
|
|
275
|
0
|
0
|
|
0
|
|
0
|
sub _get_initial_item_type ( $self, $attributes={} ) { |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
276
|
0
|
|
|
|
|
0
|
my $type = $self->SUPER::_get_initial_item_type; |
277
|
|
|
|
|
|
|
|
278
|
0
|
|
|
|
|
0
|
$type; |
279
|
|
|
|
|
|
|
} |
280
|
|
|
|
|
|
|
|
281
|
|
|
|
|
|
|
|
282
|
1
|
50
|
|
1
|
0
|
2
|
sub not_implemented ( $self, $attributes={} ) { croak "Not implemented! " . (caller(1))[3] } |
|
1
|
50
|
|
|
|
2
|
|
|
1
|
50
|
|
|
|
2
|
|
|
1
|
|
|
|
|
1
|
|
|
1
|
|
|
|
|
1
|
|
|
1
|
|
|
|
|
210
|
|
283
|
|
|
|
|
|
|
|
284
|
0
|
0
|
|
0
|
0
|
0
|
sub in_item_list ( $self, $attributes={} ) { scalar @{ $self->{list_levels} } } |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
285
|
0
|
0
|
|
0
|
0
|
0
|
sub add_list_level_item ( $self, $attributes={} ) { |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
286
|
0
|
|
|
|
|
0
|
${ $self->{list_levels} }[-1]{item_count}++; |
|
0
|
|
|
|
|
0
|
|
287
|
|
|
|
|
|
|
} |
288
|
0
|
0
|
|
0
|
0
|
0
|
sub is_first_list_level_item ( $self, $attributes={} ) { |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
289
|
0
|
|
|
|
|
0
|
${ $self->{list_levels} }[-1]{item_count} == 0; |
|
0
|
|
|
|
|
0
|
|
290
|
|
|
|
|
|
|
} |
291
|
|
|
|
|
|
|
|
292
|
0
|
0
|
|
0
|
0
|
0
|
sub start_list_level ( $self, $attributes={} ) { |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
293
|
0
|
|
|
|
|
0
|
push @{ $self->{list_levels} }, { item_count => 0 }; |
|
0
|
|
|
|
|
0
|
|
294
|
|
|
|
|
|
|
} |
295
|
|
|
|
|
|
|
|
296
|
0
|
0
|
|
0
|
0
|
0
|
sub end_list_level ( $self, $attributes={} ) { |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
297
|
0
|
|
|
|
|
0
|
pop @{ $self->{list_levels} }; |
|
0
|
|
|
|
|
0
|
|
298
|
|
|
|
|
|
|
} |
299
|
|
|
|
|
|
|
|
300
|
0
|
0
|
|
0
|
0
|
0
|
sub dont_escape ( $self ) { |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
301
|
0
|
0
|
|
|
|
0
|
$self->{in_verbatim} || $self->{in_C} |
302
|
|
|
|
|
|
|
} |
303
|
|
|
|
|
|
|
|
304
|
0
|
0
|
|
0
|
0
|
0
|
sub escape_text ( $self, $text_ref ) { |
|
0
|
0
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
|
0
|
|
|
|
|
0
|
|
305
|
0
|
|
|
|
|
0
|
$$text_ref =~ s/&/&/g; |
306
|
0
|
|
|
|
|
0
|
$$text_ref =~ s/</g; |
307
|
|
|
|
|
|
|
|
308
|
0
|
|
|
|
|
0
|
return 1; |
309
|
|
|
|
|
|
|
} |
310
|
|
|
|
|
|
|
|
311
|
|
|
|
|
|
|
|
312
|
|
|
|
|
|
|
BEGIN { |
313
|
3
|
|
|
3
|
|
763
|
require Pod::Simple::BlackBox; |
314
|
|
|
|
|
|
|
|
315
|
|
|
|
|
|
|
package Pod::Simple::BlackBox; |
316
|
|
|
|
|
|
|
|
317
|
0
|
0
|
|
0
|
|
|
sub _ponder_Verbatim ( $self, $para ) { |
|
0
|
0
|
|
|
|
|
|
|
0
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
|
318
|
0
|
|
|
|
|
|
DEBUG and print STDERR " giving verbatim treatment...\n"; |
319
|
|
|
|
|
|
|
|
320
|
0
|
|
|
|
|
|
$para->[1]{'xml:space'} = 'preserve'; |
321
|
0
|
|
|
|
|
|
foreach my $line ( @$para[ 2 .. $#$para ] ) { |
322
|
0
|
|
|
|
|
|
$line =~ s/\A(\t| )//gm; |
323
|
0
|
|
|
|
|
|
$line =~ s/\A(\t+)/" " x ( 4 * length($1) )/e; |
|
0
|
|
|
|
|
|
|
324
|
0
|
0
|
|
|
|
|
warn |
325
|
|
|
|
|
|
|
sprintf( |
326
|
|
|
|
|
|
|
"%s: tab in code listing! [%s]", |
327
|
|
|
|
|
|
|
$self->chapter, |
328
|
|
|
|
|
|
|
$line |
329
|
|
|
|
|
|
|
) if $line =~ /\t/; |
330
|
|
|
|
|
|
|
} |
331
|
|
|
|
|
|
|
|
332
|
|
|
|
|
|
|
# Now the VerbatimFormatted hoodoo... |
333
|
0
|
0
|
0
|
|
|
|
if( $self->{'accept_codes'} and |
|
|
0
|
|
|
|
|
|
334
|
|
|
|
|
|
|
$self->{'accept_codes'}{'VerbatimFormatted'} |
335
|
|
|
|
|
|
|
) { |
336
|
0
|
|
0
|
|
|
|
while(@$para > 3 and $para->[-1] !~ m/\S/) { pop @$para } |
|
0
|
|
|
|
|
|
|
337
|
|
|
|
|
|
|
# Kill any number of terminal newlines |
338
|
0
|
|
|
|
|
|
$self->_verbatim_format($para); |
339
|
|
|
|
|
|
|
} elsif ($self->{'codes_in_verbatim'}) { |
340
|
0
|
|
|
|
|
|
push @$para, |
341
|
0
|
|
|
|
|
|
@{$self->_make_treelet( |
342
|
|
|
|
|
|
|
join("\n", splice(@$para, 2)), |
343
|
|
|
|
|
|
|
$para->[1]{'start_line'}, $para->[1]{'xml:space'} |
344
|
|
|
|
|
|
|
)}; |
345
|
0
|
|
|
|
|
|
$para->[-1] =~ s/\n+$//s; # Kill any number of terminal newlines |
346
|
|
|
|
|
|
|
} else { |
347
|
0
|
0
|
|
|
|
|
push @$para, join "\n", splice(@$para, 2) if @$para > 3; |
348
|
0
|
|
|
|
|
|
$para->[-1] =~ s/\n+$//s; # Kill any number of terminal newlines |
349
|
|
|
|
|
|
|
} |
350
|
0
|
|
|
|
|
|
return; |
351
|
|
|
|
|
|
|
} |
352
|
|
|
|
|
|
|
|
353
|
|
|
|
|
|
|
} |
354
|
|
|
|
|
|
|
|
355
|
3
|
|
|
3
|
|
3431
|
BEGIN { |
356
|
|
|
|
|
|
|
|
357
|
|
|
|
|
|
|
# override _treat_Es so I can localize e2char |
358
|
|
|
|
|
|
|
sub _treat_Es { |
359
|
0
|
|
|
0
|
|
0
|
my $self = shift; |
360
|
|
|
|
|
|
|
|
361
|
0
|
|
|
|
|
0
|
require Pod::Escapes; |
362
|
0
|
|
|
|
|
0
|
local *Pod::Escapes::e2char = *e2char_tagged_text; |
363
|
|
|
|
|
|
|
|
364
|
0
|
|
|
|
|
0
|
$self->SUPER::_treat_Es( @_ ); |
365
|
|
|
|
|
|
|
} |
366
|
|
|
|
|
|
|
|
367
|
|
|
|
|
|
|
sub e2char_tagged_text { |
368
|
|
|
|
|
|
|
package Pod::Escapes; |
369
|
|
|
|
|
|
|
|
370
|
0
|
|
|
0
|
0
|
0
|
my $in = shift; |
371
|
|
|
|
|
|
|
|
372
|
0
|
0
|
0
|
|
|
0
|
return unless defined $in and length $in; |
373
|
|
|
|
|
|
|
|
374
|
0
|
0
|
|
|
|
0
|
if( $in =~ m/^(0[0-7]*)$/ ) { $in = oct $in; } |
|
0
|
0
|
|
|
|
0
|
|
375
|
0
|
|
|
|
|
0
|
elsif( $in =~ m/^0?x([0-9a-fA-F]+)$/ ) { $in = hex $1; } |
376
|
|
|
|
|
|
|
|
377
|
0
|
0
|
|
|
|
0
|
if( $NOT_ASCII ) { |
378
|
0
|
0
|
|
|
|
0
|
unless( $in =~ m/^\d+$/ ) |
379
|
|
|
|
|
|
|
{ |
380
|
0
|
|
|
|
|
0
|
$in = $Name2character{$in}; |
381
|
0
|
0
|
|
|
|
0
|
return unless defined $in; |
382
|
0
|
|
|
|
|
0
|
$in = ord $in; |
383
|
|
|
|
|
|
|
} |
384
|
|
|
|
|
|
|
|
385
|
0
|
|
0
|
|
|
0
|
return $Code2USASCII{$in} |
386
|
|
|
|
|
|
|
|| $Latin1Code_to_fallback{$in} |
387
|
|
|
|
|
|
|
|| $FAR_CHAR; |
388
|
|
|
|
|
|
|
} |
389
|
|
|
|
|
|
|
|
390
|
0
|
0
|
0
|
|
|
0
|
if( defined $Name2character_number{$in} and $Name2character_number{$in} < 127 ) { |
|
|
0
|
|
|
|
|
|
391
|
0
|
|
|
|
|
0
|
return "&$in;"; |
392
|
|
|
|
|
|
|
} |
393
|
|
|
|
|
|
|
elsif( defined $Name2character_number{$in} ) { |
394
|
|
|
|
|
|
|
# this needs to be fixed width because I want to look for |
395
|
|
|
|
|
|
|
# it in a negative lookbehind |
396
|
0
|
|
|
|
|
0
|
return sprintf '%04x;', $Name2character_number{$in}; |
397
|
|
|
|
|
|
|
} |
398
|
|
|
|
|
|
|
else |
399
|
|
|
|
|
|
|
{ |
400
|
0
|
|
|
|
|
0
|
return '???'; |
401
|
|
|
|
|
|
|
} |
402
|
|
|
|
|
|
|
|
403
|
|
|
|
|
|
|
} |
404
|
|
|
|
|
|
|
} |
405
|
|
|
|
|
|
|
|
406
|
|
|
|
|
|
|
=back |
407
|
|
|
|
|
|
|
|
408
|
|
|
|
|
|
|
=head1 TO DO |
409
|
|
|
|
|
|
|
|
410
|
|
|
|
|
|
|
|
411
|
|
|
|
|
|
|
=head1 SEE ALSO |
412
|
|
|
|
|
|
|
|
413
|
|
|
|
|
|
|
L, L |
414
|
|
|
|
|
|
|
|
415
|
|
|
|
|
|
|
=head1 SOURCE AVAILABILITY |
416
|
|
|
|
|
|
|
|
417
|
|
|
|
|
|
|
This source is in Github: |
418
|
|
|
|
|
|
|
|
419
|
|
|
|
|
|
|
http://github.com/briandfoy/pod-pseudopod-perltricks |
420
|
|
|
|
|
|
|
|
421
|
|
|
|
|
|
|
If, for some reason, I disappear from the world, one of the other |
422
|
|
|
|
|
|
|
members of the project can shepherd this module appropriately. |
423
|
|
|
|
|
|
|
|
424
|
|
|
|
|
|
|
=head1 AUTHOR |
425
|
|
|
|
|
|
|
|
426
|
|
|
|
|
|
|
brian d foy, C<< >> |
427
|
|
|
|
|
|
|
|
428
|
|
|
|
|
|
|
=head1 COPYRIGHT AND LICENSE |
429
|
|
|
|
|
|
|
|
430
|
|
|
|
|
|
|
Copyright © 2014-2015, brian d foy . All rights reserved. |
431
|
|
|
|
|
|
|
|
432
|
|
|
|
|
|
|
You may redistribute this under the same terms as Perl itself. |
433
|
|
|
|
|
|
|
|
434
|
|
|
|
|
|
|
=cut |
435
|
|
|
|
|
|
|
|
436
|
2
|
50
|
|
2
|
|
267
|
sub _ponder_paragraph_buffer ( $self ) { |
|
2
|
50
|
|
|
|
3
|
|
|
2
|
|
|
|
|
2
|
|
|
2
|
|
|
|
|
1
|
|
437
|
|
|
|
|
|
|
|
438
|
|
|
|
|
|
|
# Para-token types as found in the buffer. |
439
|
|
|
|
|
|
|
# ~Verbatim, ~Para, ~end, =head1..4, =for, =begin, =end, |
440
|
|
|
|
|
|
|
# =over, =back, =item |
441
|
|
|
|
|
|
|
# and the null =pod (to be complained about if over one line) |
442
|
|
|
|
|
|
|
# |
443
|
|
|
|
|
|
|
# "~data" paragraphs are something we generate at this level, depending on |
444
|
|
|
|
|
|
|
# a currently open =over region |
445
|
|
|
|
|
|
|
|
446
|
|
|
|
|
|
|
# Events fired: Begin and end for: |
447
|
|
|
|
|
|
|
# directivename (like head1 .. head4), item, extend, |
448
|
|
|
|
|
|
|
# for (from =begin...=end, =for), |
449
|
|
|
|
|
|
|
# over-bullet, over-number, over-text, over-block, |
450
|
|
|
|
|
|
|
# item-bullet, item-number, item-text, |
451
|
|
|
|
|
|
|
# Document, |
452
|
|
|
|
|
|
|
# Data, Para, Verbatim |
453
|
|
|
|
|
|
|
# B, C, longdirname (TODO -- wha?), etc. for all directives |
454
|
|
|
|
|
|
|
# |
455
|
|
|
|
|
|
|
|
456
|
2
|
|
|
|
|
1
|
my $paras; |
457
|
2
|
100
|
|
|
|
2
|
return unless @{$paras = $self->{'paras'}}; |
|
2
|
|
|
|
|
5
|
|
458
|
1
|
|
50
|
|
|
5
|
my $curr_open = ($self->{'curr_open'} ||= []); |
459
|
|
|
|
|
|
|
|
460
|
1
|
50
|
|
|
|
2
|
DEBUG > 10 and print "# Paragraph buffer: <<", Pod::Simple::BlackBox::pretty($paras), ">>\n"; |
461
|
|
|
|
|
|
|
|
462
|
|
|
|
|
|
|
# We have something in our buffer. So apparently the document has started. |
463
|
1
|
50
|
|
|
|
2
|
unless($self->{'doc_has_started'}) { |
464
|
1
|
|
|
|
|
2
|
$self->{'doc_has_started'} = 1; |
465
|
|
|
|
|
|
|
|
466
|
1
|
|
|
|
|
1
|
my $starting_contentless; |
467
|
1
|
|
33
|
|
|
7
|
$starting_contentless = |
468
|
|
|
|
|
|
|
( |
469
|
|
|
|
|
|
|
!@$curr_open |
470
|
|
|
|
|
|
|
and @$paras and ! grep $_->[0] ne '~end', @$paras |
471
|
|
|
|
|
|
|
# i.e., if the paras is all ~ends |
472
|
|
|
|
|
|
|
) |
473
|
|
|
|
|
|
|
; |
474
|
1
|
0
|
|
|
|
2
|
DEBUG and print "# Starting ", |
|
|
50
|
|
|
|
|
|
475
|
|
|
|
|
|
|
$starting_contentless ? 'contentless' : 'contentful', |
476
|
|
|
|
|
|
|
" document\n" |
477
|
|
|
|
|
|
|
; |
478
|
|
|
|
|
|
|
|
479
|
1
|
50
|
|
|
|
7
|
$self->_handle_element_start('Document', |
480
|
|
|
|
|
|
|
{ |
481
|
|
|
|
|
|
|
'start_line' => $paras->[0][1]{'start_line'}, |
482
|
|
|
|
|
|
|
$starting_contentless ? ( 'contentless' => 1 ) : (), |
483
|
|
|
|
|
|
|
}, |
484
|
|
|
|
|
|
|
); |
485
|
|
|
|
|
|
|
} |
486
|
|
|
|
|
|
|
|
487
|
0
|
|
|
|
|
|
my($para, $para_type); |
488
|
0
|
|
|
|
|
|
while(@$paras) { |
489
|
0
|
0
|
0
|
|
|
|
last if @$paras == 1 and |
|
|
|
0
|
|
|
|
|
490
|
|
|
|
|
|
|
( $paras->[0][0] eq '=over' or $paras->[0][0] eq '~Verbatim' |
491
|
|
|
|
|
|
|
or $paras->[0][0] eq '=item' ) |
492
|
|
|
|
|
|
|
; |
493
|
|
|
|
|
|
|
# Those're the three kinds of paragraphs that require lookahead. |
494
|
|
|
|
|
|
|
# Actually, an "=item Foo" inside an region |
495
|
|
|
|
|
|
|
# and any =item inside an region (rare) |
496
|
|
|
|
|
|
|
# don't require any lookahead, but all others (bullets |
497
|
|
|
|
|
|
|
# and numbers) do. |
498
|
|
|
|
|
|
|
|
499
|
|
|
|
|
|
|
# TODO: winge about many kinds of directives in non-resolving =for regions? |
500
|
|
|
|
|
|
|
# TODO: many? like what? =head1 etc? |
501
|
|
|
|
|
|
|
|
502
|
0
|
|
|
|
|
|
$para = shift @$paras; |
503
|
0
|
|
|
|
|
|
$para_type = $para->[0]; |
504
|
|
|
|
|
|
|
|
505
|
0
|
0
|
|
|
|
|
DEBUG > 1 and print "Pondering a $para_type paragraph, given the stack: (", |
506
|
|
|
|
|
|
|
$self->_dump_curr_open(), ")\n"; |
507
|
|
|
|
|
|
|
|
508
|
0
|
0
|
|
|
|
|
if($para_type eq '=for') { |
|
|
0
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
509
|
0
|
0
|
|
|
|
|
next if $self->_ponder_for($para,$curr_open,$paras); |
510
|
|
|
|
|
|
|
} elsif($para_type eq '=begin') { |
511
|
0
|
0
|
|
|
|
|
next if $self->_ponder_begin($para,$curr_open,$paras); |
512
|
|
|
|
|
|
|
} elsif($para_type eq '=end') { |
513
|
0
|
0
|
|
|
|
|
next if $self->_ponder_end($para,$curr_open,$paras); |
514
|
|
|
|
|
|
|
} elsif($para_type eq '~end') { # The virtual end-document signal |
515
|
0
|
0
|
|
|
|
|
next if $self->_ponder_doc_end($para,$curr_open,$paras); |
516
|
|
|
|
|
|
|
} |
517
|
|
|
|
|
|
|
|
518
|
|
|
|
|
|
|
|
519
|
|
|
|
|
|
|
# ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ |
520
|
|
|
|
|
|
|
#~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ |
521
|
0
|
0
|
|
|
|
|
if(grep $_->[1]{'~ignore'}, @$curr_open) { |
522
|
0
|
0
|
|
|
|
|
DEBUG > 1 and |
523
|
|
|
|
|
|
|
print "Skipping $para_type paragraph because in ignore mode.\n"; |
524
|
0
|
|
|
|
|
|
next; |
525
|
|
|
|
|
|
|
} |
526
|
|
|
|
|
|
|
#~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ |
527
|
|
|
|
|
|
|
# ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ |
528
|
|
|
|
|
|
|
|
529
|
0
|
0
|
|
|
|
|
if($para_type eq '=pod') { |
|
|
0
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
530
|
0
|
|
|
|
|
|
$self->_ponder_pod($para,$curr_open,$paras); |
531
|
|
|
|
|
|
|
} elsif($para_type eq '=over') { |
532
|
0
|
0
|
|
|
|
|
next if $self->_ponder_over($para,$curr_open,$paras); |
533
|
|
|
|
|
|
|
} elsif($para_type eq '=back') { |
534
|
0
|
0
|
|
|
|
|
next if $self->_ponder_back($para,$curr_open,$paras); |
535
|
|
|
|
|
|
|
} elsif($para_type eq '=row') { |
536
|
0
|
0
|
|
|
|
|
next if $self->_ponder_row_start($para,$curr_open,$paras); |
537
|
|
|
|
|
|
|
|
538
|
|
|
|
|
|
|
} elsif( $para_type eq '=headrow'){ |
539
|
0
|
|
|
|
|
|
$self->start_headrow; |
540
|
|
|
|
|
|
|
} elsif( $para_type eq '=bodyrows') { |
541
|
0
|
|
|
|
|
|
$self->start_bodyrows; |
542
|
|
|
|
|
|
|
} |
543
|
|
|
|
|
|
|
|
544
|
|
|
|
|
|
|
else { |
545
|
|
|
|
|
|
|
# All non-magical codes!!! |
546
|
|
|
|
|
|
|
|
547
|
|
|
|
|
|
|
# Here we start using $para_type for our own twisted purposes, to |
548
|
|
|
|
|
|
|
# mean how it should get treated, not as what the element name |
549
|
|
|
|
|
|
|
# should be. |
550
|
|
|
|
|
|
|
|
551
|
0
|
0
|
|
|
|
|
DEBUG > 1 and print "Pondering non-magical $para_type\n"; |
552
|
|
|
|
|
|
|
|
553
|
|
|
|
|
|
|
# In tables, the start of a headrow or bodyrow also terminates an |
554
|
|
|
|
|
|
|
# existing open row. |
555
|
0
|
0
|
0
|
|
|
|
if($para_type eq '=headrow' || $para_type eq '=bodyrows') { |
556
|
0
|
|
|
|
|
|
$self->_ponder_row_end($para,$curr_open,$paras); |
557
|
|
|
|
|
|
|
} |
558
|
|
|
|
|
|
|
|
559
|
|
|
|
|
|
|
# Enforce some =headN discipline |
560
|
0
|
0
|
0
|
|
|
|
if($para_type =~ m/^=head\d$/s |
|
|
|
0
|
|
|
|
|
|
|
|
0
|
|
|
|
|
561
|
|
|
|
|
|
|
and ! $self->{'accept_heads_anywhere'} |
562
|
|
|
|
|
|
|
and @$curr_open |
563
|
|
|
|
|
|
|
and $curr_open->[-1][0] eq '=over' |
564
|
|
|
|
|
|
|
) { |
565
|
0
|
0
|
|
|
|
|
DEBUG > 2 and print "'=$para_type' inside an '=over'!\n"; |
566
|
0
|
|
|
|
|
|
$self->whine( |
567
|
|
|
|
|
|
|
$para->[1]{'start_line'}, |
568
|
|
|
|
|
|
|
"You forgot a '=back' before '$para_type'" |
569
|
|
|
|
|
|
|
); |
570
|
0
|
|
|
|
|
|
unshift @$paras, ['=back', {}, ''], $para; # close the =over |
571
|
0
|
|
|
|
|
|
next; |
572
|
|
|
|
|
|
|
} |
573
|
|
|
|
|
|
|
|
574
|
|
|
|
|
|
|
|
575
|
0
|
0
|
0
|
|
|
|
if($para_type eq '=item') { |
|
|
0
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
576
|
0
|
0
|
|
|
|
|
next if $self->_ponder_item($para,$curr_open,$paras); |
577
|
0
|
|
|
|
|
|
$para_type = 'Plain'; |
578
|
|
|
|
|
|
|
# Now fall thru and process it. |
579
|
|
|
|
|
|
|
|
580
|
|
|
|
|
|
|
} elsif($para_type eq '=extend') { |
581
|
|
|
|
|
|
|
# Well, might as well implement it here. |
582
|
0
|
|
|
|
|
|
$self->_ponder_extend($para); |
583
|
0
|
|
|
|
|
|
next; # and skip |
584
|
|
|
|
|
|
|
} elsif($para_type eq '=encoding') { |
585
|
|
|
|
|
|
|
# Not actually acted on here, but we catch errors here. |
586
|
0
|
|
|
|
|
|
$self->_handle_encoding_second_level($para); |
587
|
|
|
|
|
|
|
|
588
|
0
|
|
|
|
|
|
next; # and skip |
589
|
|
|
|
|
|
|
} elsif($para_type eq '~Verbatim') { |
590
|
0
|
|
|
|
|
|
$para->[0] = 'Verbatim'; |
591
|
0
|
|
|
|
|
|
$para_type = '?Verbatim'; |
592
|
|
|
|
|
|
|
} elsif($para_type eq '~Para') { |
593
|
0
|
|
|
|
|
|
$para->[0] = 'Para'; |
594
|
0
|
|
|
|
|
|
$para_type = '?Plain'; |
595
|
|
|
|
|
|
|
} elsif($para_type eq 'Data') { |
596
|
0
|
|
|
|
|
|
$para->[0] = 'Data'; |
597
|
0
|
|
|
|
|
|
$para_type = '?Data'; |
598
|
|
|
|
|
|
|
} elsif( $para_type =~ s/^=//s |
599
|
|
|
|
|
|
|
and defined( $para_type = $self->{'accept_directives'}{$para_type} ) |
600
|
|
|
|
|
|
|
) { |
601
|
0
|
0
|
|
|
|
|
DEBUG > 1 and print " Pondering known directive ${$para}[0] as $para_type\n"; |
|
0
|
|
|
|
|
|
|
602
|
|
|
|
|
|
|
} else { |
603
|
|
|
|
|
|
|
# An unknown directive! |
604
|
0
|
|
|
|
|
|
DEBUG > 1 and printf "Unhandled directive %s (Handled: %s)\n", |
605
|
0
|
0
|
|
|
|
|
$para->[0], join(' ', sort keys %{$self->{'accept_directives'}} ) |
606
|
|
|
|
|
|
|
; |
607
|
0
|
|
|
|
|
|
$self->whine( |
608
|
|
|
|
|
|
|
$para->[1]{'start_line'}, |
609
|
|
|
|
|
|
|
"Unknown directive: $para->[0]" |
610
|
|
|
|
|
|
|
); |
611
|
|
|
|
|
|
|
|
612
|
|
|
|
|
|
|
# And maybe treat it as text instead of just letting it go? |
613
|
0
|
|
|
|
|
|
next; |
614
|
|
|
|
|
|
|
} |
615
|
|
|
|
|
|
|
|
616
|
0
|
0
|
|
|
|
|
DEBUG > 1 and print "para_type is $para_type\n"; |
617
|
0
|
0
|
|
|
|
|
if($para_type =~ s/^\?//s) { |
618
|
0
|
0
|
|
|
|
|
if(! @$curr_open) { # usual case |
619
|
0
|
0
|
|
|
|
|
DEBUG and print "Treating $para_type paragraph as such because stack is empty.\n"; |
620
|
|
|
|
|
|
|
} else { |
621
|
0
|
|
|
|
|
|
my @fors = grep $_->[0] eq '=for', @$curr_open; |
622
|
0
|
0
|
|
|
|
|
DEBUG > 1 and print "Containing fors: ", |
623
|
|
|
|
|
|
|
join(',', map $_->[1]{'target'}, @fors), "\n"; |
624
|
|
|
|
|
|
|
|
625
|
0
|
0
|
|
|
|
|
if(! @fors) { |
|
|
0
|
|
|
|
|
|
626
|
0
|
0
|
|
|
|
|
DEBUG and print "Treating $para_type paragraph as such because stack has no =for's\n"; |
627
|
|
|
|
|
|
|
|
628
|
|
|
|
|
|
|
#} elsif(grep $_->[1]{'~resolve'}, @fors) { |
629
|
|
|
|
|
|
|
#} elsif(not grep !$_->[1]{'~resolve'}, @fors) { |
630
|
|
|
|
|
|
|
} elsif( $fors[-1][1]{'~resolve'} ) { |
631
|
|
|
|
|
|
|
# Look to the immediately containing for |
632
|
0
|
0
|
|
|
|
|
DEBUG and print "~resolve is $fors[-1][1]{'~resolve'}\n"; |
633
|
|
|
|
|
|
|
|
634
|
0
|
0
|
|
|
|
|
if($para_type eq 'Data') { |
635
|
0
|
0
|
|
|
|
|
DEBUG and print "Treating Data paragraph as Plain/Verbatim because the containing =for ($fors[-1][1]{'target'}) is a resolver\n"; |
636
|
0
|
|
|
|
|
|
$para->[0] = 'Para'; |
637
|
0
|
|
|
|
|
|
$para_type = 'Plain'; |
638
|
|
|
|
|
|
|
} else { |
639
|
0
|
0
|
|
|
|
|
DEBUG and print "Treating $para_type paragraph as such because the containing =for ($fors[-1][1]{'target'}) is a resolver\n"; |
640
|
|
|
|
|
|
|
} |
641
|
|
|
|
|
|
|
} else { |
642
|
0
|
0
|
|
|
|
|
DEBUG and print "Treating $para_type paragraph as Data because the containing =for ($fors[-1][1]{'target'}) is a non-resolver\n"; |
643
|
0
|
|
|
|
|
|
$para->[0] = $para_type = 'Data'; |
644
|
|
|
|
|
|
|
} |
645
|
|
|
|
|
|
|
} |
646
|
|
|
|
|
|
|
} |
647
|
|
|
|
|
|
|
|
648
|
|
|
|
|
|
|
#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |
649
|
0
|
0
|
|
|
|
|
if($para_type eq 'Plain') { |
|
|
0
|
|
|
|
|
|
|
|
0
|
|
|
|
|
|
650
|
0
|
|
|
|
|
|
$self->_ponder_Plain($para); |
651
|
|
|
|
|
|
|
} elsif($para_type eq 'Verbatim') { |
652
|
0
|
|
|
|
|
|
$self->_ponder_Verbatim($para); |
653
|
|
|
|
|
|
|
} elsif($para_type eq 'Data') { |
654
|
0
|
|
|
|
|
|
$self->_ponder_Data($para); |
655
|
|
|
|
|
|
|
} else { |
656
|
0
|
|
|
|
|
|
die "\$para type is $para_type -- how did that happen?"; |
657
|
|
|
|
|
|
|
# Shouldn't happen. |
658
|
|
|
|
|
|
|
} |
659
|
|
|
|
|
|
|
|
660
|
|
|
|
|
|
|
#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |
661
|
0
|
|
|
|
|
|
$para->[0] =~ s/^[~=]//s; |
662
|
|
|
|
|
|
|
|
663
|
0
|
0
|
|
|
|
|
DEBUG and print "\n", Pod::Simple::BlackBox::pretty($para), "\n"; |
664
|
|
|
|
|
|
|
|
665
|
|
|
|
|
|
|
# traverse the treelet (which might well be just one string scalar) |
666
|
0
|
|
0
|
|
|
|
$self->{'content_seen'} ||= 1; |
667
|
0
|
|
|
|
|
|
$self->_traverse_treelet_bit(@$para); |
668
|
|
|
|
|
|
|
} |
669
|
|
|
|
|
|
|
} |
670
|
|
|
|
|
|
|
|
671
|
0
|
|
|
|
|
|
return; |
672
|
|
|
|
|
|
|
} |
673
|
|
|
|
|
|
|
|
674
|
|
|
|
|
|
|
1; |