NAME
   Package::Strictures - Facilitate toggling validation code at users
   request, without extra performance penalties.

VERSION
   version 1.000000

SYNOPSIS
 IMPLEMENTING MODULES
     package Foo::Bar::Baz;

     use Package::Strictures::Register -setup => {
         -strictures => {
             STRICT => {
               default => ''
             },
         },
     };

     if( STRICT ) {
       /* Elimintated Code */
     }

   See "Package::Strictures::Register" for more detail.

 CONSUMING USERS
     use Package::Strictures -for => {
       'Foo::Bar::Baz' => {
         'STRICT' => 1,
       },
     };

     use Foo::Bar::Baz;

     /* Previously eliminated code now runs.

DESCRIPTION
   Often, I find myself in a bind, where I have code I want to do things
   properly, so it will detect of its own accord ( at run time ) misuses of
   varying data-structures or methods, but the very same tools that would
   be used to analyze and assure that things are going correctly, result in
   substantial performance penalties.

   This module, and the infrastructure I hope builds on top of it, may
   hopefully provide an 'in' that lets me have the best of both worlds,
   fast on the production server, and concise when trying to debug it (
   that is, not having to manually desk-check the whole execution cycle
   through various functions and modules just to find which level things
   are going wrong at ).

   In an ideal world, code would be both fast and concise, however, that is
   a future fantasy, and this here instead aims to produce 80% of the same
   benefits, but now, instead of never.

MINOR WARNING
   This code is pretty fresh. Its been done to death with T.D.D., and does
   everything I want it to, but there's always bugs.

AUTHOR
   Kent Fredric <[email protected]>

COPYRIGHT AND LICENSE
   This software is copyright (c) 2014 by Kent Fredric.

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