NAME

Tie::Trace - easy print debugging with tie

VERSION

Version 0.04

SYNOPSIS

   use Tie::Trace;

   my %hash;
   tie %hash, "Tie::Trace";

   $hash{hoge} = 'hogehoge'; # warn Hash => Key: hoge, Value: hogehgoe at ...

   my @array;
   tie @aray, "Tie::Trace";
   push @array, "array";    # warn Array => Point: 0, Value: array at ...

   my $scalar;
   tie $scalar, "Tie::Trace";
   $scalar = "scalar";      # warn Scalar => Value: scalar at ...

DESCRIPTION

This is usefull for print debugging. Using tie mechanism, you can see sotred value for the specified variable.

If the stored value is scalar/array/hash ref, this can check recursively.

for example;

tie %hash, "Tie::Trace";

$hash{foo} = {a => 1, b => 2}; # warn ...
$hash{foo}->{a} = 2            # warn ...

But This ignores blessed reference and tied value.

OPTIONS

key => [values/regexs/coderef]
tie %hash, "Tie::Trace", key => [qw/foo bar/];

It is for hash. You can spedify key name/regex/coderef for checking. Not specified/matched keys are ignored for warning. When you give coderef, this codref receive tied value and key as arguments, it returns false, the key is ignored.

for example;

tie %hash, "Tie::Trace", key => [qw/foo bar/, qr/x/];

$hash{foo} = 1 # warn ...
$hash{bar} = 1 # warn ...
$hash{var} = 1 # *no* warnings
$hash{_x_} = 1 # warn ...
value => [contents/regexs/coderef]
tie %hash, "Tie::Trace", value => [qw/foo bar/];

You can spedify value's content/regex/coderef for checking. Not specified/matched are ignored for warning. When you give coderef, this codref receive tied value and value as arguments, it returns false, the value is ignored.

for example;

tie %hash, "Tie::Trace", value => [qw/foo bar/, qr/\)/];

$hash{a} = 'foo'  # warn ...
$hash{b} = 'foo1' # *no* warnings
$hash{c} = 'bar'  # warn ...
$hash{d} = ':-)'  # warn ...
use => [qw/hash array scalar/]
tie %hash, "Tie::Trace", use => [qw/array/];

It specify type(scalar, array or hash) of variable for checking. As default, all type will be checked.

for example;

tie %hash, "Tie::Trace", use => [qw/array/];

$hash{foo} = 1         # *no* warnings
$hash{bar} = 1         # *no* warnings
$hash{var} = []        # *no* warnings
push @{$hash{var}} = 1 # warn ...
debug => 'dumper'/coderef
tie %hash, "Tie::Trace", debug => 'dumper'
tie %hash, "Tie::Trace", debug => sub{my($self, @v) = @_; return @v }

It specify value representation. As default, just print value as scalar. You can use "dumper" or coderef. "dumper" make value show with Data::Dumper::Dumper. When you specify your coderef, its first argument is tied value and second argument is value, it should modify it and return it.

debug_value => [contents/regexs/coderef]
tie %hash, "Tie::Trace", debug => sub{my($s,$v) = @_; $v =~tr/op/po/;}, debug_value => [qw/foo boo/];

You can spedify debugged value's content/regex for checking. Not specified/matched are ignored for warning. When you give coderef, this codref receive tied value and value as arguments, it returns false, the value is ignored.

for example;

tie %hash, "Tie::Trace", debug => sub{my($s,$v) = @_; $v =~tr/op/po/;}, debug_value => [qw/foo boo/];

$hash{a} = 'fpp'  # warn ...      because debugged value is foo
$hash{b} = 'foo'  # *no* warnings because debugged value is fpp
$hash{c} = 'bpp'  # warn ...      because debugged value is boo
r => 0/1
tie %hash, "Tie::Trace", r => 0;

If r is 0, this won't check recusively. 1 is default.

caller => number/[numbers]
tie %hash, "Tie::Trace", caller => 2;

It effects warning message. default is 0. If you set grater than 0, it goes upstream to check.

You can specify array ref.

tie %hash, "Tie::Trace", caller => [1, 2, 3];

It display following messages.

Hash => Key: key, Value:hoge at filename line 61.
at filename line 383.
at filename line 268.

METHODS

It is used in coderef which is passed for options, for example, key, value and/or debug_value or as the method of the returned of tied fucntion.

storage
tie %hash, "Tie::Trace", debug =>
  sub {
    my($self, $v) = @_;
    my $storage = $self->storage;
    return $storage;
  };

This returns reference in which value(s) stored.

parent
tie %hash, "Tie::Trace", debug =>
  sub {
    my($self, $v) = @_;
    my $parent = $self->parent->storage;
    return $parent;
  };

This method returns $self's parent tied value.

for example;

tie my %hash, "Tie::Trace";
my %hash2;
$hash{1} = \%hash2;
my $tied_hash2 = tied %hash2;
print tied %hash eq $tied_hash2->parent; # 1

AUTHOR

Ktat, <atusi at pure.ne.jp>

BUGS

Please report any bugs or feature requests to bug-tie-debug at rt.cpan.org, or through the web interface at http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Tie-Trace. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.

SUPPORT

You can find documentation for this module with the perldoc command.

perldoc Tie::Trace

You can also find documentation written in Japanese(euc-jp) for this module with the perldoc command.

perldoc Tie::Trace_JP

You can also look for information at:

$BCx:n8"(B & $B%i%$%;%s%9(B

Copyright 2006 Ktat, all rights reserved.

This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.