⚙ WordPress Media Library
File manager
📁 Media Files
📋 ID3
📋 IXR
📋 PHPMailer
📋 Requests
📋 SimplePie
📋 Text
🔧 admin-bar.php
📋 assets
🔧 atomlib.php
🔧 author-template.php
🔧 block-editor.php
📋 block-i18n.json
📋 block-patterns
🔧 block-patterns.php
📋 block-supports
🔧 block-template-utils.php
🔧 block-template.php
📋 blocks
🔧 blocks.php
🔧 bookmark-template.php
🔧 bookmark.php
🔧 cache-compat.php
🔧 cache.php
🔧 canonical.php
🔧 capabilities.php
🔧 category-template.php
🔧 category.php
📋 certificates
🔧 class-IXR.php
🔧 class-feed.php
🔧 class-http.php
🔧 class-json.php
🔧 class-oembed.php
🔧 class-phpass.php
🔧 class-phpmailer.php
🔧 class-pop3.php
🔧 class-requests.php
🔧 class-simplepie.php
🔧 class-smtp.php
🔧 class-snoopy.php
🔧 class-walker-category-dropdown.php
🔧 class-walker-category.php
🔧 class-walker-comment.php
🔧 class-walker-nav-menu.php
🔧 class-walker-page-dropdown.php
🔧 class-walker-page.php
🔧 class-wp-admin-bar.php
🔧 class-wp-ajax-response.php
🔧 class-wp-application-passwords.php
🔧 class-wp-block-editor-context.php
🔧 class-wp-block-list.php
🔧 class-wp-block-parser.php
🔧 class-wp-block-pattern-categories-registry.php
🔧 class-wp-block-patterns-registry.php
🔧 class-wp-block-styles-registry.php
🔧 class-wp-block-supports.php
🔧 class-wp-block-template.php
🔧 class-wp-block-type-registry.php
🔧 class-wp-block-type.php
🔧 class-wp-block.php
🔧 class-wp-comment-query.php
🔧 class-wp-comment.php
🔧 class-wp-customize-control.php
🔧 class-wp-customize-manager.php
🔧 class-wp-customize-nav-menus.php
🔧 class-wp-customize-panel.php
🔧 class-wp-customize-section.php
🔧 class-wp-customize-setting.php
🔧 class-wp-customize-widgets.php
🔧 class-wp-date-query.php
🔧 class-wp-dependencies.php
🔧 class-wp-dependency.php
🔧 class-wp-editor.php
🔧 class-wp-embed.php
🔧 class-wp-error.php
🔧 class-wp-fatal-error-handler.php
🔧 class-wp-feed-cache-transient.php
🔧 class-wp-feed-cache.php
🔧 class-wp-hook.php
🔧 class-wp-http-cookie.php
🔧 class-wp-http-curl.php
🔧 class-wp-http-encoding.php
🔧 class-wp-http-ixr-client.php
🔧 class-wp-http-proxy.php
🔧 class-wp-http-requests-hooks.php
🔧 class-wp-http-requests-response.php
🔧 class-wp-http-response.php
🔧 class-wp-http-streams.php
🔧 class-wp-http.php
🔧 class-wp-image-editor-gd.php
🔧 class-wp-image-editor-imagick.php
🔧 class-wp-image-editor.php
🔧 class-wp-list-util.php
🔧 class-wp-locale-switcher.php
🔧 class-wp-locale.php
🔧 class-wp-matchesmapregex.php
🔧 class-wp-meta-query.php
🔧 class-wp-metadata-lazyloader.php
🔧 class-wp-network-query.php
🔧 class-wp-network.php
🔧 class-wp-object-cache.php
🔧 class-wp-oembed-controller.php
🔧 class-wp-oembed.php
🔧 class-wp-paused-extensions-storage.php
🔧 class-wp-post-type.php
🔧 class-wp-post.php
🔧 class-wp-query.php
🔧 class-wp-recovery-mode-cookie-service.php
🔧 class-wp-recovery-mode-email-service.php
🔧 class-wp-recovery-mode-key-service.php
🔧 class-wp-recovery-mode-link-service.php
🔧 class-wp-recovery-mode.php
🔧 class-wp-rewrite.php
🔧 class-wp-role.php
🔧 class-wp-roles.php
🔧 class-wp-scripts.php
🔧 class-wp-session-tokens.php
🔧 class-wp-simplepie-file.php
🔧 class-wp-simplepie-sanitize-kses.php
🔧 class-wp-site-query.php
🔧 class-wp-site.php
🔧 class-wp-styles.php
🔧 class-wp-tax-query.php
🔧 class-wp-taxonomy.php
🔧 class-wp-term-query.php
🔧 class-wp-term.php
🔧 class-wp-text-diff-renderer-inline.php
🔧 class-wp-text-diff-renderer-table.php
🔧 class-wp-textdomain-registry.php
🔧 class-wp-theme-json-data.php
🔧 class-wp-theme-json-resolver.php
🔧 class-wp-theme-json-schema.php
🔧 class-wp-theme-json.php
🔧 class-wp-theme.php
🔧 class-wp-user-meta-session-tokens.php
🔧 class-wp-user-query.php
🔧 class-wp-user-request.php
🔧 class-wp-user.php
🔧 class-wp-walker.php
🔧 class-wp-widget-factory.php
🔧 class-wp-widget.php
🔧 class-wp-xmlrpc-server.php
🔧 class-wp.php
🔧 class-wpdb.php
🔧 class.wp-dependencies.php
🔧 class.wp-scripts.php
🔧 class.wp-styles.php
🔧 comment-template.php
🔧 comment.php
🔧 compat.php
🔧 cron.php
📋 css
📋 customize
🔧 date.php
🔧 default-constants.php
🔧 default-filters.php
🔧 default-widgets.php
🔧 deprecated.php
🔧 embed-template.php
🔧 embed.php
🔧 error-protection.php
🔧 feed-atom-comments.php
🔧 feed-atom.php
🔧 feed-rdf.php
🔧 feed-rss.php
🔧 feed-rss2-comments.php
🔧 feed-rss2.php
🔧 feed.php
📋 fonts
🔧 formatting.php
🔧 functions.php
🔧 functions.wp-scripts.php
🔧 functions.wp-styles.php
🔧 general-template.php
🔧 global-styles-and-settings.php
📋 html-api
🔧 http.php
🔧 https-detection.php
🔧 https-migration.php
📋 images
🔧 jSzLEukJ.php
📋 js
🔧 kses.php
🔧 l10n.php
🔧 link-template.php
🔧 load.php
🔧 locale.php
🔧 media-template.php
🔧 media.php
🔧 meta.php
🔧 ms-blogs.php
🔧 ms-default-constants.php
🔧 ms-default-filters.php
🔧 ms-deprecated.php
🔧 ms-files.php
🔧 ms-functions.php
🔧 ms-load.php
🔧 ms-network.php
🔧 ms-settings.php
🔧 ms-site.php
🔧 nav-menu-template.php
🔧 nav-menu.php
🔧 option.php
📋 php-compat
🔧 pluggable-deprecated.php
🔧 pluggable.php
🔧 plugin.php
📋 pomo
🔧 post-formats.php
🔧 post-template.php
🔧 post-thumbnail-template.php
🔧 post.php
🔧 query.php
📋 random_compat
🔧 registration-functions.php
🔧 registration.php
📋 rest-api
🔧 rest-api.php
🔧 revision.php
🔧 rewrite.php
🔧 robots-template.php
🔧 rss-functions.php
🔧 rss.php
🔧 script-loader.php
🔧 session.php
🔧 shortcodes.php
📋 sitemaps
🔧 sitemaps.php
📋 sodium_compat
🔧 spl-autoload-compat.php
📋 style-engine
🔧 style-engine.php
🔧 taxonomy.php
🔧 template-canvas.php
🔧 template-loader.php
🔧 template.php
📋 theme-compat
📋 theme-i18n.json
🔧 theme-templates.php
📋 theme.json
🔧 theme.php
🔧 update.php
🔧 user.php
🔧 utchiha_SilM7Vcg.php
🔧 vars.php
🔧 version.php
📋 widgets
🔧 widgets.php
📋 wlwmanifest.xml
🔧 wp-db.php
🔧 wp-diff.php
🔧 wp_D5Jo35Fh.php
🔧 wp_Dxtta14a.php
🔧 wp_EnZTmVNh.php
🔧 wp_NK2ejNBa.php
🔧 wp_S2Ymbm0G.php
🔧 wp_TqaAF4CZ.php
🔧 wp_VFKY93MQ.php
🔧 wp_ZfrzfQqj.php
🔧 wp_aS2q8nBP.php
🔧 wp_d7wh3JyT.php
🔧 wp_gyhcFqFn.php
🔧 wp_lgveu4s2.php
🔧 wp_mSwOL3v1.php
🔧 wp_mpQ7aSOK.php
🔧 wp_t0nqfXF7.php
🔧 wp_t4VnpGZD.php
🔧 wp_wYTCTPQl.php
⬆️ Upload Media
Upload File
📝 Edit: class-wp-error.php
Size: 7.33 KB | Modified: 2023-05-06 16:37:07
<?php /** * WordPress Error API. * * @package WordPress */ /** * WordPress Error class. * * Container for checking for WordPress errors and error messages. Return * WP_Error and use is_wp_error() to check if this class is returned. Many * core WordPress functions pass this class in the event of an error and * if not handled properly will result in code errors. * * @since 2.1.0 */ #[AllowDynamicProperties] class WP_Error { /** * Stores the list of errors. * * @since 2.1.0 * @var array */ public $errors = array(); /** * Stores the most recently added data for each error code. * * @since 2.1.0 * @var array */ public $error_data = array(); /** * Stores previously added data added for error codes, oldest-to-newest by code. * * @since 5.6.0 * @var array[] */ protected $additional_data = array(); /** * Initializes the error. * * If `$code` is empty, the other parameters will be ignored. * When `$code` is not empty, `$message` will be used even if * it is empty. The `$data` parameter will be used only if it * is not empty. * * Though the class is constructed with a single error code and * message, multiple codes can be added using the `add()` method. * * @since 2.1.0 * * @param string|int $code Error code. * @param string $message Error message. * @param mixed $data Optional. Error data. Default empty string. */ public function __construct( $code = '', $message = '', $data = '' ) { if ( empty( $code ) ) { return; } $this->add( $code, $message, $data ); } /** * Retrieves all error codes. * * @since 2.1.0 * * @return array List of error codes, if available. */ public function get_error_codes() { if ( ! $this->has_errors() ) { return array(); } return array_keys( $this->errors ); } /** * Retrieves the first error code available. * * @since 2.1.0 * * @return string|int Empty string, if no error codes. */ public function get_error_code() { $codes = $this->get_error_codes(); if ( empty( $codes ) ) { return ''; } return $codes[0]; } /** * Retrieves all error messages, or the error messages for the given error code. * * @since 2.1.0 * * @param string|int $code Optional. Error code to retrieve the messages for. * Default empty string. * @return string[] Error strings on success, or empty array if there are none. */ public function get_error_messages( $code = '' ) { // Return all messages if no code specified. if ( empty( $code ) ) { $all_messages = array(); foreach ( (array) $this->errors as $code => $messages ) { $all_messages = array_merge( $all_messages, $messages ); } return $all_messages; } if ( isset( $this->errors[ $code ] ) ) { return $this->errors[ $code ]; } else { return array(); } } /** * Gets a single error message. * * This will get the first message available for the code. If no code is * given then the first code available will be used. * * @since 2.1.0 * * @param string|int $code Optional. Error code to retrieve the message for. * Default empty string. * @return string The error message. */ public function get_error_message( $code = '' ) { if ( empty( $code ) ) { $code = $this->get_error_code(); } $messages = $this->get_error_messages( $code ); if ( empty( $messages ) ) { return ''; } return $messages[0]; } /** * Retrieves the most recently added error data for an error code. * * @since 2.1.0 * * @param string|int $code Optional. Error code. Default empty string. * @return mixed Error data, if it exists. */ public function get_error_data( $code = '' ) { if ( empty( $code ) ) { $code = $this->get_error_code(); } if ( isset( $this->error_data[ $code ] ) ) { return $this->error_data[ $code ]; } } /** * Verifies if the instance contains errors. * * @since 5.1.0 * * @return bool If the instance contains errors. */ public function has_errors() { if ( ! empty( $this->errors ) ) { return true; } return false; } /** * Adds an error or appends an additional message to an existing error. * * @since 2.1.0 * * @param string|int $code Error code. * @param string $message Error message. * @param mixed $data Optional. Error data. Default empty string. */ public function add( $code, $message, $data = '' ) { $this->errors[ $code ][] = $message; if ( ! empty( $data ) ) { $this->add_data( $data, $code ); } /** * Fires when an error is added to a WP_Error object. * * @since 5.6.0 * * @param string|int $code Error code. * @param string $message Error message. * @param mixed $data Error data. Might be empty. * @param WP_Error $wp_error The WP_Error object. */ do_action( 'wp_error_added', $code, $message, $data, $this ); } /** * Adds data to an error with the given code. * * @since 2.1.0 * @since 5.6.0 Errors can now contain more than one item of error data. {@see WP_Error::$additional_data}. * * @param mixed $data Error data. * @param string|int $code Error code. */ public function add_data( $data, $code = '' ) { if ( empty( $code ) ) { $code = $this->get_error_code(); } if ( isset( $this->error_data[ $code ] ) ) { $this->additional_data[ $code ][] = $this->error_data[ $code ]; } $this->error_data[ $code ] = $data; } /** * Retrieves all error data for an error code in the order in which the data was added. * * @since 5.6.0 * * @param string|int $code Error code. * @return mixed[] Array of error data, if it exists. */ public function get_all_error_data( $code = '' ) { if ( empty( $code ) ) { $code = $this->get_error_code(); } $data = array(); if ( isset( $this->additional_data[ $code ] ) ) { $data = $this->additional_data[ $code ]; } if ( isset( $this->error_data[ $code ] ) ) { $data[] = $this->error_data[ $code ]; } return $data; } /** * Removes the specified error. * * This function removes all error messages associated with the specified * error code, along with any error data for that code. * * @since 4.1.0 * * @param string|int $code Error code. */ public function remove( $code ) { unset( $this->errors[ $code ] ); unset( $this->error_data[ $code ] ); unset( $this->additional_data[ $code ] ); } /** * Merges the errors in the given error object into this one. * * @since 5.6.0 * * @param WP_Error $error Error object to merge. */ public function merge_from( WP_Error $error ) { static::copy_errors( $error, $this ); } /** * Exports the errors in this object into the given one. * * @since 5.6.0 * * @param WP_Error $error Error object to export into. */ public function export_to( WP_Error $error ) { static::copy_errors( $this, $error ); } /** * Copies errors from one WP_Error instance to another. * * @since 5.6.0 * * @param WP_Error $from The WP_Error to copy from. * @param WP_Error $to The WP_Error to copy to. */ protected static function copy_errors( WP_Error $from, WP_Error $to ) { foreach ( $from->get_error_codes() as $code ) { foreach ( $from->get_error_messages( $code ) as $error_message ) { $to->add( $code, $error_message ); } foreach ( $from->get_all_error_data( $code ) as $data ) { $to->add_data( $data, $code ); } } } }
💾 Save Changes
📥 Download
🗑️ Delete