diff -r 3d4e9c994f10 -r a86126ab1dd4 wp/wp-includes/comment-template.php
--- a/wp/wp-includes/comment-template.php Tue Oct 22 16:11:46 2019 +0200
+++ b/wp/wp-includes/comment-template.php Tue Dec 15 13:49:49 2020 +0100
@@ -9,7 +9,7 @@
*/
/**
- * Retrieve the author of the current comment.
+ * Retrieves the author of the current comment.
*
* If the comment has an empty comment_author field, then 'Anonymous' person is
* assumed.
@@ -25,7 +25,8 @@
$comment = get_comment( $comment_ID );
if ( empty( $comment->comment_author ) ) {
- if ( $comment->user_id && $user = get_userdata( $comment->user_id ) ) {
+ $user = $comment->user_id ? get_userdata( $comment->user_id ) : false;
+ if ( $user ) {
$author = $user->display_name;
} else {
$author = __( 'Anonymous' );
@@ -73,7 +74,7 @@
}
/**
- * Retrieve the email of the author of the current comment.
+ * Retrieves the email of the author of the current comment.
*
* @since 1.5.0
* @since 4.4.0 Added the ability for `$comment_ID` to also accept a WP_Comment object.
@@ -99,7 +100,7 @@
}
/**
- * Display the email of the author of the current global $comment.
+ * Displays the email of the author of the current global $comment.
*
* Care should be taken to protect the email address and assure that email
* harvesters do not capture your commenter's email address. Most assume that
@@ -130,7 +131,7 @@
}
/**
- * Display the html email link to the author of the current comment.
+ * Displays the HTML email link to the author of the current comment.
*
* Care should be taken to protect the email address and assure that email
* harvesters do not capture your commenter's email address. Most assume that
@@ -148,13 +149,14 @@
* @param int|WP_Comment $comment Optional. Comment ID or WP_Comment object. Default is the current comment.
*/
function comment_author_email_link( $linktext = '', $before = '', $after = '', $comment = null ) {
- if ( $link = get_comment_author_email_link( $linktext, $before, $after, $comment ) ) {
+ $link = get_comment_author_email_link( $linktext, $before, $after, $comment );
+ if ( $link ) {
echo $link;
}
}
/**
- * Return the html email link to the author of the current comment.
+ * Returns the HTML email link to the author of the current comment.
*
* Care should be taken to protect the email address and assure that email
* harvesters do not capture your commenter's email address. Most assume that
@@ -190,8 +192,8 @@
*/
$email = apply_filters( 'comment_email', $comment->comment_author_email, $comment );
- if ( ( ! empty( $email ) ) && ( $email != '@' ) ) {
- $display = ( $linktext != '' ) ? $linktext : $email;
+ if ( ( ! empty( $email ) ) && ( '@' !== $email ) ) {
+ $display = ( '' !== $linktext ) ? $linktext : $email;
$return = $before;
$return .= sprintf( '%2$s', esc_url( 'mailto:' . $email ), esc_html( $display ) );
$return .= $after;
@@ -202,7 +204,7 @@
}
/**
- * Retrieve the HTML link to the URL of the author of the current comment.
+ * Retrieves the HTML link to the URL of the author of the current comment.
*
* Both get_comment_author_url() and get_comment_author() rely on get_comment(),
* which falls back to the global comment variable if the $comment_ID argument is empty.
@@ -219,10 +221,10 @@
$url = get_comment_author_url( $comment );
$author = get_comment_author( $comment );
- if ( empty( $url ) || 'http://' == $url ) {
+ if ( empty( $url ) || 'http://' === $url ) {
$return = $author;
} else {
- $return = "$author";
+ $return = "$author";
}
/**
@@ -240,7 +242,7 @@
}
/**
- * Display the html link to the url of the author of the current comment.
+ * Displays the HTML link to the URL of the author of the current comment.
*
* @since 0.71
* @since 4.4.0 Added the ability for `$comment_ID` to also accept a WP_Comment object.
@@ -262,7 +264,7 @@
* Default current comment.
* @return string Comment author's IP address.
*/
-function get_comment_author_IP( $comment_ID = 0 ) {
+function get_comment_author_IP( $comment_ID = 0 ) { // phpcs:ignore WordPress.NamingConventions.ValidFunctionName.FunctionNameInvalid
$comment = get_comment( $comment_ID );
/**
@@ -275,11 +277,11 @@
* @param int $comment_ID The comment ID.
* @param WP_Comment $comment The comment object.
*/
- return apply_filters( 'get_comment_author_IP', $comment->comment_author_IP, $comment->comment_ID, $comment );
+ return apply_filters( 'get_comment_author_IP', $comment->comment_author_IP, $comment->comment_ID, $comment ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.NotLowercase
}
/**
- * Display the IP address of the author of the current comment.
+ * Displays the IP address of the author of the current comment.
*
* @since 0.71
* @since 4.4.0 Added the ability for `$comment_ID` to also accept a WP_Comment object.
@@ -287,26 +289,27 @@
* @param int|WP_Comment $comment_ID Optional. WP_Comment or the ID of the comment for which to print the author's IP address.
* Default current comment.
*/
-function comment_author_IP( $comment_ID = 0 ) {
+function comment_author_IP( $comment_ID = 0 ) { // phpcs:ignore WordPress.NamingConventions.ValidFunctionName.FunctionNameInvalid
echo esc_html( get_comment_author_IP( $comment_ID ) );
}
/**
- * Retrieve the url of the author of the current comment.
+ * Retrieves the URL of the author of the current comment, not linked.
*
* @since 1.5.0
* @since 4.4.0 Added the ability for `$comment_ID` to also accept a WP_Comment object.
*
* @param int|WP_Comment $comment_ID Optional. WP_Comment or the ID of the comment for which to get the author's URL.
* Default current comment.
- * @return string Comment author URL.
+ * @return string Comment author URL, if provided, an empty string otherwise.
*/
function get_comment_author_url( $comment_ID = 0 ) {
$comment = get_comment( $comment_ID );
$url = '';
$id = 0;
+
if ( ! empty( $comment ) ) {
- $author_url = ( 'http://' == $comment->comment_author_url ) ? '' : $comment->comment_author_url;
+ $author_url = ( 'http://' === $comment->comment_author_url ) ? '' : $comment->comment_author_url;
$url = esc_url( $author_url, array( 'http', 'https' ) );
$id = $comment->comment_ID;
}
@@ -325,7 +328,7 @@
}
/**
- * Display the url of the author of the current comment.
+ * Displays the URL of the author of the current comment, not linked.
*
* @since 0.71
* @since 4.4.0 Added the ability for `$comment_ID` to also accept a WP_Comment object.
@@ -350,7 +353,7 @@
}
/**
- * Retrieves the HTML link of the url of the author of the current comment.
+ * Retrieves the HTML link of the URL of the author of the current comment.
*
* $linktext parameter is only used if the URL does not exist for the comment
* author. If the URL does exist then the URL will be used and the $linktext
@@ -374,11 +377,11 @@
*/
function get_comment_author_url_link( $linktext = '', $before = '', $after = '', $comment = 0 ) {
$url = get_comment_author_url( $comment );
- $display = ( $linktext != '' ) ? $linktext : $url;
+ $display = ( '' !== $linktext ) ? $linktext : $url;
$display = str_replace( 'http://www.', '', $display );
$display = str_replace( 'http://', '', $display );
- if ( '/' == substr( $display, -1 ) ) {
+ if ( '/' === substr( $display, -1 ) ) {
$display = substr( $display, 0, -1 );
}
@@ -395,7 +398,7 @@
}
/**
- * Displays the HTML link of the url of the author of the current comment.
+ * Displays the HTML link of the URL of the author of the current comment.
*
* @since 0.71
* @since 4.6.0 Added the `$comment` parameter.
@@ -423,13 +426,14 @@
* Default empty.
* @param int|WP_Comment $comment Comment ID or WP_Comment object. Default current comment.
* @param int|WP_Post $post_id Post ID or WP_Post object. Default current post.
- * @param bool $echo Optional. Whether to cho or return the output.
+ * @param bool $echo Optional. Whether to echo or return the output.
* Default true.
- * @return string If `$echo` is false, the class will be returned. Void otherwise.
+ * @return void|string Void if `$echo` argument is true, comment classes if `$echo` is false.
*/
function comment_class( $class = '', $comment = null, $post_id = null, $echo = true ) {
- // Separates classes with a single space, collates classes for comment DIV
+ // Separates classes with a single space, collates classes for comment DIV.
$class = 'class="' . join( ' ', get_comment_class( $class, $comment, $post_id ) ) . '"';
+
if ( $echo ) {
echo $class;
} else {
@@ -450,7 +454,7 @@
* @param string|array $class Optional. One or more classes to add to the class list. Default empty.
* @param int|WP_Comment $comment_id Comment ID or WP_Comment object. Default current comment.
* @param int|WP_Post $post_id Post ID or WP_Post object. Default current post.
- * @return array An array of classes.
+ * @return string[] An array of classes.
*/
function get_comment_class( $class = '', $comment_id = null, $post_id = null ) {
global $comment_alt, $comment_depth, $comment_thread_alt;
@@ -462,15 +466,17 @@
return $classes;
}
- // Get the comment type (comment, trackback),
+ // Get the comment type (comment, trackback).
$classes[] = ( empty( $comment->comment_type ) ) ? 'comment' : $comment->comment_type;
// Add classes for comment authors that are registered users.
- if ( $comment->user_id > 0 && $user = get_userdata( $comment->user_id ) ) {
+ $user = $comment->user_id ? get_userdata( $comment->user_id ) : false;
+ if ( $user ) {
$classes[] = 'byuser';
$classes[] = 'comment-author-' . sanitize_html_class( $user->user_nicename, $comment->user_id );
- // For comment authors who are the author of the post
- if ( $post = get_post( $post_id ) ) {
+ // For comment authors who are the author of the post.
+ $post = get_post( $post_id );
+ if ( $post ) {
if ( $comment->user_id === $post->post_author ) {
$classes[] = 'bypostauthor';
}
@@ -496,7 +502,7 @@
$comment_alt++;
- // Alt for top-level comments
+ // Alt for top-level comments.
if ( 1 == $comment_depth ) {
if ( $comment_thread_alt % 2 ) {
$classes[] = 'thread-odd';
@@ -525,7 +531,7 @@
*
* @param string[] $classes An array of comment classes.
* @param string $class A comma-separated list of additional classes added to the list.
- * @param int $comment_id The comment id.
+ * @param int $comment_id The comment ID.
* @param WP_Comment $comment The comment object.
* @param int|WP_Post $post_id The post ID or WP_Post object.
*/
@@ -533,86 +539,84 @@
}
/**
- * Retrieve the comment date of the current comment.
+ * Retrieves the comment date of the current comment.
*
* @since 1.5.0
* @since 4.4.0 Added the ability for `$comment_ID` to also accept a WP_Comment object.
*
- * @param string $d Optional. The format of the date. Default user's setting.
- * @param int|WP_Comment $comment_ID WP_Comment or ID of the comment for which to get the date.
- * Default current comment.
+ * @param string $format Optional. The format of the date. Default user's setting.
+ * @param int|WP_Comment $comment_ID WP_Comment or ID of the comment for which to get the date.
+ * Default current comment.
* @return string The comment's date.
*/
-function get_comment_date( $d = '', $comment_ID = 0 ) {
+function get_comment_date( $format = '', $comment_ID = 0 ) {
$comment = get_comment( $comment_ID );
- if ( '' == $d ) {
- $date = mysql2date( get_option( 'date_format' ), $comment->comment_date );
- } else {
- $date = mysql2date( $d, $comment->comment_date );
- }
+
+ $_format = ! empty( $format ) ? $format : get_option( 'date_format' );
+
+ $date = mysql2date( $_format, $comment->comment_date );
+
/**
* Filters the returned comment date.
*
* @since 1.5.0
*
* @param string|int $date Formatted date string or Unix timestamp.
- * @param string $d The format of the date.
+ * @param string $format The format of the date.
* @param WP_Comment $comment The comment object.
*/
- return apply_filters( 'get_comment_date', $date, $d, $comment );
+ return apply_filters( 'get_comment_date', $date, $format, $comment );
}
/**
- * Display the comment date of the current comment.
+ * Displays the comment date of the current comment.
*
* @since 0.71
* @since 4.4.0 Added the ability for `$comment_ID` to also accept a WP_Comment object.
*
- * @param string $d Optional. The format of the date. Default user's settings.
+ * @param string $format Optional. The format of the date. Default user's settings.
* @param int|WP_Comment $comment_ID WP_Comment or ID of the comment for which to print the date.
* Default current comment.
*/
-function comment_date( $d = '', $comment_ID = 0 ) {
- echo get_comment_date( $d, $comment_ID );
+function comment_date( $format = '', $comment_ID = 0 ) {
+ echo get_comment_date( $format, $comment_ID );
}
/**
- * Retrieve the excerpt of the current comment.
+ * Retrieves the excerpt of the given comment.
*
- * Will cut each word and only output the first 20 words with '…' at the end.
- * If the word count is less than 20, then no truncating is done and no '…'
- * will appear.
+ * Returns a maximum of 20 words with an ellipsis appended if necessary.
*
* @since 1.5.0
* @since 4.4.0 Added the ability for `$comment_ID` to also accept a WP_Comment object.
*
* @param int|WP_Comment $comment_ID WP_Comment or ID of the comment for which to get the excerpt.
* Default current comment.
- * @return string The maybe truncated comment with 20 words or less.
+ * @return string The possibly truncated comment excerpt.
*/
function get_comment_excerpt( $comment_ID = 0 ) {
- $comment = get_comment( $comment_ID );
- $comment_text = strip_tags( str_replace( array( "\n", "\r" ), ' ', $comment->comment_content ) );
- $words = explode( ' ', $comment_text );
+ $comment = get_comment( $comment_ID );
+
+ if ( ! post_password_required( $comment->comment_post_ID ) ) {
+ $comment_text = strip_tags( str_replace( array( "\n", "\r" ), ' ', $comment->comment_content ) );
+ } else {
+ $comment_text = __( 'Password protected' );
+ }
+
+ /* translators: Maximum number of words used in a comment excerpt. */
+ $comment_excerpt_length = intval( _x( '20', 'comment_excerpt_length' ) );
/**
- * Filters the amount of words used in the comment excerpt.
+ * Filters the maximum number of words used in the comment excerpt.
*
* @since 4.4.0
*
* @param int $comment_excerpt_length The amount of words you want to display in the comment excerpt.
*/
- $comment_excerpt_length = apply_filters( 'comment_excerpt_length', 20 );
+ $comment_excerpt_length = apply_filters( 'comment_excerpt_length', $comment_excerpt_length );
- $use_ellipsis = count( $words ) > $comment_excerpt_length;
- if ( $use_ellipsis ) {
- $words = array_slice( $words, 0, $comment_excerpt_length );
- }
+ $excerpt = wp_trim_words( $comment_text, $comment_excerpt_length, '…' );
- $excerpt = trim( join( ' ', $words ) );
- if ( $use_ellipsis ) {
- $excerpt .= '…';
- }
/**
* Filters the retrieved comment excerpt.
*
@@ -627,7 +631,7 @@
}
/**
- * Display the excerpt of the current comment.
+ * Displays the excerpt of the current comment.
*
* @since 1.2.0
* @since 4.4.0 Added the ability for `$comment_ID` to also accept a WP_Comment object.
@@ -652,13 +656,13 @@
}
/**
- * Retrieve the comment id of the current comment.
+ * Retrieves the comment ID of the current comment.
*
* @since 1.5.0
*
* @return int The comment ID.
*/
-function get_comment_ID() {
+function get_comment_ID() { // phpcs:ignore WordPress.NamingConventions.ValidFunctionName.FunctionNameInvalid
$comment = get_comment();
/**
@@ -670,27 +674,27 @@
* @param int $comment_ID The current comment ID.
* @param WP_Comment $comment The comment object.
*/
- return apply_filters( 'get_comment_ID', $comment->comment_ID, $comment );
+ return apply_filters( 'get_comment_ID', $comment->comment_ID, $comment ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.NotLowercase
}
/**
- * Display the comment id of the current comment.
+ * Displays the comment ID of the current comment.
*
* @since 0.71
*/
-function comment_ID() {
+function comment_ID() { // phpcs:ignore WordPress.NamingConventions.ValidFunctionName.FunctionNameInvalid
echo get_comment_ID();
}
/**
- * Retrieve the link to a given comment.
+ * Retrieves the link to a given comment.
*
* @since 1.5.0
* @since 4.4.0 Added the ability for `$comment` to also accept a WP_Comment object. Added `$cpage` argument.
*
* @see get_page_of_comment()
*
- * @global WP_Rewrite $wp_rewrite
+ * @global WP_Rewrite $wp_rewrite WordPress rewrite component.
* @global bool $in_comment_loop
*
* @param WP_Comment|int|null $comment Comment to retrieve. Default current comment.
@@ -821,7 +825,7 @@
}
/**
- * Display the link to the current post comments.
+ * Displays the link to the current post comments.
*
* @since 0.71
*
@@ -869,51 +873,53 @@
}
/**
- * Display the language string for the number of comments the current post has.
+ * Displays the language string for the number of comments the current post has.
*
* @since 0.71
+ * @since 5.4.0 The `$deprecated` parameter was changed to `$post_id`.
*
- * @param string $zero Optional. Text for no comments. Default false.
- * @param string $one Optional. Text for one comment. Default false.
- * @param string $more Optional. Text for more than one comment. Default false.
- * @param string $deprecated Not used.
+ * @param string $zero Optional. Text for no comments. Default false.
+ * @param string $one Optional. Text for one comment. Default false.
+ * @param string $more Optional. Text for more than one comment. Default false.
+ * @param int|WP_Post $post_id Optional. Post ID or WP_Post object. Default is the global `$post`.
*/
-function comments_number( $zero = false, $one = false, $more = false, $deprecated = '' ) {
- if ( ! empty( $deprecated ) ) {
- _deprecated_argument( __FUNCTION__, '1.3.0' );
- }
- echo get_comments_number_text( $zero, $one, $more );
+function comments_number( $zero = false, $one = false, $more = false, $post_id = 0 ) {
+ echo get_comments_number_text( $zero, $one, $more, $post_id );
}
/**
- * Display the language string for the number of comments the current post has.
+ * Displays the language string for the number of comments the current post has.
*
* @since 4.0.0
+ * @since 5.4.0 Added the `$post_id` parameter to allow using the function outside of the loop.
*
- * @param string $zero Optional. Text for no comments. Default false.
- * @param string $one Optional. Text for one comment. Default false.
- * @param string $more Optional. Text for more than one comment. Default false.
+ * @param string $zero Optional. Text for no comments. Default false.
+ * @param string $one Optional. Text for one comment. Default false.
+ * @param string $more Optional. Text for more than one comment. Default false.
+ * @param int|WP_Post $post_id Optional. Post ID or WP_Post object. Default is the global `$post`.
+ * @return string Language string for the number of comments a post has.
*/
-function get_comments_number_text( $zero = false, $one = false, $more = false ) {
- $number = get_comments_number();
+function get_comments_number_text( $zero = false, $one = false, $more = false, $post_id = 0 ) {
+ $number = get_comments_number( $post_id );
if ( $number > 1 ) {
if ( false === $more ) {
- /* translators: %s: number of comments */
+ /* translators: %s: Number of comments. */
$output = sprintf( _n( '%s Comment', '%s Comments', $number ), number_format_i18n( $number ) );
} else {
// % Comments
- /* translators: If comment number in your language requires declension,
+ /*
+ * translators: If comment number in your language requires declension,
* translate this to 'on'. Do not translate into your own language.
*/
if ( 'on' === _x( 'off', 'Comment number declension: on or off' ) ) {
$text = preg_replace( '#.+?#', '', $more );
- $text = preg_replace( '/&.+?;/', '', $text ); // Kill entities
+ $text = preg_replace( '/&.+?;/', '', $text ); // Kill entities.
$text = trim( strip_tags( $text ), '% ' );
- // Replace '% Comments' with a proper plural form
+ // Replace '% Comments' with a proper plural form.
if ( $text && ! preg_match( '/[0-9]+/', $text ) && false !== strpos( $more, '%' ) ) {
- /* translators: %s: number of comments */
+ /* translators: %s: Number of comments. */
$new_text = _n( '%s Comment', '%s Comments', $number );
$new_text = trim( sprintf( $new_text, '' ) );
@@ -926,9 +932,9 @@
$output = str_replace( '%', number_format_i18n( $number ), $more );
}
- } elseif ( $number == 0 ) {
+ } elseif ( 0 == $number ) {
$output = ( false === $zero ) ? __( 'No Comments' ) : $zero;
- } else { // must be one
+ } else { // Must be one.
$output = ( false === $one ) ? __( '1 Comment' ) : $one;
}
/**
@@ -946,21 +952,38 @@
}
/**
- * Retrieve the text of the current comment.
+ * Retrieves the text of the current comment.
*
* @since 1.5.0
* @since 4.4.0 Added the ability for `$comment_ID` to also accept a WP_Comment object.
+ * @since 5.4.0 Added 'In reply to %s.' prefix to child comments in comments feed.
*
* @see Walker_Comment::comment()
*
- * @param int|WP_Comment $comment_ID WP_Comment or ID of the comment for which to get the text.
- * Default current comment.
- * @param array $args Optional. An array of arguments. Default empty.
+ * @param int|WP_Comment $comment_ID WP_Comment or ID of the comment for which to get the text.
+ * Default current comment.
+ * @param array $args Optional. An array of arguments. Default empty array.
* @return string The comment content.
*/
function get_comment_text( $comment_ID = 0, $args = array() ) {
$comment = get_comment( $comment_ID );
+ $comment_content = $comment->comment_content;
+
+ if ( is_comment_feed() && $comment->comment_parent ) {
+ $parent = get_comment( $comment->comment_parent );
+ if ( $parent ) {
+ $parent_link = esc_url( get_comment_link( $parent ) );
+ $name = get_comment_author( $parent );
+
+ $comment_content = sprintf(
+ /* translators: %s: Comment link. */
+ ent2ncr( __( 'In reply to %s.' ) ),
+ '' . $name . ''
+ ) . "\n\n" . $comment_content;
+ }
+ }
+
/**
* Filters the text of a comment.
*
@@ -972,20 +995,20 @@
* @param WP_Comment $comment The comment object.
* @param array $args An array of arguments.
*/
- return apply_filters( 'get_comment_text', $comment->comment_content, $comment, $args );
+ return apply_filters( 'get_comment_text', $comment_content, $comment, $args );
}
/**
- * Display the text of the current comment.
+ * Displays the text of the current comment.
*
* @since 0.71
* @since 4.4.0 Added the ability for `$comment_ID` to also accept a WP_Comment object.
*
* @see Walker_Comment::comment()
*
- * @param int|WP_Comment $comment_ID WP_Comment or ID of the comment for which to print the text.
- * Default current comment.
- * @param array $args Optional. An array of arguments. Default empty array. Default empty.
+ * @param int|WP_Comment $comment_ID WP_Comment or ID of the comment for which to print the text.
+ * Default current comment.
+ * @param array $args Optional. An array of arguments. Default empty array.
*/
function comment_text( $comment_ID = 0, $args = array() ) {
$comment = get_comment( $comment_ID );
@@ -999,32 +1022,31 @@
* @see Walker_Comment::comment()
*
* @param string $comment_text Text of the current comment.
- * @param WP_Comment|null $comment The comment object.
+ * @param WP_Comment|null $comment The comment object. Null if not found.
* @param array $args An array of arguments.
*/
echo apply_filters( 'comment_text', $comment_text, $comment, $args );
}
/**
- * Retrieve the comment time of the current comment.
+ * Retrieves the comment time of the current comment.
*
* @since 1.5.0
*
- * @param string $d Optional. The format of the time. Default user's settings.
+ * @param string $format Optional. The format of the time. Default user's settings.
* @param bool $gmt Optional. Whether to use the GMT date. Default false.
* @param bool $translate Optional. Whether to translate the time (for use in feeds).
* Default true.
* @return string The formatted time.
*/
-function get_comment_time( $d = '', $gmt = false, $translate = true ) {
+function get_comment_time( $format = '', $gmt = false, $translate = true ) {
$comment = get_comment();
$comment_date = $gmt ? $comment->comment_date_gmt : $comment->comment_date;
- if ( '' == $d ) {
- $date = mysql2date( get_option( 'time_format' ), $comment_date, $translate );
- } else {
- $date = mysql2date( $d, $comment_date, $translate );
- }
+
+ $_format = ! empty( $format ) ? $format : get_option( 'time_format' );
+
+ $date = mysql2date( $_format, $comment_date, $translate );
/**
* Filters the returned comment time.
@@ -1032,27 +1054,27 @@
* @since 1.5.0
*
* @param string|int $date The comment time, formatted as a date string or Unix timestamp.
- * @param string $d Date format.
+ * @param string $format Date format.
* @param bool $gmt Whether the GMT date is in use.
* @param bool $translate Whether the time is translated.
* @param WP_Comment $comment The comment object.
*/
- return apply_filters( 'get_comment_time', $date, $d, $gmt, $translate, $comment );
+ return apply_filters( 'get_comment_time', $date, $format, $gmt, $translate, $comment );
}
/**
- * Display the comment time of the current comment.
+ * Displays the comment time of the current comment.
*
* @since 0.71
*
- * @param string $d Optional. The format of the time. Default user's settings.
+ * @param string $format Optional. The format of the time. Default user's settings.
*/
-function comment_time( $d = '' ) {
- echo get_comment_time( $d );
+function comment_time( $format = '' ) {
+ echo get_comment_time( $format );
}
/**
- * Retrieve the comment type of the current comment.
+ * Retrieves the comment type of the current comment.
*
* @since 1.5.0
* @since 4.4.0 Added the ability for `$comment_ID` to also accept a WP_Comment object.
@@ -1063,7 +1085,8 @@
*/
function get_comment_type( $comment_ID = 0 ) {
$comment = get_comment( $comment_ID );
- if ( '' == $comment->comment_type ) {
+
+ if ( '' === $comment->comment_type ) {
$comment->comment_type = 'comment';
}
@@ -1081,7 +1104,7 @@
}
/**
- * Display the comment type of the current comment.
+ * Displays the comment type of the current comment.
*
* @since 0.71
*
@@ -1113,7 +1136,7 @@
}
/**
- * Retrieve The current post's trackback URL.
+ * Retrieves the current post's trackback URL.
*
* There is a check to see if permalink's have been enabled and if so, will
* retrieve the pretty path. If permalinks weren't enabled, the ID of the
@@ -1124,7 +1147,7 @@
* @return string The trackback URL after being filtered.
*/
function get_trackback_url() {
- if ( '' != get_option( 'permalink_structure' ) ) {
+ if ( get_option( 'permalink_structure' ) ) {
$tb_url = trailingslashit( get_permalink() ) . user_trailingslashit( 'trackback', 'single_trackback' );
} else {
$tb_url = get_option( 'siteurl' ) . '/wp-trackback.php?p=' . get_the_ID();
@@ -1141,7 +1164,7 @@
}
/**
- * Display the current post's trackback URL.
+ * Displays the current post's trackback URL.
*
* @since 0.71
*
@@ -1154,8 +1177,8 @@
_deprecated_argument(
__FUNCTION__,
'2.5.0',
- /* translators: %s: get_trackback_url() */
sprintf(
+ /* translators: %s: get_trackback_url() */
__( 'Use %s instead if you do not want the value echoed.' ),
'get_trackback_url()
'
)
@@ -1170,7 +1193,7 @@
}
/**
- * Generate and display the RDF for the trackback information of current post.
+ * Generates and displays the RDF for the trackback information of current post.
*
* Deprecated in 3.0.0, and restored in 3.0.1.
*
@@ -1218,7 +1241,7 @@
$_post = get_post( $post_id );
$post_id = $_post ? $_post->ID : 0;
- $open = ( 'open' == $_post->comment_status );
+ $open = ( 'open' === $_post->comment_status );
/**
* Filters whether the current post is open for comments.
@@ -1248,7 +1271,7 @@
$_post = get_post( $post_id );
$post_id = $_post ? $_post->ID : 0;
- $open = ( 'open' == $_post->ping_status );
+ $open = ( 'open' === $_post->ping_status );
/**
* Filters whether the current post is open for pings.
@@ -1262,7 +1285,7 @@
}
/**
- * Display form token for unfiltered comments.
+ * Displays form token for unfiltered comments.
*
* Will only display nonce token if the current user has permissions for
* unfiltered html. Won't display the token for other users.
@@ -1286,7 +1309,7 @@
}
/**
- * Load the comment template specified in $file.
+ * Loads the comment template specified in $file.
*
* Will not display the comments template if not on single post or page, or if
* the post does not have comments.
@@ -1305,13 +1328,12 @@
*
* @since 1.5.0
*
- * @global WP_Query $wp_query
- * @global WP_Post $post
- * @global wpdb $wpdb
+ * @global WP_Query $wp_query WordPress Query object.
+ * @global WP_Post $post Global post object.
+ * @global wpdb $wpdb WordPress database abstraction object.
* @global int $id
- * @global WP_Comment $comment
+ * @global WP_Comment $comment Global comment object.
* @global string $user_login
- * @global int $user_ID
* @global string $user_identity
* @global bool $overridden_cpage
* @global bool $withcomments
@@ -1321,7 +1343,7 @@
* Default false.
*/
function comments_template( $file = '/comments.php', $separate_comments = false ) {
- global $wp_query, $withcomments, $post, $wpdb, $id, $comment, $user_login, $user_ID, $user_identity, $overridden_cpage;
+ global $wp_query, $withcomments, $post, $wpdb, $id, $comment, $user_login, $user_identity, $overridden_cpage;
if ( ! ( is_single() || is_page() || $withcomments ) || empty( $post ) ) {
return;
@@ -1351,7 +1373,7 @@
$comment_author_email = $commenter['comment_author_email'];
/*
- * The url of the current comment author escaped for use in attributes.
+ * The URL of the current comment author escaped for use in attributes.
*/
$comment_author_url = esc_url( $commenter['comment_author_url'] );
@@ -1370,8 +1392,8 @@
$comment_args['hierarchical'] = false;
}
- if ( $user_ID ) {
- $comment_args['include_unapproved'] = array( $user_ID );
+ if ( is_user_logged_in() ) {
+ $comment_args['include_unapproved'] = array( get_current_user_id() );
} else {
$unapproved_email = wp_get_unapproved_comment_author_email();
@@ -1488,8 +1510,9 @@
}
$overridden_cpage = false;
+
if ( '' == get_query_var( 'cpage' ) && $wp_query->max_num_comment_pages > 1 ) {
- set_query_var( 'cpage', 'newest' == get_option( 'default_comments_page' ) ? get_comment_pages_count() : 1 );
+ set_query_var( 'cpage', 'newest' === get_option( 'default_comments_page' ) ? get_comment_pages_count() : 1 );
$overridden_cpage = true;
}
@@ -1498,6 +1521,7 @@
}
$theme_template = STYLESHEETPATH . $file;
+
/**
* Filters the path to the theme template file used for the comments template.
*
@@ -1506,12 +1530,13 @@
* @param string $theme_template The path to the theme template file.
*/
$include = apply_filters( 'comments_template', $theme_template );
+
if ( file_exists( $include ) ) {
- require( $include );
+ require $include;
} elseif ( file_exists( TEMPLATEPATH . $file ) ) {
- require( TEMPLATEPATH . $file );
- } else { // Backward compat code will be removed in a future release
- require( ABSPATH . WPINC . '/theme-compat/comments.php' );
+ require TEMPLATEPATH . $file;
+ } else { // Backward compat code will be removed in a future release.
+ require ABSPATH . WPINC . '/theme-compat/comments.php';
}
}
@@ -1527,29 +1552,29 @@
* @param false|string $none Optional. String to display when comments have been turned off. Default false.
*/
function comments_popup_link( $zero = false, $one = false, $more = false, $css_class = '', $none = false ) {
- $id = get_the_ID();
- $title = get_the_title();
- $number = get_comments_number( $id );
+ $post_id = get_the_ID();
+ $post_title = get_the_title();
+ $number = get_comments_number( $post_id );
if ( false === $zero ) {
- /* translators: %s: post title */
- $zero = sprintf( __( 'No Comments on %s' ), $title );
+ /* translators: %s: Post title. */
+ $zero = sprintf( __( 'No Comments on %s' ), $post_title );
}
if ( false === $one ) {
- /* translators: %s: post title */
- $one = sprintf( __( '1 Comment on %s' ), $title );
+ /* translators: %s: Post title. */
+ $one = sprintf( __( '1 Comment on %s' ), $post_title );
}
if ( false === $more ) {
- /* translators: 1: number of comments, 2: post title */
+ /* translators: 1: Number of comments, 2: Post title. */
$more = _n( '%1$s Comment on %2$s', '%1$s Comments on %2$s', $number );
- $more = sprintf( $more, number_format_i18n( $number ), $title );
+ $more = sprintf( $more, number_format_i18n( $number ), $post_title );
}
if ( false === $none ) {
- /* translators: %s: post title */
- $none = sprintf( __( 'Comments Off on %s' ), $title );
+ /* translators: %s: Post title. */
+ $none = sprintf( __( 'Comments Off on %s' ), $post_title );
}
if ( 0 == $number && ! comments_open() && ! pings_open() ) {
@@ -1571,9 +1596,9 @@
* @since 4.4.0
*
* @param string $respond_link The default response link.
- * @param integer $id The post ID.
+ * @param int $post_id The post ID.
*/
- echo apply_filters( 'respond_link', $respond_link, $id );
+ echo apply_filters( 'respond_link', $respond_link, $post_id );
} else {
comments_link();
}
@@ -1599,12 +1624,12 @@
}
/**
- * Retrieve HTML content for reply to comment link.
+ * Retrieves HTML content for reply to comment link.
*
* @since 2.7.0
* @since 4.4.0 Added the ability for `$comment` to also accept a WP_Comment object.
*
- * @param array $args {
+ * @param array $args {
* Optional. Override default arguments.
*
* @type string $add_below The first part of the selector used to identify the comment to respond below.
@@ -1624,14 +1649,14 @@
* @param int|WP_Comment $comment Comment being replied to. Default current comment.
* @param int|WP_Post $post Post ID or WP_Post object the comment is going to be displayed on.
* Default current post.
- * @return void|false|string Link to show comment form, if successful. False, if comments are closed.
+ * @return string|false|null Link to show comment form, if successful. False, if comments are closed.
*/
function get_comment_reply_link( $args = array(), $comment = null, $post = null ) {
$defaults = array(
'add_below' => 'comment',
'respond_id' => 'respond',
'reply_text' => __( 'Reply' ),
- /* translators: Comment reply button text. %s: Comment author name */
+ /* translators: Comment reply button text. %s: Comment author name. */
'reply_to_text' => __( 'Reply to %s' ),
'login_text' => __( 'Log in to Reply' ),
'max_depth' => 0,
@@ -1648,6 +1673,10 @@
$comment = get_comment( $comment );
+ if ( empty( $comment ) ) {
+ return;
+ }
+
if ( empty( $post ) ) {
$post = $comment->comment_post_ID;
}
@@ -1682,6 +1711,7 @@
'postid' => $post->ID,
'belowelement' => $args['add_below'] . '-' . $comment->comment_ID,
'respondelement' => $args['respond_id'],
+ 'replyto' => sprintf( $args['reply_to_text'], $comment->comment_author ),
);
$data_attribute_string = '';
@@ -1700,7 +1730,8 @@
'replytocom' => $comment->comment_ID,
'unapproved' => false,
'moderation-hash' => false,
- )
+ ),
+ get_permalink( $post->ID )
)
) . '#' . $args['respond_id'],
$data_attribute_string,
@@ -1714,10 +1745,10 @@
*
* @since 2.7.0
*
- * @param string $link The HTML markup for the comment reply link.
- * @param array $args An array of arguments overriding the defaults.
- * @param object $comment The object of the comment being replied.
- * @param WP_Post $post The WP_Post object.
+ * @param string $link The HTML markup for the comment reply link.
+ * @param array $args An array of arguments overriding the defaults.
+ * @param WP_Comment $comment The object of the comment being replied.
+ * @param WP_Post $post The WP_Post object.
*/
return apply_filters( 'comment_reply_link', $args['before'] . $link . $args['after'], $args, $comment, $post );
}
@@ -1729,22 +1760,21 @@
*
* @see get_comment_reply_link()
*
- * @param array $args Optional. Override default options.
- * @param int $comment Comment being replied to. Default current comment.
- * @param int|WP_Post $post Post ID or WP_Post object the comment is going to be displayed on.
- * Default current post.
- * @return mixed Link to show comment form, if successful. False, if comments are closed.
+ * @param array $args Optional. Override default options. Default empty array.
+ * @param int|WP_Comment $comment Comment being replied to. Default current comment.
+ * @param int|WP_Post $post Post ID or WP_Post object the comment is going to be displayed on.
+ * Default current post.
*/
function comment_reply_link( $args = array(), $comment = null, $post = null ) {
echo get_comment_reply_link( $args, $comment, $post );
}
/**
- * Retrieve HTML content for reply to post link.
+ * Retrieves HTML content for reply to post link.
*
* @since 2.7.0
*
- * @param array $args {
+ * @param array $args {
* Optional. Override default arguments.
*
* @type string $add_below The first part of the selector used to identify the comment to respond below.
@@ -1760,7 +1790,7 @@
* }
* @param int|WP_Post $post Optional. Post ID or WP_Post object the comment is going to be displayed on.
* Default current post.
- * @return false|null|string Link to show comment form, if successful. False, if comments are closed.
+ * @return string|false|null Link to show comment form, if successful. False, if comments are closed.
*/
function get_post_reply_link( $args = array(), $post = null ) {
$defaults = array(
@@ -1821,21 +1851,21 @@
*
* @see get_post_reply_link()
*
- * @param array $args Optional. Override default options,
+ * @param array $args Optional. Override default options. Default empty array.
* @param int|WP_Post $post Post ID or WP_Post object the comment is going to be displayed on.
* Default current post.
- * @return string|bool|null Link to show comment form, if successful. False, if comments are closed.
*/
function post_reply_link( $args = array(), $post = null ) {
echo get_post_reply_link( $args, $post );
}
/**
- * Retrieve HTML content for cancel comment reply link.
+ * Retrieves HTML content for cancel comment reply link.
*
* @since 2.7.0
*
- * @param string $text Optional. Text to display for cancel reply link. Default empty.
+ * @param string $text Optional. Text to display for cancel reply link. If empty,
+ * defaults to 'Click here to cancel reply'. Default empty.
* @return string
*/
function get_cancel_comment_reply_link( $text = '' ) {
@@ -1861,58 +1891,66 @@
}
/**
- * Display HTML content for cancel comment reply link.
+ * Displays HTML content for cancel comment reply link.
*
* @since 2.7.0
*
- * @param string $text Optional. Text to display for cancel reply link. Default empty.
+ * @param string $text Optional. Text to display for cancel reply link. If empty,
+ * defaults to 'Click here to cancel reply'. Default empty.
*/
function cancel_comment_reply_link( $text = '' ) {
echo get_cancel_comment_reply_link( $text );
}
/**
- * Retrieve hidden input HTML for replying to comments.
+ * Retrieves hidden input HTML for replying to comments.
*
* @since 3.0.0
*
- * @param int $id Optional. Post ID. Default current post ID.
- * @return string Hidden input HTML for replying to comments
+ * @param int $post_id Optional. Post ID. Defaults to the current post ID.
+ * @return string Hidden input HTML for replying to comments.
*/
-function get_comment_id_fields( $id = 0 ) {
- if ( empty( $id ) ) {
- $id = get_the_ID();
+function get_comment_id_fields( $post_id = 0 ) {
+ if ( empty( $post_id ) ) {
+ $post_id = get_the_ID();
}
- $replytoid = isset( $_GET['replytocom'] ) ? (int) $_GET['replytocom'] : 0;
- $result = "\n";
- $result .= "\n";
+ $reply_to_id = isset( $_GET['replytocom'] ) ? (int) $_GET['replytocom'] : 0;
+ $result = "\n";
+ $result .= "\n";
/**
- * Filters the returned comment id fields.
+ * Filters the returned comment ID fields.
*
* @since 3.0.0
*
- * @param string $result The HTML-formatted hidden id field comment elements.
- * @param int $id The post ID.
- * @param int $replytoid The id of the comment being replied to.
+ * @param string $result The HTML-formatted hidden ID field comment elements.
+ * @param int $post_id The post ID.
+ * @param int $reply_to_id The ID of the comment being replied to.
*/
- return apply_filters( 'comment_id_fields', $result, $id, $replytoid );
+ return apply_filters( 'comment_id_fields', $result, $post_id, $reply_to_id );
}
/**
- * Output hidden input HTML for replying to comments.
+ * Outputs hidden input HTML for replying to comments.
+ *
+ * Adds two hidden inputs to the comment form to identify the `comment_post_ID`
+ * and `comment_parent` values for threaded comments.
+ *
+ * This tag must be within the `