From 3c16bdc5389d011ea6153e940bb07037503ddd94 Mon Sep 17 00:00:00 2001 From: Sergey Biryukov Date: Thu, 23 May 2019 00:38:52 +0000 Subject: [PATCH] Date/Time: Return early from `the_weekday()` and `the_weekday_date()` if we're not in the loop. Restore `$previousweekday` global usage in `the_weekday_date()`, so it could still be used simultaneously with `the_date()`. Partially reverts [45378]. See #47354. Built from https://develop.svn.wordpress.org/trunk@45379 git-svn-id: http://core.svn.wordpress.org/trunk@45190 1a063a9b-81f0-0310-95a4-ce76da25c4cd --- wp-includes/general-template.php | 28 ++++++++++++++++++++-------- wp-includes/version.php | 2 +- 2 files changed, 21 insertions(+), 9 deletions(-) diff --git a/wp-includes/general-template.php b/wp-includes/general-template.php index e88713425b..be46abad25 100644 --- a/wp-includes/general-template.php +++ b/wp-includes/general-template.php @@ -2682,7 +2682,13 @@ function get_post_modified_time( $d = 'U', $gmt = false, $post = null, $translat function the_weekday() { global $wp_locale; - $the_weekday = $wp_locale->get_weekday( mysql2date( 'w', get_post()->post_date, false ) ); + $post = get_post(); + + if ( ! $post ) { + return; + } + + $the_weekday = $wp_locale->get_weekday( get_post_time( 'w', false, $post ) ); /** * Filters the weekday on which the post was written, for display. @@ -2702,23 +2708,29 @@ function the_weekday() { * * @since 0.71 * - * @global WP_Locale $wp_locale The WordPress date and time locale object. - * @global string $currentday The day of the current post in the loop. - * @global string $previousday The day of the previous post in the loop. + * @global WP_Locale $wp_locale The WordPress date and time locale object. + * @global string $currentday The day of the current post in the loop. + * @global string $previousweekday The day of the previous post in the loop. * * @param string $before Optional. Output before the date. * @param string $after Optional. Output after the date. */ function the_weekday_date( $before = '', $after = '' ) { - global $wp_locale, $currentday, $previousday; + global $wp_locale, $currentday, $previousweekday; + + $post = get_post(); + + if ( ! $post ) { + return; + } $the_weekday_date = ''; - if ( is_new_day() ) { + if ( $currentday !== $previousweekday ) { $the_weekday_date .= $before; - $the_weekday_date .= $wp_locale->get_weekday( mysql2date( 'w', get_post()->post_date, false ) ); + $the_weekday_date .= $wp_locale->get_weekday( get_post_time( 'w', false, $post ) ); $the_weekday_date .= $after; - $previousday = $currentday; + $previousweekday = $currentday; } /** diff --git a/wp-includes/version.php b/wp-includes/version.php index 6498d504a1..507069b613 100644 --- a/wp-includes/version.php +++ b/wp-includes/version.php @@ -13,7 +13,7 @@ * * @global string $wp_version */ -$wp_version = '5.3-alpha-45378'; +$wp_version = '5.3-alpha-45379'; /** * Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.