Carp::Datum 0.1
     Copyright (c) 2000-2001, Christophe Dehaudt & Raphael Manfredi

------------------------------------------------------------------------
    This program is free software; you can redistribute it and/or modify
    it under the terms of the Artistic License, a copy of which can be
    found with perl.

    This program 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
    Artistic License for more details.
------------------------------------------------------------------------

========================================================================
This module is known to exercise a bug in perl 5.6.0.  Don't use that
version of perl: use 5.005_03, or try 5.6.1.

If ran under 5.6.0 nonetheless, the t/failmsg_on tests will be skipped.
========================================================================

       *** This is alpha software -- use at your own risks ***

Name           DSLI  Description                                  Info
-----------    ----  -------------------------------------------- -----
Carp::Datum    adpf  Debugging And Tracing Ultimate Module        CDE

========================================================================

This module is the Perl version of a C/C++ library, called DATUM, which
we have been using in many programs since 1996.

Following is the preamble to the DATUM library, written by Raphael in 1998:

--- Begin Exerpt:

A bug in a software system may have multiple causes. It can be the result
of an oversight, a typo, a misunderstanding, a misuse, etc... Being able
to identify the presence of a bug, and then nail it down as quickly as
possible were the reasons of our deciding to create debugging foundations.

During the bug hunting phase, a developer needs to be able to trace
routine execution around the suspected bug spot, which is a moving target
usually. Flexibility of the tracing subsystem is therefore mandatory to
only be able to trace a specific area of the software.

Detecting bugs as early as possible is also recognized as the most
efficient route to quality, and it is certainly economically justified.
By following the Design by Contract principle, i.e. by inserting pre- and
post-conditions to specify the interfaces, one guards against improper
implementations and also formally documents the original intent of the
designer. That is also an invaluable aid during maintenance or evolution,
since it avoids improper use of existing interfaces that could otherwise
lead to havoc when left undetected.


    NOTE: It is a wise practice to develop and test a piece of
    software with all the assertions turned on (that includes pre- and
    post-conditions, but also any additional assertion checking within
    the code), and release it with only pre-conditions enabled. Indeed,
    software correctness is compromised when any pre-condition is
    violated.

--- End Exerpt.

Carp::Datum implements the following features:

* Programming by contract: pre-conditions, post-conditions, assertions.
* Flow control tracing: routine entry, arguments, returned values
* Dynamic (i.e. runtime) configuration via mini language to tailor
  debugging and/or tracing at the routine / file / package / type level.
* Ability to statically remove all assertions and flow control tracing
  hooks in modules making use of Carp::Datum.
* Cooperation with Log::Agent for tracing.

In order to do so, the following routines are provided:

	Assertions:   DREQUIRE, DENSURE, DASSERT
	Flow control: DFEATURE, DVAL, DARY, DVOID
	Tracing:      DTRACE

A sepcial precondition, VERIFY, is always kept (i.e. never stripped)
and can be used for checking important conditions, to write:

	VERIFY $pre_condition, "message";

where one would otherwise use a test like:

	logcroak "message" if !$pre_condition;

in regular code.

Over the years, we have found DATUM to be a very valuable aid in large
software, especially in situations where the bug tolerence is zero: OS
modules, DB access/replication modules.  We hope you will enjoy it.

-- Christophe Dehaudt <christophe@dehaudt.org>
-- Raphael Manfredi <Raphael_Manfredi@pobox.com>