<html><head><meta name="color-scheme" content="light dark"></head><body><pre style="word-wrap: break-word; white-space: pre-wrap;"># THIS IS A WORK IN PROGRESS
# IT SHOULD BE CONSIDERED ALPHA
# BUT I EXPECT IT TO IMPROVE
# THIS IS A RE-IMPLEMENTATION OF PREVIOUS CODE THAT WAS WRITTEN
# ON-THE-FLY AS NEEDED. 

# YOU ARE ADVISED TO RUN THE TEST SCRIPT!!!


package Debug::Xray::WatchArray;
use strict;
use warnings;

use strict;
use Exporter qw(import);

our $VERSION     = 1.00;
our @ISA         = qw(Exporter);
our @EXPORT_OK   = qw( set_log_handler TIESCALAR STORE FETCH); # TODO SEE WHAT WE NEED HERE

use Carp::Assert;
use Data::Dumper;

use parent 'Tie::Scalar';


my $LogHandler;


sub TIESCALAR {
    assert ( (($#_==1) or ($#_==2)), 'Parms' );

    my $class = shift;
    assert( $class eq 'Debug::Xray::WatchArray' );

    my $var_name = shift;
    assert ($var_name, 'Must have variable name');

    my $value = shift || undef;

    my $self  = {};

    $self-&gt;{VAR_NAME} = $var_name;
    $self-&gt;{VALUE} = $value;

    $value = 'undef' unless defined $value;
    $LogHandler-&gt;("TIE: TIESCALAR $var_name=$value");
    return bless $self, $class;
}


sub STORE {    
    assert ( $#_==1, "Parms: found " . Dumper \@_ );
    assert ( defined $LogHandler, 'No Log Handler defined - Exiting' );
    my $self = shift;
    $self-&gt;{VALUE} = shift;

    my $value = $self-&gt;{VALUE} || 'undef';
    $LogHandler-&gt;("TIE: STORE $value to $self-&gt;{VAR_NAME}");
}


sub FETCH {
    assert ( $#_==0, "Parms: found " . Dumper \@_ );
    assert ( defined $LogHandler, 'No Log Handler defined - Exiting' );
    my $self = shift;

    my $value = $self-&gt;{VALUE} || 'undef';

    $LogHandler-&gt;("TIE: FETCH $value from $self-&gt;{VAR_NAME}");
    return $self-&gt;{VALUE};
}


sub set_log_handler {
    assert ( $#_==1, 'Parms' ) if DEBUG;
    my $self = shift;
    $LogHandler = shift;
}



1;
</pre></body></html>