WP_Recovery_Mode::get_extension_for_error( array $error ): array|false

In this article

Gets the extension that the error occurred in.

Parameters

$errorarrayrequired
Error details from error_get_last().

Return

array|false Extension details.
  • slug string
    The extension slug. This is the plugin or theme’s directory.
  • type string
    The extension type. Either 'plugin' or 'theme'.

Source

protected function get_extension_for_error( $error ) {
	global $wp_theme_directories;

	if ( ! isset( $error['file'] ) ) {
		return false;
	}

	if ( ! defined( 'WP_PLUGIN_DIR' ) ) {
		return false;
	}

	$error_file    = wp_normalize_path( $error['file'] );
	$wp_plugin_dir = wp_normalize_path( WP_PLUGIN_DIR );

	if ( str_starts_with( $error_file, $wp_plugin_dir ) ) {
		$path  = str_replace( $wp_plugin_dir . '/', '', $error_file );
		$parts = explode( '/', $path );

		return array(
			'type' => 'plugin',
			'slug' => $parts[0],
		);
	}

	if ( empty( $wp_theme_directories ) ) {
		return false;
	}

	foreach ( $wp_theme_directories as $theme_directory ) {
		$theme_directory = wp_normalize_path( $theme_directory );

		if ( str_starts_with( $error_file, $theme_directory ) ) {
			$path  = str_replace( $theme_directory . '/', '', $error_file );
			$parts = explode( '/', $path );

			return array(
				'type' => 'theme',
				'slug' => $parts[0],
			);
		}
	}

	return false;
}

Changelog

VersionDescription
5.2.0Introduced.

User Contributed Notes

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