# vim:ts=4 sw=4
# ----------------------------------------------------------------------------------------------------
# Name : Class::STL::Trace.pm
# Created : 12 May 2006
# Author : Mario Gaffiero (gaffie)
#
# Copyright 2006-2007 Mario Gaffiero.
#
# This file is part of Class::STL::Containers(TM).
#
# Class::STL::Containers 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; version 2 of the License.
#
# Class::STL::Containers 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 Class::STL::Containers; if not, write to the Free Software
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
# ----------------------------------------------------------------------------------------------------
# Modification History
# When Version Who What
# ----------------------------------------------------------------------------------------------------
# TO DO:
# ----------------------------------------------------------------------------------------------------
package Class::STL::Trace;
require 5.005_62;
use strict;
use warnings;
use vars qw($VERSION $BUILD);
$VERSION = '0.24';
$BUILD = 'Saturday May 6 23:08:34 GMT 2006';
# ----------------------------------------------------------------------------------------------------
{
package Class::STL::Trace; # Singleton
use UNIVERSAL qw(isa can);
use Carp qw(confess);
sub new {
our $__class_stl_trace;
return $__class_stl_trace if (defined($__class_stl_trace));
use vars qw(@ISA);
my $proto = shift;
my $class = ref($proto) || $proto;
$__class_stl_trace = int(@ISA) ? $class->SUPER::new(@_) : {};
bless($__class_stl_trace, $class);
$__class_stl_trace->members_init(@_);
return $__class_stl_trace;
}
sub filename {
my $self = shift;
$self->{Class_STL_Trace}->{FILENAME} = shift if (@_);
return $self->{Class_STL_Trace}->{FILENAME};
}
sub trace_level {
my $self = shift;
$self->{Class_STL_Trace}->{TRACE_LEVEL} = shift if (@_);
return $self->{Class_STL_Trace}->{TRACE_LEVEL};
}
sub debug_on {
my $self = shift;
$self->{Class_STL_Trace}->{DEBUG_ON} = shift if (@_);
return $self->{Class_STL_Trace}->{DEBUG_ON};
}
sub print {
my $self = shift;
my $caller = shift || '';
open(DEBUG, ">>@{[ $self->filename() ]}");
print DEBUG "# $caller\n"; # !!! need to get this as arg to print !!!
print DEBUG @_, "\n";
close(DEBUG);
}
sub members_init {
my $self = shift;
use vars qw(@ISA);
if (int(@ISA) && (caller())[0] ne __PACKAGE__) {
$self->SUPER::members_init(@_);
}
my @p;
while (@_) { my $p=shift; push(@p, $p, shift) if (!ref($p)); }
my %p = @p;
$self->filename(exists($p{'filename'}) ? $p{'filename'} : "class_stl_dump$$");
$self->trace_level(exists($p{'trace_level'}) ? $p{'trace_level'} : '0');
$self->debug_on(exists($p{'debug_on'}) ? $p{'debug_on'} : '0');
}
sub member_print {
my $self = shift;
my $delim = shift || '|';
return join("$delim",
"debug_on=@{[ defined($self->debug_on()) ? $self->debug_on() : 'NULL' ]}",
"filename=@{[ defined($self->filename()) ? $self->filename() : 'NULL' ]}",
"trace_level=@{[ defined($self->trace_level()) ? $self->trace_level() : 'NULL' ]}",
);
}
sub members_local { # static function
return {
debug_on=>[ '0', '' ],
filename=>[ "class_stl_dump$$", '' ],
trace_level=>[ '0', '' ],
};
}
sub members {
my $self = shift;
use vars qw(@ISA);
my $super = (int(@ISA)) ? $self->SUPER::members() : {};
return keys(%$super)
? {
%$super,
debug_on=>[ '0', '' ],
filename=>[ "class_stl_dump$$", '' ],
trace_level=>[ '0', '' ]
}
: {
debug_on=>[ '0', '' ],
filename=>[ "class_stl_dump$$", '' ],
trace_level=>[ '0', '' ]
};
}
sub swap {
my $self = shift;
my $other = shift;
use vars qw(@ISA);
my $tmp = $self->clone();
$self->SUPER::swap($other) if (int(@ISA));
$self->filename($other->filename());
$self->trace_level($other->trace_level());
$self->debug_on($other->debug_on());
$other->filename($tmp->filename());
$other->trace_level($tmp->trace_level());
$other->debug_on($tmp->debug_on());
}
sub clone {
my $self = shift;
use vars qw(@ISA);
my $clone = int(@ISA) ? $self->SUPER::clone() : $self->new();
$clone->filename($self->filename());
$clone->trace_level($self->trace_level());
$clone->debug_on($self->debug_on());
return $clone;
}
}
1;
syntax highlighted by Code2HTML, v. 0.9.1