NAME
dtRdr::Hack - self-documenting adaptive finger-wagging global vars
SYNOPSIS
This is a global store for things that cannot otherwise be cleanly solved at the moment.
package WayOver::OnThe::Left;
use dtRdr::Hack; dtRdr::Hack->set_variableB(45);
package Bottom::Right::Corner;
use dtRdr::Hack;
my $variableB = dtRdr::Hack->get_variableB;
Basically, just a way to formalize global variable sharing.
Arrays, hashes, objects, and globs are all passed and stored directly as references.
Declarations
Variables are declared in the %declarations
and %deprecated
hashes in the Hack.pm code. To deprecate variables, move them rather than duplicating.
The behavior is controlled by the following constants, which should be similar to perl's warnings and strict pragmas (less the lexical aspects and dynamic switchability.)
my %declared = (
some_scalar => '', # scalar
some_array => [], # array
some_hash => {}, # hash
some_univ => bless({}, 'UNIVERSAL'), # any object
some_obj => bless({}, 'dtRdr::Book'), # class or subclass
some_sub => sub {_die 'ex_sub'}, # declare subs like this
some_undef => undef, # run-time typing
);
TODO: you can currently set an object where you declared a hash, but STRICT should probably not allow that.
Moving variables to %deprecated
allows you to denote that your code should no longer be using these.
my %deprecated = (
some_other_scalar => '',
some_other_array => [],
some_other_hash => {},
some_other_sub => sub {_die 'ex_sub'},
);
NOTE: The sub {_die 'ex_sub'}
idiom lets you stop yourself from calling what you thought was set elsewhere.
- STRICT
-
Throws errors when you:
get/set to an undeclared variable
set the wrong type to a variable
(TODO) set the wrong type to a dynamically typed variable
- WARNINGS
-
Complains when you:
get/set deprecated variables
get/set undeclared variables (allowed if STRICT=0)
get/set the wrong type for a variable (allowed if STRICT=0)
- TRACE
-
Is not implemented yet.
NOTE: Running without STRICT=1 is only lightly tested and is not recommended.
AUTHOR
Eric Wilhelm <ewilhelm at cpan dot org>
http://scratchcomputing.com/
BUGS
COPYRIGHT
Copyright (C) 2006 OSoft, Eric L. Wilhelm, All Rights Reserved.
Portions derived from Jifty::DBI - Copyright Best Practical.
NO WARRANTY
Absolutely, positively NO WARRANTY, neither express or implied, is offered with this software. You use this software at your own risk. In case of loss, no person or entity owes you anything whatsoever. You have been warned.
LICENSE
The dotReader(TM) is OSI Certified Open Source Software licensed under the GNU General Public License (GPL) Version 2, June 1991. Non-encrypted and encrypted packages are usable in connection with the dotReader(TM). The ability to create, edit, or otherwise modify content of such encrypted packages is self-contained within the packages, and NOT provided by the dotReader(TM), and is addressed in a separate commercial license.
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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.