mirror of
https://github.com/WordPress/WordPress.git
synced 2025-01-03 15:08:10 +01:00
Database: Move the if statement outside of the loop.
In the foreach loop of last results, move the if statement outside of the loop. There is no need to check every element in the array for the output type. Do this once outside of the loop. For large database queries with lots of rows returned, this should improve PHP performance. Props spacedmonkey, Cybr, johnbillion, costdev, joemcgill. Fixes #56541. Built from https://develop.svn.wordpress.org/trunk@56066 git-svn-id: http://core.svn.wordpress.org/trunk@55578 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
00401e16b3
commit
b80a8763c7
@ -34,7 +34,7 @@ function render_block_core_cover( $attributes, $content ) {
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* Inserts the featured image between the (1st) cover 'background' `span` and 'inner_container' `div`,
|
* Inserts the featured image between the (1st) cover 'background' `span` and 'inner_container' `div`,
|
||||||
* and removes eventual withespace characters between the two (typically introduced at template level)
|
* and removes eventual whitespace characters between the two (typically introduced at template level)
|
||||||
*/
|
*/
|
||||||
$inner_container_start = '/<div\b[^>]+wp-block-cover__inner-container[\s|"][^>]*>/U';
|
$inner_container_start = '/<div\b[^>]+wp-block-cover__inner-container[\s|"][^>]*>/U';
|
||||||
if ( 1 === preg_match( $inner_container_start, $content, $matches, PREG_OFFSET_CAPTURE ) ) {
|
if ( 1 === preg_match( $inner_container_start, $content, $matches, PREG_OFFSET_CAPTURE ) ) {
|
||||||
@ -46,22 +46,19 @@ function render_block_core_cover( $attributes, $content ) {
|
|||||||
update_post_thumbnail_cache();
|
update_post_thumbnail_cache();
|
||||||
}
|
}
|
||||||
$current_featured_image = get_the_post_thumbnail_url();
|
$current_featured_image = get_the_post_thumbnail_url();
|
||||||
|
if ( ! $current_featured_image ) {
|
||||||
$styles = 'background-image:url(' . esc_url( $current_featured_image ) . '); ';
|
return $content;
|
||||||
|
|
||||||
if ( isset( $attributes['minHeight'] ) ) {
|
|
||||||
$height_unit = empty( $attributes['minHeightUnit'] ) ? 'px' : $attributes['minHeightUnit'];
|
|
||||||
$height = " min-height:{$attributes['minHeight']}{$height_unit}";
|
|
||||||
|
|
||||||
$styles .= $height;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$content = preg_replace(
|
$processor = new WP_HTML_Tag_Processor( $content );
|
||||||
'/class=\".*?\"/',
|
$processor->next_tag();
|
||||||
'${0} style="' . $styles . '"',
|
|
||||||
$content,
|
$styles = $processor->get_attribute( 'style' );
|
||||||
1
|
$merged_styles = ! empty( $styles ) ? $styles . ';' : '';
|
||||||
);
|
$merged_styles .= 'background-image:url(' . esc_url( $current_featured_image ) . ');';
|
||||||
|
|
||||||
|
$processor->set_attribute( 'style', $merged_styles );
|
||||||
|
$content = $processor->get_updated_html();
|
||||||
}
|
}
|
||||||
|
|
||||||
return $content;
|
return $content;
|
||||||
|
@ -3137,11 +3137,13 @@ class wpdb {
|
|||||||
} elseif ( ARRAY_A === $output || ARRAY_N === $output ) {
|
} elseif ( ARRAY_A === $output || ARRAY_N === $output ) {
|
||||||
// Return an integer-keyed array of...
|
// Return an integer-keyed array of...
|
||||||
if ( $this->last_result ) {
|
if ( $this->last_result ) {
|
||||||
foreach ( (array) $this->last_result as $row ) {
|
if ( ARRAY_N === $output ) {
|
||||||
if ( ARRAY_N === $output ) {
|
foreach ( (array) $this->last_result as $row ) {
|
||||||
// ...integer-keyed row arrays.
|
// ...integer-keyed row arrays.
|
||||||
$new_array[] = array_values( get_object_vars( $row ) );
|
$new_array[] = array_values( get_object_vars( $row ) );
|
||||||
} else {
|
}
|
||||||
|
} else {
|
||||||
|
foreach ( (array) $this->last_result as $row ) {
|
||||||
// ...column name-keyed row arrays.
|
// ...column name-keyed row arrays.
|
||||||
$new_array[] = get_object_vars( $row );
|
$new_array[] = get_object_vars( $row );
|
||||||
}
|
}
|
||||||
|
@ -16,7 +16,7 @@
|
|||||||
*
|
*
|
||||||
* @global string $wp_version
|
* @global string $wp_version
|
||||||
*/
|
*/
|
||||||
$wp_version = '6.3-alpha-56065';
|
$wp_version = '6.3-alpha-56066';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
* Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.
|
||||||
|
Loading…
Reference in New Issue
Block a user