NAME
XML::Grammar::FictionBase::FromProto::Parser::LineIterator - line iterator base class for the parser.
For internal use only.
SYNOPSIS
TODO: write one.
DESCRIPTION
This is a line iterator that is useful to handle text (e.g: out of a file) and process it incrementally.
METHODS
$self->setup_text($multi_line_text)
Use $multi_line_text as the text to process, populate the lines array with it and reset the other variables.
$line_ref = $self->curr_line_ref()
Returns a reference to the current line (a string).
For example:
my $l_ref = $self->curr_line_ref();
if ($$l_ref !~ m{\G<tag>}g)
{
die "Could not match tag.";
}
my $pos = $self->curr_pos()
Returns the current position (using pos($$l)) of the current line.
$self->at_line_start()
Returns if at start of line (curr_pos == 0).
my ($line_ref, $pos) = $self->curr_line_and_pos();
Convenience method to return the line reference and the position.
For example:
# Check for a tag.
my ($l_ref, $p) = $self->curr_line_and_pos();
my $is_tag_cond = ($$l_ref =~ m{\G<}cg);
my $is_close = $is_tag_cond && ($$l_ref =~ m{\G/}cg);
pos($$l) = $p;
return ($is_tag_cond, $is_close);
my $line_copy_ref = $self->curr_line_copy()
Returns a reference to a copy of the current line that is allowed to be tempered with (by assigning to pos() or in a different way.). The line is returned as a reference so to avoid destroying its pos() value.
For example:
sub _look_ahead_for_tag
{
my $self = shift;
my $l = $self->curr_line_copy();
my $is_tag_cond = ($$l =~ m{\G<}cg);
my $is_close = $is_tag_cond && ($$l =~ m{\G/}cg);
return ($is_tag_cond, $is_close);
}
my $line_ref = $self->next_line_ref()
Advance the line pointer and return the next line.
$self->skip_space()
Skip whitespace (spaces and tabs) from the current position onwards.
$self->skip_multiline_space()
Skip multiline space.
$self->curr_line_continues_with($regex)
Matches the current line with $regex starting from the current position and returns the result. The position remains at the original position if the regular expression does not match (using qr//cg
).
my $line_number = $self->line_idx()
Returns the line index as an integer. It starts from 0 for the first line (like in Perl lines.)
my $line_number = $self->line_num()
Returns the line number as an integer. It starts from 1 for the first line (like in file lines.)
$self->consume($regex)
Consume as much text as $regex matches.
$self->consume_up_to($regex)
Consume up to the point where $regex matches.
$self->throw_text_error($exception_class, $text)
Throws the Error class $exception_class with the text $text (and the current line number.
eof()
Returns if the parser reached the end of the file.
$self->meta()
Leftover from Moo.