Page MenuHomec4science

phlog.php
No OneTemporary

File Metadata

Created
Fri, Jan 17, 22:03

phlog.php

<?php
/**
* libphutil log function for development debugging. Takes any argument and
* forwards it to registered listeners. This is essentially a more powerful
* version of ##error_log()##.
*
* NOTE: You must call ##PhutilErrorHandler::initialize()## before this will do
* anything.
*
* @param wild Any value you want printed to the error log or other registered
* logs/consoles.
* @return wild Passed $value.
* @group error
*/
function phlog($value) {
if (!PhutilErrorHandler::hasInitialized()) {
throw new Exception(
"Call to phlog() before PhutilErrorHandler::initialize()!");
}
// Get the caller information
$trace = debug_backtrace();
$file = $trace[0]['file'];
$line = $trace[0]['line'];
PhutilErrorHandler::dispatchErrorMessage(
$value instanceof Exception
? PhutilErrorHandler::EXCEPTION
: PhutilErrorHandler::PHLOG,
$value,
array('file' => $file,
'line' => $line,
'trace' => $trace));
return $value;
}
/**
* Example @{class:PhutilErrorHandler} error listener callback. When you call
* ##PhutilErrorHandler::setErrorListener()##, you must pass a callback function
* with the same signature as this one.
*
* NOTE: @{class:PhutilErrorHandler} handles writing messages to the error
* log, so you only need to provide a listener if you have some other console
* (like Phabricator's DarkConsole) which you //also// want to send errors to.
*
* NOTE: You will receive errors which were silenced with the "@" operator. If
* you don't want to display these, test for "@" being in effect by checking if
* ##error_reporting() === 0## before displaying the error.
*
* @param const A PhutilErrorHandler constant, like PhutilErrorHandler::ERROR,
* which indicates the event type (e.g. error, exception,
* user message).
* @param wild The event value, like the Exception object for an exception
* event, an error string for an error event, or some user object
* for user messages.
* @param dict A dictionary of metadata about the event. The keys 'file',
* 'line' and 'trace' are always available. Other keys may be
* present, depending on the event type.
* @return void
* @group error
*/
function phutil_error_listener_example($event, $value, array $metadata) {
throw new Exception("This is just an example function!");
}

Event Timeline