WP_Image_Editor_GD::_save( resource|GdImage $image, string|null $filename = null, string|null $mime_type = null ): array|WP_Error

In this article

Parameters

$imageresource|GdImagerequired
$filenamestring|nulloptional

Default:null

$mime_typestring|nulloptional

Default:null

Return

array|WP_Error Array on success or WP_Error if the file failed to save.
  • path string
    Path to the image file.
  • file string
    Name of the image file.
  • width int
    Image width.
  • height int
    Image height.
  • mime-type string
    The mime type of the image.
  • filesize int
    File size of the image.

Source

protected function _save( $image, $filename = null, $mime_type = null ) {
	list( $filename, $extension, $mime_type ) = $this->get_output_format( $filename, $mime_type );

	if ( ! $filename ) {
		$filename = $this->generate_filename( null, null, $extension );
	}

	if ( function_exists( 'imageinterlace' ) ) {
		/**
		 * Filters whether to output progressive images (if available).
		 *
		 * @since 6.5.0
		 *
		 * @param bool   $interlace Whether to use progressive images for output if available. Default false.
		 * @param string $mime_type The mime type being saved.
		 */
		imageinterlace( $image, apply_filters( 'image_save_progressive', false, $mime_type ) );
	}

	if ( 'image/gif' === $mime_type ) {
		if ( ! $this->make_image( $filename, 'imagegif', array( $image, $filename ) ) ) {
			return new WP_Error( 'image_save_error', __( 'Image Editor Save Failed' ) );
		}
	} elseif ( 'image/png' === $mime_type ) {
		// Convert from full colors to index colors, like original PNG.
		if ( function_exists( 'imageistruecolor' ) && ! imageistruecolor( $image ) ) {
			imagetruecolortopalette( $image, false, imagecolorstotal( $image ) );
		}

		if ( ! $this->make_image( $filename, 'imagepng', array( $image, $filename ) ) ) {
			return new WP_Error( 'image_save_error', __( 'Image Editor Save Failed' ) );
		}
	} elseif ( 'image/jpeg' === $mime_type ) {
		if ( ! $this->make_image( $filename, 'imagejpeg', array( $image, $filename, $this->get_quality() ) ) ) {
			return new WP_Error( 'image_save_error', __( 'Image Editor Save Failed' ) );
		}
	} elseif ( 'image/webp' == $mime_type ) {
		if ( ! function_exists( 'imagewebp' ) || ! $this->make_image( $filename, 'imagewebp', array( $image, $filename, $this->get_quality() ) ) ) {
			return new WP_Error( 'image_save_error', __( 'Image Editor Save Failed' ) );
		}
	} elseif ( 'image/avif' == $mime_type ) {
		if ( ! function_exists( 'imageavif' ) || ! $this->make_image( $filename, 'imageavif', array( $image, $filename, $this->get_quality() ) ) ) {
			return new WP_Error( 'image_save_error', __( 'Image Editor Save Failed' ) );
		}
	} else {
		return new WP_Error( 'image_save_error', __( 'Image Editor Save Failed' ) );
	}

	// Set correct file permissions.
	$stat  = stat( dirname( $filename ) );
	$perms = $stat['mode'] & 0000666; // Same permissions as parent folder, strip off the executable bits.
	chmod( $filename, $perms );

	return array(
		'path'      => $filename,
		/**
		 * Filters the name of the saved image file.
		 *
		 * @since 2.6.0
		 *
		 * @param string $filename Name of the file.
		 */
		'file'      => wp_basename( apply_filters( 'image_make_intermediate_size', $filename ) ),
		'width'     => $this->size['width'],
		'height'    => $this->size['height'],
		'mime-type' => $mime_type,
		'filesize'  => wp_filesize( $filename ),
	);
}

Hooks

apply_filters( ‘image_make_intermediate_size’, string $filename )

Filters the name of the saved image file.

apply_filters( ‘image_save_progressive’, bool $interlace, string $mime_type )

Filters whether to output progressive images (if available).

Changelog

VersionDescription
6.0.0The $filesize value was added to the returned array.
3.5.0Introduced.

User Contributed Notes

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