WordPress.org

Make WordPress Core

Ticket #22400: 22400.general-templates.php.diff

File 22400.general-templates.php.diff, 14.1 KB (added by MikeHansenMe, 5 years ago)

general-template.php with some minor code cleanup

  • wp-includes/general-template.php

     
    879879        );
    880880
    881881        $r = wp_parse_args( $args, $defaults );
    882         extract( $r, EXTR_SKIP );
    883882
    884         if ( '' == $type )
    885                 $type = 'monthly';
     883        if ( '' == $r['type'] )
     884                $r['type'] = 'monthly';
    886885
    887         if ( '' != $limit ) {
    888                 $limit = absint($limit);
    889                 $limit = ' LIMIT '.$limit;
     886        if ( '' != $r['limit'] ) {
     887                $r['limit'] = absint( $r['limit'] );
     888                $r['limit'] = ' LIMIT '.$r['limit'];
    890889        }
    891890
    892891        $order = strtoupper( $order );
     
    907906        $archive_week_end_date_format   = 'Y/m/d';
    908907
    909908        if ( !$archive_date_format_over_ride ) {
    910                 $archive_day_date_format = get_option('date_format');
    911                 $archive_week_start_date_format = get_option('date_format');
    912                 $archive_week_end_date_format = get_option('date_format');
     909                $archive_day_date_format = get_option( 'date_format' );
     910                $archive_week_start_date_format = get_option( 'date_format' );
     911                $archive_week_end_date_format = get_option( 'date_format' );
    913912        }
    914913
    915914        //filters
     
    918917
    919918        $output = '';
    920919
    921         if ( 'monthly' == $type ) {
    922                 $query = "SELECT YEAR(post_date) AS `year`, MONTH(post_date) AS `month`, count(ID) as posts FROM $wpdb->posts $join $where GROUP BY YEAR(post_date), MONTH(post_date) ORDER BY post_date $order $limit";
    923                 $key = md5($query);
     920        if ( 'monthly' == $r['type'] ) {
     921                $query = "SELECT YEAR(post_date) AS `year`, MONTH(post_date) AS `month`, count(ID) as posts FROM $wpdb->posts $join $where GROUP BY YEAR(post_date), MONTH(post_date) ORDER BY post_date $order " . $r['limit'];
     922                $key = md5( $query );
    924923                $cache = wp_cache_get( 'wp_get_archives' , 'general');
    925924                if ( !isset( $cache[ $key ] ) ) {
    926                         $arcresults = $wpdb->get_results($query);
     925                        $arcresults = $wpdb->get_results( $query );
    927926                        $cache[ $key ] = $arcresults;
    928927                        wp_cache_set( 'wp_get_archives', $cache, 'general' );
    929928                } else {
    930929                        $arcresults = $cache[ $key ];
    931930                }
    932931                if ( $arcresults ) {
    933                         $afterafter = $after;
     932                        $afterafter = $r['after'];
    934933                        foreach ( (array) $arcresults as $arcresult ) {
    935934                                $url = get_month_link( $arcresult->year, $arcresult->month );
    936935                                /* translators: 1: month name, 2: 4-digit year */
    937                                 $text = sprintf(__('%1$s %2$d'), $wp_locale->get_month($arcresult->month), $arcresult->year);
    938                                 if ( $show_post_count )
    939                                         $after = ' ('.$arcresult->posts.')' . $afterafter;
    940                                 $output .= get_archives_link($url, $text, $format, $before, $after);
     936                                $text = sprintf( __( '%1$s %2$d' ), $wp_locale->get_month( $arcresult->month ), $arcresult->year );
     937                                if ( $r['show_post_count'] )
     938                                        $r['after'] = ' ('.$arcresult->posts.')' . $afterafter;
     939                                $output .= get_archives_link( $url, $text, $r['format'], $r['before'], $r['after'] );
    941940                        }
    942941                }
    943         } elseif ('yearly' == $type) {
    944                 $query = "SELECT YEAR(post_date) AS `year`, count(ID) as posts FROM $wpdb->posts $join $where GROUP BY YEAR(post_date) ORDER BY post_date $order $limit";
    945                 $key = md5($query);
     942        } elseif ( 'yearly' == $r['type'] ) {
     943                $query = "SELECT YEAR(post_date) AS `year`, count(ID) as posts FROM $wpdb->posts $join $where GROUP BY YEAR(post_date) ORDER BY post_date $order " . $r['limit'];
     944                $key = md5( $query );
    946945                $cache = wp_cache_get( 'wp_get_archives' , 'general');
    947946                if ( !isset( $cache[ $key ] ) ) {
    948                         $arcresults = $wpdb->get_results($query);
     947                        $arcresults = $wpdb->get_results( $query );
    949948                        $cache[ $key ] = $arcresults;
    950949                        wp_cache_set( 'wp_get_archives', $cache, 'general' );
    951950                } else {
    952951                        $arcresults = $cache[ $key ];
    953952                }
    954                 if ($arcresults) {
    955                         $afterafter = $after;
     953                if ( $arcresults ) {
     954                        $afterafter = $r['after'];
    956955                        foreach ( (array) $arcresults as $arcresult) {
    957                                 $url = get_year_link($arcresult->year);
    958                                 $text = sprintf('%d', $arcresult->year);
    959                                 if ($show_post_count)
    960                                         $after = ' ('.$arcresult->posts.')' . $afterafter;
    961                                 $output .= get_archives_link($url, $text, $format, $before, $after);
     956                                $url = get_year_link( $arcresult->year );
     957                                $text = sprintf( '%d', $arcresult->year );
     958                                if ($r['show_post_count'])
     959                                        $r['after'] = ' ('.$arcresult->posts.')' . $afterafter;
     960                                $output .= get_archives_link( $url, $text, $r['format'], $r['before'], $r['after'] );
    962961                        }
    963962                }
    964         } elseif ( 'daily' == $type ) {
    965                 $query = "SELECT YEAR(post_date) AS `year`, MONTH(post_date) AS `month`, DAYOFMONTH(post_date) AS `dayofmonth`, count(ID) as posts FROM $wpdb->posts $join $where GROUP BY YEAR(post_date), MONTH(post_date), DAYOFMONTH(post_date) ORDER BY post_date $order $limit";
    966                 $key = md5($query);
     963        } elseif ( 'daily' == $r['type'] ) {
     964                $query = "SELECT YEAR(post_date) AS `year`, MONTH(post_date) AS `month`, DAYOFMONTH(post_date) AS `dayofmonth`, count(ID) as posts FROM $wpdb->posts $join $where GROUP BY YEAR(post_date), MONTH(post_date), DAYOFMONTH(post_date) ORDER BY post_date $order " . $r['limit'];
     965                $key = md5( $query );
    967966                $cache = wp_cache_get( 'wp_get_archives' , 'general');
    968967                if ( !isset( $cache[ $key ] ) ) {
    969                         $arcresults = $wpdb->get_results($query);
     968                        $arcresults = $wpdb->get_results( $query );
    970969                        $cache[ $key ] = $arcresults;
    971970                        wp_cache_set( 'wp_get_archives', $cache, 'general' );
    972971                } else {
    973972                        $arcresults = $cache[ $key ];
    974973                }
    975974                if ( $arcresults ) {
    976                         $afterafter = $after;
     975                        $afterafter = $r['after'];
    977976                        foreach ( (array) $arcresults as $arcresult ) {
    978                                 $url    = get_day_link($arcresult->year, $arcresult->month, $arcresult->dayofmonth);
    979                                 $date = sprintf('%1$d-%2$02d-%3$02d 00:00:00', $arcresult->year, $arcresult->month, $arcresult->dayofmonth);
    980                                 $text = mysql2date($archive_day_date_format, $date);
    981                                 if ($show_post_count)
    982                                         $after = ' ('.$arcresult->posts.')'.$afterafter;
    983                                 $output .= get_archives_link($url, $text, $format, $before, $after);
     977                                $url    = get_day_link( $arcresult->year, $arcresult->month, $arcresult->dayofmonth );
     978                                $date = sprintf( '%1$d-%2$02d-%3$02d 00:00:00', $arcresult->year, $arcresult->month, $arcresult->dayofmonth );
     979                                $text = mysql2date( $archive_day_date_format, $date );
     980                                if ( $r['show_post_count'] )
     981                                        $r['after'] = ' ('.$arcresult->posts.')'.$afterafter;
     982                                $output .= get_archives_link( $url, $text, $r['format'], $r['before'], $r['after'] );
    984983                        }
    985984                }
    986         } elseif ( 'weekly' == $type ) {
     985        } elseif ( 'weekly' == $r['type'] ) {
    987986                $week = _wp_mysql_week( '`post_date`' );
    988                 $query = "SELECT DISTINCT $week AS `week`, YEAR( `post_date` ) AS `yr`, DATE_FORMAT( `post_date`, '%Y-%m-%d' ) AS `yyyymmdd`, count( `ID` ) AS `posts` FROM `$wpdb->posts` $join $where GROUP BY $week, YEAR( `post_date` ) ORDER BY `post_date` $order $limit";
    989                 $key = md5($query);
     987                $query = "SELECT DISTINCT $week AS `week`, YEAR( `post_date` ) AS `yr`, DATE_FORMAT( `post_date`, '%Y-%m-%d' ) AS `yyyymmdd`, count( `ID` ) AS `posts` FROM `$wpdb->posts` $join $where GROUP BY $week, YEAR( `post_date` ) ORDER BY `post_date` $order " . $r['limit'];
     988                $key = md5( $query );
    990989                $cache = wp_cache_get( 'wp_get_archives' , 'general');
    991990                if ( !isset( $cache[ $key ] ) ) {
    992                         $arcresults = $wpdb->get_results($query);
     991                        $arcresults = $wpdb->get_results( $query );
    993992                        $cache[ $key ] = $arcresults;
    994993                        wp_cache_set( 'wp_get_archives', $cache, 'general' );
    995994                } else {
    996995                        $arcresults = $cache[ $key ];
    997996                }
    998997                $arc_w_last = '';
    999                 $afterafter = $after;
     998                $afterafter = $r['after'];
    1000999                if ( $arcresults ) {
    10011000                                foreach ( (array) $arcresults as $arcresult ) {
    10021001                                        if ( $arcresult->week != $arc_w_last ) {
    10031002                                                $arc_year = $arcresult->yr;
    10041003                                                $arc_w_last = $arcresult->week;
    1005                                                 $arc_week = get_weekstartend($arcresult->yyyymmdd, get_option('start_of_week'));
    1006                                                 $arc_week_start = date_i18n($archive_week_start_date_format, $arc_week['start']);
    1007                                                 $arc_week_end = date_i18n($archive_week_end_date_format, $arc_week['end']);
    1008                                                 $url  = sprintf('%1$s/%2$s%3$sm%4$s%5$s%6$sw%7$s%8$d', home_url(), '', '?', '=', $arc_year, '&', '=', $arcresult->week);
     1004                                                $arc_week = get_weekstartend( $arcresult->yyyymmdd, get_option( 'start_of_week' ) );
     1005                                                $arc_week_start = date_i18n( $archive_week_start_date_format, $arc_week['start'] );
     1006                                                $arc_week_end = date_i18n( $archive_week_end_date_format, $arc_week['end'] );
     1007                                                $url  = sprintf( '%1$s/%2$s%3$sm%4$s%5$s%6$sw%7$s%8$d', home_url(), '', '?', '=', $arc_year, '&', '=', $arcresult->week );
    10091008                                                $text = $arc_week_start . $archive_week_separator . $arc_week_end;
    1010                                                 if ($show_post_count)
    1011                                                         $after = ' ('.$arcresult->posts.')'.$afterafter;
    1012                                                 $output .= get_archives_link($url, $text, $format, $before, $after);
     1009                                                if ( $r['show_post_count'] )
     1010                                                        $r['after'] = ' ('.$arcresult->posts.')'.$afterafter;
     1011                                                $output .= get_archives_link( $url, $text, $r['format'], $r['before'], $r['after'] );
    10131012                                        }
    10141013                                }
    10151014                }
    1016         } elseif ( ( 'postbypost' == $type ) || ('alpha' == $type) ) {
    1017                 $orderby = ('alpha' == $type) ? 'post_title ASC ' : 'post_date DESC ';
    1018                 $query = "SELECT * FROM $wpdb->posts $join $where ORDER BY $orderby $limit";
    1019                 $key = md5($query);
     1015        } elseif ( ( 'postbypost' == $r['type'] ) || ('alpha' == $r['type']) ) {
     1016                $orderby = ( 'alpha' == $r['type'] ) ? 'post_title ASC ' : 'post_date DESC ';
     1017                $query = "SELECT * FROM $wpdb->posts $join $where ORDER BY $orderby " . $r['limit'];
     1018                $key = md5( $query );
    10201019                $cache = wp_cache_get( 'wp_get_archives' , 'general');
    10211020                if ( !isset( $cache[ $key ] ) ) {
    1022                         $arcresults = $wpdb->get_results($query);
     1021                        $arcresults = $wpdb->get_results( $query );
    10231022                        $cache[ $key ] = $arcresults;
    10241023                        wp_cache_set( 'wp_get_archives', $cache, 'general' );
    10251024                } else {
     
    10331032                                                $text = strip_tags( apply_filters( 'the_title', $arcresult->post_title, $arcresult->ID ) );
    10341033                                        else
    10351034                                                $text = $arcresult->ID;
    1036                                         $output .= get_archives_link($url, $text, $format, $before, $after);
     1035                                        $output .= get_archives_link( $url, $text, $r['format'], $r['before'], $r['after'] );
    10371036                                }
    10381037                        }
    10391038                }
    10401039        }
    1041         if ( $echo )
     1040        if ( $r['echo'] )
    10421041                echo $output;
    10431042        else
    10441043                return $output;
     
    19371936        );
    19381937
    19391938        $args = wp_parse_args( $args, $defaults );
    1940         extract($args, EXTR_SKIP);
    19411939
    19421940        // Who knows what else people pass in $args
    1943         $total = (int) $total;
    1944         if ( $total < 2 )
     1941        $args['total'] = (int) $args['total'];
     1942        if ( $args['total'] < 2 )
    19451943                return;
    1946         $current  = (int) $current;
    1947         $end_size = 0  < (int) $end_size ? (int) $end_size : 1; // Out of bounds?  Make it the default.
    1948         $mid_size = 0 <= (int) $mid_size ? (int) $mid_size : 2;
    1949         $add_args = is_array($add_args) ? $add_args : false;
     1944        $args['current']  = (int) $args['current'];
     1945        $args['end_size'] = 0  < (int) $args['end_size'] ? (int) $args['end_size'] : 1; // Out of bounds?  Make it the default.
     1946        $args['mid_size'] = 0 <= (int) $args['mid_size'] ? (int) $args['mid_size'] : 2;
     1947        $args['add_args'] = is_array( $args['add_args '] ) ? $args['add_args '] : false;
    19501948        $r = '';
    19511949        $page_links = array();
    19521950        $n = 0;
    19531951        $dots = false;
    19541952
    1955         if ( $prev_next && $current && 1 < $current ) :
    1956                 $link = str_replace('%_%', 2 == $current ? '' : $format, $base);
    1957                 $link = str_replace('%#%', $current - 1, $link);
    1958                 if ( $add_args )
    1959                         $link = add_query_arg( $add_args, $link );
    1960                 $link .= $add_fragment;
    1961                 $page_links[] = '<a class="prev page-numbers" href="' . esc_url( apply_filters( 'paginate_links', $link ) ) . '">' . $prev_text . '</a>';
     1953        if ( $args['prev_next'] && $args['current'] && 1 < $args['current'] ) :
     1954                $link = str_replace('%_%', 2 == $args['current'] ? '' : $args['format'], $linkdata['link_category']);
     1955                $link = str_replace('%#%', $args['current'] - 1, $link);
     1956                if ( $args['add_args '] )
     1957                        $link = add_query_arg( $args['add_args '], $link );
     1958                $link .= $args['add_fragment'];
     1959                $page_links[] = '<a class="prev page-numbers" href="' . esc_url( apply_filters( 'paginate_links', $link ) ) . '">' . $args['prev_text'] . '</a>';
    19621960        endif;
    1963         for ( $n = 1; $n <= $total; $n++ ) :
     1961        for ( $n = 1; $n <= $args['total']; $n++ ) :
    19641962                $n_display = number_format_i18n($n);
    1965                 if ( $n == $current ) :
     1963                if ( $n == $args['current'] ) :
    19661964                        $page_links[] = "<span class='page-numbers current'>$n_display</span>";
    19671965                        $dots = true;
    19681966                else :
    1969                         if ( $show_all || ( $n <= $end_size || ( $current && $n >= $current - $mid_size && $n <= $current + $mid_size ) || $n > $total - $end_size ) ) :
    1970                                 $link = str_replace('%_%', 1 == $n ? '' : $format, $base);
     1967                        if ( $args['show_all'] || ( $n <= $args['end_size'] || ( $args['current'] && $n >= $args['current'] - $args['mid_size'] && $n <= $args['current'] + $args['mid_size'] ) || $n > $args['total'] - $args['end_size'] ) ) :
     1968                                $link = str_replace('%_%', 1 == $n ? '' : $args['format'], $args['base']);
    19711969                                $link = str_replace('%#%', $n, $link);
    1972                                 if ( $add_args )
    1973                                         $link = add_query_arg( $add_args, $link );
    1974                                 $link .= $add_fragment;
     1970                                if ( $args['add_args '] )
     1971                                        $link = add_query_arg( $args['add_args '], $link );
     1972                                $link .= $args['add_fragment'];
    19751973                                $page_links[] = "<a class='page-numbers' href='" . esc_url( apply_filters( 'paginate_links', $link ) ) . "'>$n_display</a>";
    19761974                                $dots = true;
    1977                         elseif ( $dots && !$show_all ) :
     1975                        elseif ( $dots && !$args['show_all'] ) :
    19781976                                $page_links[] = '<span class="page-numbers dots">' . __( '&hellip;' ) . '</span>';
    19791977                                $dots = false;
    19801978                        endif;
    19811979                endif;
    19821980        endfor;
    1983         if ( $prev_next && $current && ( $current < $total || -1 == $total ) ) :
    1984                 $link = str_replace('%_%', $format, $base);
    1985                 $link = str_replace('%#%', $current + 1, $link);
    1986                 if ( $add_args )
    1987                         $link = add_query_arg( $add_args, $link );
    1988                 $link .= $add_fragment;
    1989                 $page_links[] = '<a class="next page-numbers" href="' . esc_url( apply_filters( 'paginate_links', $link ) ) . '">' . $next_text . '</a>';
     1981        if ( $args['prev_next'] && $args['current'] && ( $args['current'] < $args['total'] || -1 == $args['total'] ) ) :
     1982                $link = str_replace('%_%', $args['format'], $args['base']);
     1983                $link = str_replace('%#%', $args['current'] + 1, $link);
     1984                if ( $args['add_args '] )
     1985                        $link = add_query_arg( $args['add_args '], $link );
     1986                $link .= $args['add_fragment'];
     1987                $page_links[] = '<a class="next page-numbers" href="' . esc_url( apply_filters( 'paginate_links', $link ) ) . '">' . $args['next_text'] . '</a>';
    19901988        endif;
    1991         switch ( $type ) :
     1989        switch ( $args['type'] ) :
    19921990                case 'array' :
    19931991                        return $page_links;
    19941992                        break;