The HTML_CSS package is implemented with a flexible error handler plug-in system. You may use any error handler that you want. Using PEAR_Error object (default), but also the PEAR_ErrorStack package, or any other error handler you might want to plug in.
Without any configuration, each HTML_CSS API error (basic or exception) will raise a HTML_CSS_Error object that will be return to call script (user script).
Tip: Easy to distinct basic PEAR_Error from other PEAR packages to HTML_CSS errors, even if there is a better and more robust solution: HTML_CSS::isError(). But also provide a unique way to retrieve the level of error (warning, error, exception) with the HTML_CSS_Error::getLevel() method.
As usual you can use the PEAR error API as well.
<?php require_once 'HTML/CSS.php'; $css = new HTML_CSS(); $result = $css->setStyle('div', 'color', 5); if (PEAR::isError($result)) { // do something when an error is raised } ?> |
Exception |
Perhaps this standard behavior is not what you want. Don't worry, you can change everything :
display or ignore the error
display or hide part of message (error level, body, context)
Important: HTML_CSS obey at display_errors and log_errors protocol
A error handler's configuration is determined by the arguments used in its construction. Here's an overview of these parameters.
<?php require_once 'HTML/CSS.php'; $errorConf = array('error_handler' => 'myErrorHandler', 'push_callback' => 'myError', // ... more options ); $css = new HTML_CSS(null, $errorConf); ?> |
Table 47-1. Error Handler configuration parameters
Option | Type | Description |
---|---|---|
error_handler | callback | A valid callback (function) to manage errors raised by the HTML_CSS::raiseError() method. Default is: HTML_CSS::_errorHandler |
push_callback | callback | A valid callback (function) that decides to following action. Default return: PEAR_ERROR_DIE if exception, NULL otherwise. |
error_callback | callback | A valid callback (function) that decides to call a real free user function. Default call: none |
message_callback | callback | A valid callback (function) to control message generation. Default is: HTML_CSS_Error::_msgCallback |
context_callback | callback | A valid callback (function) to control error context generation. Default is: HTML_CSS_Error::getBacktrace |
handler | mixed | any handler-specific settings |
There are many scenarios in which fine-grained control over error raising is absolutely necessary.
The first level to control error generation is the php.ini directives display_errors and log_errors. When these directives are set to TRUE, then browser and file outputs are effective.
Tip: If you want to ignore all errors raised (no display, no logs) and avoid to include PEAR core class, then you should have something like :
<?php require_once 'HTML/CSS.php'; function myErrorHandler() { return null; } $errorConf = array('error_handler' => 'myErrorHandler'); $css = new HTML_CSS(null, $errorConf); // ... ?>
Note for users of HTML_CSS 1.4.0 or greater: You may want to decide to print (yes/no), log (yes/no) error messages with a full free user function local to HTML_CSS
rather than using global PEAR error handler (PEAR::setErrorHandling, PEAR::pushErrorHandling, PEAR::popErrorHandling).
<?php require_once 'HTML/CSS.php'; function myErrorAction($css_error) { // do what you want: print and/or log $css_error instance of HTML_CSS_Error object } $errorConf = array('error_callback' => 'myErrorAction'); $css = new HTML_CSS(null, $errorConf); // ... ?>
<?php require_once 'HTML/CSS.php'; function myErrorAction($css_error) { // do what you want: print and/or log $css_error instance of HTML_CSS_Error object } PEAR::setErrorHandling(PEAR_ERROR_CALLBACK, 'myErrorAction'); $css = new HTML_CSS(); // ... ?>
With push_callback option, you can decides to stop script execution (as done with exceptions by default: returns PEAR_ERROR_DIE constant), or continue without filtering (returns NULL).
If you want to write your own callback function for the push_callback option, this one should have two arguments: first one will get the error code, and second will get error level. These are all the necessary informations to do a filtering. Example that follow show how to be aware that a script use wrong argument data type.
<?php require_once 'HTML/CSS.php'; function myErrorFilter($code, $level) { if ($code === HTML_CSS_ERROR_INVALID_INPUT) { error_log('script: '.__FILE__.' used wrong argument data type', 1, 'admin@yoursite.com'); } return null; } $errorConf = array('push_callback' => 'myErrorFilter'); $css = new HTML_CSS(null, $errorConf); // ... ?> |
In some cases, you may want to customize error generation. For instance, for each error (basic/exception), it is useful to include file, line number, and class/function context information in order to trace it. The default option will be sufficient for most cases but you want perhaps customize the output format (render) of context information.
With this example we will change display and log renders.
<?php require_once 'HTML/CSS.php'; $displayConfig = array( 'lineFormat' => '<b>%1$s</b>: %2$s<br />%3$s', 'contextFormat' => '<b>File:</b> %1$s <br />' . '<b>Line:</b> %2$s <br />' . '<b>Function:</b> %3$s ' ); $logConfig = array( 'lineFormat' => '%1$s %2$s [%3$s] %4$s', 'timeFormat' => '%b' ); $prefs = array( 'handler' => array('display' => $displayConfig, 'log' => $logConfig )); $css = new HTML_CSS(null, $prefs); // ... $result = $css->setStyle('div', 'color', 5); ?> |
Display render will give something like:
Exception |
Log render will give something like:
Jun 127.0.0.1 |
Note: To have both display and log output, check the php.ini display_errors and log_errors values : must be set to TRUE.
Let review, step by step, how to get such results.
Remember that with default classes, there are two drivers : display and log that have both their own configuration parameters. You can override these parameters values with the handler entry in the hash of second argument of the HTML_CSS class constructor.
We did it here with the $prefs variable; it's a two key associative array. First key display defines the display driver values, and the second key log defines the log driver values.
Review the display driver custom values. Only two keys: lineFormat, contextFormat are redefined, thats means remains key eol keep its default value. See table below.
Table 47-2. Display driver configuration parameters
Parameter | Type | Default | Description |
---|---|---|---|
eol | string | <br />\n | The end-on-line character sequence |
lineFormat | string | <b>%1$s</b>: %2$s %3$s | Log line format specification:
|
contextFormat | string | in <b>%3$s</b> (file <b>%1$s</b> on line <b>%2$s</b>) | Context format (class, file, line) specification:
|
Tip: If you don't wish to see context information in the error message, then remove the parameter %3$ in the lineFormat option even if contextFormat is set.
Review now the log driver custom values. Only two keys lineFormat, timeFormat are redefined, thats means six remains keys eol, contextFormat, ident, message_type, destination, extra_headers keep their default values. See table below.
Table 47-3. Log driver configuration parameters
Parameter | Type | Default | Description |
---|---|---|---|
eol | string | \n | The end-on-line character sequence |
lineFormat | string | %1$s %2$s [%3$s] %4$s %5$s | Log line format specification:
|
contextFormat | string | in %3$s (file %1$s on line %2$s) | Context format (class, file, line) specification:
|
timeFormat | string | %b %d %H:%M:%S | Time stamp format used by strftime |
ident | string | REMOTE_ADDR | Client IP |
message_type | string | 3 | Destination type used by error_log |
destination | string | html_css_error.log | Destination name used by error_log |
extra_headers | string | NULL | Extra headers depending of destination type |
Tip: If you don't wish to see context information in the error message, then remove the parameter %5$ in the lineFormat option even if contextFormat is set.
There are two methods of HTML_CSS_Error designed for use with generating error messages efficiently. To use them, you must set the options below in the HTML_CSS class constructor (argument #2):
The default message handling callback (HTML_CSS_Error::_getErrorMessage) get an array mapping error codes to error message templates, like so:
<?php $messages = array( HTML_CSS_ERROR_UNKNOWN => 'unknown error', HTML_CSS_ERROR_INVALID_INPUT => 'invalid input, parameter #%paramnum% ' . '"%var%" was expecting ' . '"%expected%", instead got "%was%"' ); ?> |