The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
package HTML::Native::Attribute::ReadOnly;

# Copyright (C) 2011 Michael Brown <mbrown@fensystems.co.uk>.
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License as
# published by the Free Software Foundation; either version 2 of the
# License, or any later version.
#
# This program is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
# General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.

=head1 NAME

HTML::Native::Attribute::ReadOnly - A read-only HTML element attribute

=head1 SYNOPSIS

    use HTML::Native::Attribute::ReadOnly;

    my $attr =
	HTML::Native::Attribute::ReadOnly->new ( [ qw ( foo bar ) ] );
    print $attr;  # prints "foo bar"
    $attr->{foo} = 0;  # dies

=head1 DESCRIPTION

An L<HTML::Native::Attribute::ReadOnly> object is an
L<HTML::Native::Attribute> object that does not allow modification of
its values.

See L<HTML::Native::Attribute/"DYNAMIC GENERATION"> for further
details on when and why you might want to use an
L<HTML::Native::Attribute::ReadOnly> object.

=cut

use base qw ( HTML::Native::Attribute );
use mro "c3";
use strict;
use warnings;

sub hash {
  my $self = shift;
  my $value = $self->next::method ( @_ );

  return $self->new_readonly_hash ( $value );
}

sub array {
  my $self = shift;
  my $value = $self->next::method ( @_ );

  return $self->new_readonly_array ( $value );
}

1;