WP_Debug_Data::format( array $info_array, string $data_type ): string

In this article

Formats the information gathered for debugging, in a manner suitable for copying to a forum or support ticket.

Parameters

$info_arrayarrayrequired
Information gathered from the WP_Debug_Data::debug_data() function.
$data_typestringrequired
The data type to return, either 'info' or 'debug'.

Return

string The formatted data.

Source

public static function format( $info_array, $data_type ) {
	$return = "`\n";

	foreach ( $info_array as $section => $details ) {
		// Skip this section if there are no fields, or the section has been declared as private.
		if ( empty( $details['fields'] ) || ( isset( $details['private'] ) && $details['private'] ) ) {
			continue;
		}

		$section_label = 'debug' === $data_type ? $section : $details['label'];

		$return .= sprintf(
			"### %s%s ###\n\n",
			$section_label,
			( isset( $details['show_count'] ) && $details['show_count'] ? sprintf( ' (%d)', count( $details['fields'] ) ) : '' )
		);

		foreach ( $details['fields'] as $field_name => $field ) {
			if ( isset( $field['private'] ) && true === $field['private'] ) {
				continue;
			}

			if ( 'debug' === $data_type && isset( $field['debug'] ) ) {
				$debug_data = $field['debug'];
			} else {
				$debug_data = $field['value'];
			}

			// Can be array, one level deep only.
			if ( is_array( $debug_data ) ) {
				$value = '';

				foreach ( $debug_data as $sub_field_name => $sub_field_value ) {
					$value .= sprintf( "\n\t%s: %s", $sub_field_name, $sub_field_value );
				}
			} elseif ( is_bool( $debug_data ) ) {
				$value = $debug_data ? 'true' : 'false';
			} elseif ( empty( $debug_data ) && '0' !== $debug_data ) {
				$value = 'undefined';
			} else {
				$value = $debug_data;
			}

			if ( 'debug' === $data_type ) {
				$label = $field_name;
			} else {
				$label = $field['label'];
			}

			$return .= sprintf( "%s: %s\n", $label, $value );
		}

		$return .= "\n";
	}

	$return .= '`';

	return $return;
}

Changelog

VersionDescription
5.2.0Introduced.

User Contributed Notes

You must log in before being able to contribute a note or feedback.