Menu Adam R Brown

WP hooks navigation: Home/browseActions indexFilters index

Source View: wp_count_posts

To save our bandwidth, we show only a snippet of code around each occurence of the hook. View complete file in SVN (without highlighting).

Understanding Source Code

The best way to understand what a hook does is to look at where it occurs in the source code.

Remember, this hook may occur in more than one file. Moreover, the hook's context may change from version to version.

Source View

This hook occurs 2 times in this file.

Line Code
2530      if ( ! post_type_exists( $type ) ) {
2531           return new stdClass;
2532      }
2533
2534      $cache_key = _count_posts_cache_key( $type, $perm );
2535
2536      $counts = wp_cache_get( $cache_key, 'counts' );
2537      if ( false !== $counts ) {
2538           /** This filter is documented in wp-includes/post.php */
2539           return apply_filters( 'wp_count_posts', $counts, $type, $perm );
2540      }
2541
2542      $query = "SELECT post_status, COUNT( * ) AS num_posts FROM {$wpdb->posts} WHERE post_type = %s";
2543      if ( 'readable' == $perm && is_user_logged_in() ) {
2544           $post_type_object = get_post_type_object( $type );
2545           if ( ! current_user_can( $post_type_object->cap->read_private_posts ) ) {
2546                $query .= $wpdb->prepare(
2547                     " AND (post_status != 'private' OR ( post_author = %d AND post_status = 'private' ))",
2548                     get_current_user_id()
 
Line Code
2566       *
2567       * @since 3.7.0
2568       *
2569       * @param object $counts An object containing the current post_type's post
2570       *                       counts by status.
2571       * @param string $type   Post type.
2572       * @param string $perm   The permission to determine if the posts are 'readable'
2573       *                       by the current user.
2574       */
2575      return apply_filters( 'wp_count_posts', $counts, $type, $perm );
2576 }
2577
2578 /**
2579  * Count number of attachments for the mime type(s).
2580  *
2581  * If you set the optional mime_type parameter, then an array will still be
2582  * returned, but will only have the item you are looking for. It does not give
2583  * you the number of attachments that are children of a post. You can get that
2584  * by counting the number of children that post has.