Page Menu
Home
c4science
Search
Configure Global Search
Log In
Files
F107105492
phlog.php
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Award Token
Subscribers
None
File Metadata
Details
File Info
Storage
Attached
Created
Fri, Apr 4, 16:22
Size
2 KB
Mime Type
text/x-php
Expires
Sun, Apr 6, 16:22 (1 d, 23 h)
Engine
blob
Format
Raw Data
Handle
25332433
Attached To
rPHU libphutil
phlog.php
View Options
<?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()##.
*
* @param wild Any value you want printed to the error log or other registered
* logs/consoles.
* @param ... Other values to be logged.
* @return wild Passed $value.
* @group error
*/
function
phlog
(
$value
/* , ... */
)
{
// Get the caller information
$trace
=
debug_backtrace
();
$metadata
=
array
(
'file'
=>
$trace
[
0
][
'file'
],
'line'
=>
$trace
[
0
][
'line'
],
'trace'
=>
$trace
,
);
foreach
(
func_get_args
()
as
$event
)
{
PhutilErrorHandler
::
dispatchErrorMessage
(
$event
instanceof
Exception
?
PhutilErrorHandler
::
EXCEPTION
:
PhutilErrorHandler
::
PHLOG
,
$event
,
$metadata
);
}
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
Log In to Comment