NAME

    Object::Pad::SlotAttr::Final - declare Object::Pad slots readonly after
    construction

SYNOPSIS

       use Object::Pad;
       use Object::Pad::SlotAttr::Final;
    
       class Rectangle {
          has $width  :param :reader :Final;
          has $height :param :reader :Final;
    
          has $area :reader :Final;
    
          ADJUST {
             $area = $width * $height;
          }
       }

DESCRIPTION

    This module provides a third-party slot attribute for Object::Pad-based
    classes, which declares that the slot it is attached to shall be set as
    readonly when the constructor returns, disallowing further modification
    to it.

    WARNING The ability for Object::Pad to take third-party slot attributes
    is still new and highly experimental, and subject to much API change in
    future. As a result, this module should be considered equally
    experimental.

SLOT ATTRIBUTES

 :Final

       has $slot :Final ...;
       has $slot :Final ... = DEFAULT;

    Declares that the slot variable will be set readonly at the end of the
    constructor, after any assignments from :param declarations or ADJUST
    blocks. At this point, the value cannot otherwise be modified by
    directly writing into the slot variable.

       has $slot :Final;
    
       ADJUST { $slot = 123; }    # this is permitted
    
       method m { $slot = 456; }  # this will fail

    Note that this is only a shallow readonly setting; if the slot variable
    contains a reference to a data structure, that structure itself remains
    mutable.

       has $aref :Final;
       ADJUST { $aref = []; }
    
       method more { push @$aref, "another"; }   # this is permitted

AUTHOR

    Paul Evans <leonerd@leonerd.org.uk>