WordPress.org

Make WordPress Core

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

File 22400.general-templates.php.diff, 14.1 KB (added by MikeHansenMe, 17 months 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;