Add inline documentation for properties and other inline docs fixes for `WP_Adjacent_Post`.

See #26937.

Built from https://develop.svn.wordpress.org/trunk@27291


git-svn-id: http://core.svn.wordpress.org/trunk@27147 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
Drew Jaynes 2014-02-26 18:16:14 +00:00
parent d30ab62e44
commit cf4131f7ad
1 changed files with 66 additions and 14 deletions

View File

@ -1148,16 +1148,61 @@ function get_adjacent_post( $in_same_term = false, $excluded_terms = '', $previo
* WordPress Adjacent Post API * WordPress Adjacent Post API
* *
* Based on the current or specified post, determines either the previous or * Based on the current or specified post, determines either the previous or
* next post based on the criteria specified. Supports retrieving posts with the * next post based on the criteria specified. Supports retrieving posts with
* same taxonomy terms and posts that lack specific terms. * the same taxonomy terms and posts that lack specific terms.
*
* @since 3.9.0
*
* @package WordPress
* @subpackage Template
*/ */
class WP_Adjacent_Post { class WP_Adjacent_Post {
/**
* Adjacent post object.
*
* @since 3.9.0
* @access public
* @var null|WP_Adjacent_Post
*/
public $adjacent_post = null; public $adjacent_post = null;
/**
* Current post object.
*
* @since 3.9.0
* @access protected
* @var bool|WP_Post
*/
protected $current_post = false; protected $current_post = false;
/**
* 'previous' or 'next' type of adjacent post.
*
* @since 3.9.0
* @access protected
* @var string
*/
protected $adjacent = 'previous'; protected $adjacent = 'previous';
protected $taxonomy = 'category'; protected $taxonomy = 'category';
/**
* Whether the post should be in a same taxonomy term.
*
* @since 3.9.0
* @access protected
* @var string
*/
protected $in_same_term = false; protected $in_same_term = false;
/**
* Excluded term IDs.
*
* @since 3.9.0
* @access protected
* @var string|array
*/
protected $excluded_terms = ''; protected $excluded_terms = '';
/** /**
@ -1179,7 +1224,7 @@ class WP_Adjacent_Post {
/** /**
* Allow direct access to adjacent post from the class instance itself * Allow direct access to adjacent post from the class instance itself
* *
* @param string $property * @param string $property Property to get.
* @return mixed String when adjacent post is found and post property exists. Null when no adjacent post is found. * @return mixed String when adjacent post is found and post property exists. Null when no adjacent post is found.
*/ */
public function __get( $property ) { public function __get( $property ) {
@ -1312,26 +1357,29 @@ class WP_Adjacent_Post {
* Apply the deprecated filters to WP_Query's clauses. * Apply the deprecated filters to WP_Query's clauses.
* *
* @param array $clauses * @param array $clauses
* @uses $this->filter_join_and_where()
* @uses $this->filter_sort()
* @filter post_clauses
* @return array * @return array
*/ */
public function filter( $clauses ) { public function filter( $clauses ) {
// Immediately deregister these legacy filters to avoid modifying /*
// any calls to WP_Query from filter callbacks hooked to WP_Query filters. * Immediately deregister these legacy filters to avoid modifying
* any calls to WP_Query from filter callbacks hooked to WP_Query filters.
*/
remove_filter( 'posts_clauses', array( $this, 'filter' ) ); remove_filter( 'posts_clauses', array( $this, 'filter' ) );
// The `join` and `where` filters are identical in their parameters, /*
// so we can use the same approach for both. * The `join` and `where` filters are identical in their parameters,
* so we can use the same approach for both.
*/
foreach ( array( 'join', 'where' ) as $clause ) { foreach ( array( 'join', 'where' ) as $clause ) {
if ( has_filter( 'get_' . $this->adjacent . '_post_' . $clause ) ) { if ( has_filter( 'get_' . $this->adjacent . '_post_' . $clause ) ) {
$clauses[ $clause ] = $this->filter_join_and_where( $clauses[ $clause ], $clause ); $clauses[ $clause ] = $this->filter_join_and_where( $clauses[ $clause ], $clause );
} }
} }
// The legacy `sort` filter combined the ORDER BY and LIMIT clauses, /*
// while `WP_Query` does not, which requires special handling. * The legacy `sort` filter combined the ORDER BY and LIMIT clauses,
* while `WP_Query` does not, which requires special handling.
*/
if ( has_filter( 'get_' . $this->adjacent . '_post_sort' ) ) { if ( has_filter( 'get_' . $this->adjacent . '_post_sort' ) ) {
$sort_clauses = $this->filter_sort( $clauses['orderby'], $clauses['limits'] ); $sort_clauses = $this->filter_sort( $clauses['orderby'], $clauses['limits'] );
$clauses = array_merge( $clauses, $sort_clauses ); $clauses = array_merge( $clauses, $sort_clauses );
@ -1349,6 +1397,7 @@ class WP_Adjacent_Post {
*/ */
protected function filter_join_and_where( $value, $clause ) { protected function filter_join_and_where( $value, $clause ) {
/** /**
* @todo Minimal hook docs
* @deprecated 3.9.0 * @deprecated 3.9.0
*/ */
return apply_filters( 'get_' . $this->adjacent . '_post_' . $clause, $value, $this->in_same_term, $this->excluded_terms ); return apply_filters( 'get_' . $this->adjacent . '_post_' . $clause, $value, $this->in_same_term, $this->excluded_terms );
@ -1377,8 +1426,11 @@ class WP_Adjacent_Post {
// Split the string of one or two clauses into their respective array keys // Split the string of one or two clauses into their respective array keys
if ( false !== $has_order_by && false !== $has_limit ) { if ( false !== $has_order_by && false !== $has_limit ) {
// The LIMIT clause cannot appear before the ORDER BY clause in a valid query /*
// However, since the legacy filter would allow a user to invert the order, we maintain that handling so the same errors are triggered. * The LIMIT clause cannot appear before the ORDER BY clause in a valid query
* However, since the legacy filter would allow a user to invert the order,
* we maintain that handling so the same errors are triggered.
*/
if ( $has_order_by < $has_limit ) { if ( $has_order_by < $has_limit ) {
$orderby = trim( str_ireplace( 'order by', '', substr( $sort, 0, $has_limit ) ) ); $orderby = trim( str_ireplace( 'order by', '', substr( $sort, 0, $has_limit ) ) );
$limits = trim( substr( $sort, $has_limit ) ); $limits = trim( substr( $sort, $has_limit ) );