A WordPress-centric search engine for devs and theme authors



wp_debug_backtrace_summary ›

Since3.4.0
Deprecatedn/a
wp_debug_backtrace_summary ( $ignore_class = null, $skip_frames = 0, $pretty = true )
Parameters: (3)
  • (string) $ignore_class Optional. A class to ignore all function calls within - useful when you want to just give info about the callee. Default null.
    Required: No
    Default: null
  • (int) $skip_frames Optional. A number of stack frames to skip - useful for unwinding back to the source of the issue. Default 0.
    Required: No
    Default:
  • (bool) $pretty Optional. Whether or not you want a comma separated string or raw array returned. Default true.
    Required: No
    Default: true
See:
Returns:
  • (string|array) Either a string containing a reversed comma separated trace or an array of individual calls.
Defined at:
Codex:

Return a comma-separated string of functions that have been called to get to the current point in code.



Source

function wp_debug_backtrace_summary( $ignore_class = null, $skip_frames = 0, $pretty = true ) {
	static $truncate_paths;

	if ( version_compare( PHP_VERSION, '5.2.5', '>=' ) ) {
		$trace = debug_backtrace( false );
	} else {
		$trace = debug_backtrace();
	}

	$caller      = array();
	$check_class = ! is_null( $ignore_class );
	$skip_frames++; // skip this function

	if ( ! isset( $truncate_paths ) ) {
		$truncate_paths = array(
			wp_normalize_path( WP_CONTENT_DIR ),
			wp_normalize_path( ABSPATH ),
		);
	}

	foreach ( $trace as $call ) {
		if ( $skip_frames > 0 ) {
			$skip_frames--;
		} elseif ( isset( $call['class'] ) ) {
			if ( $check_class && $ignore_class == $call['class'] ) {
				continue; // Filter out calls
			}

			$caller[] = "{$call['class']}{$call['type']}{$call['function']}";
		} else {
			if ( in_array( $call['function'], array( 'do_action', 'apply_filters', 'do_action_ref_array', 'apply_filters_ref_array' ) ) ) {
				$caller[] = "{$call['function']}('{$call['args'][0]}')";
			} elseif ( in_array( $call['function'], array( 'include', 'include_once', 'require', 'require_once' ) ) ) {
				$filename = isset( $call['args'][0] ) ? $call['args'][0] : '';
				$caller[] = $call['function'] . "('" . str_replace( $truncate_paths, '', wp_normalize_path( $filename ) ) . "')";
			} else {
				$caller[] = $call['function'];
			}
		}
	}
	if ( $pretty ) {
		return join( ', ', array_reverse( $caller ) );
	} else {
		return $caller;
	}
}