package HTML::Tidy::Message;
use warnings;
use strict;
use overload
q{""} => \&as_string,
fallback => 'sounds like a good idea';
=head1 NAME
HTML::Tidy::Message - Message object for the Tidy functionality
=head1 SYNOPSIS
See L for all the gory details.
=head1 EXPORTS
None. It's all object-based.
=head1 METHODS
Almost everything is an accessor.
=head2 new( $file, $line, $column, $text )
Create an object. It's not very exciting.
=cut
sub new {
my $class = shift;
my $file = shift;
my $type = shift;
my $line = shift || 0;
my $column = shift || 0;
my $text = shift;
# Add an element that says what tag caused the error (B, TR, etc)
# so that we can match 'em up down the road.
my $self = {
_file => $file,
_type => $type,
_line => $line,
_column => $column,
_text => $text,
};
bless $self, $class;
return $self;
}
=head2 where()
Returns a formatted string that describes where in the file the
error has occurred.
For example,
(14:23)
for line 14, column 23.
The terrible thing about this function is that it's both a plain
ol' formatting function as in
my $str = where( 14, 23 );
AND it's an object method, as in:
my $str = $error->where();
I don't know what I was thinking when I set it up this way, but
it's bad practice.
=cut
sub where {
my $self = shift;
return '-' unless $self->line && $self->column;
return sprintf( '(%d:%d)', $self->line, $self->column );
}
=head2 as_string()
Returns a nicely-formatted string for printing out to stdout or some similar user thing.
=cut
sub as_string {
my $self = shift;
my %strings = (
1 => 'Warning',
2 => 'Error',
);
return sprintf( '%s %s %s: %s',
$self->file, $self->where, $strings{$self->type}, $self->text );
}
=head2 file()
Returns the filename of the error, as set by the caller.
=head2 type()
Returns the type of the error. This will either be C,
or C.
=head2 line()
Returns the line number of the error, or 0 if there isn't an applicable
line number.
=head2 column()
Returns the column number, or 0 if there isn't an applicable column
number.
=head2 text()
Returns the text of the message. This does not include a type string,
like "Info: ".
=cut
sub file { my $self = shift; return $self->{_file} }
sub type { my $self = shift; return $self->{_type} }
sub line { my $self = shift; return $self->{_line} }
sub column { my $self = shift; return $self->{_column} }
sub text { my $self = shift; return $self->{_text} }
=head1 LICENSE
This code may be distributed under the same terms as Perl itself.
Please note that these modules are not products of or supported by the
employers of the various contributors to the code.
=head1 AUTHOR
Andy Lester, C<< >>
=cut
1; # happy