Don't allow passing slugs to get_tag_link() and get_category_link(); they are too ambiguous. Restore WP_Error return to get_term_link(). fixes #16521 for trunk

git-svn-id: http://svn.automattic.com/wordpress/trunk@17443 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
ryan 2011-02-10 21:48:40 +00:00
parent 035b775354
commit 55c2425b3b
2 changed files with 22 additions and 6 deletions

View File

@ -12,11 +12,19 @@
* @since 1.0.0
* @see get_term_link()
*
* @param int $category Category ID, object, or slug.
* @param int|object $category Category ID or object.
* @return string Link on success, empty string if category does not exist.
*/
function get_category_link( $category ) {
return get_term_link( $category, 'category' );
if ( ! is_object( $category ) )
$category = (int) $category;
$category = get_term_link( $category, 'category' );
if ( is_wp_error( $category ) )
return '';
return $category;
}
/**
@ -964,11 +972,19 @@ class Walker_CategoryDropdown extends Walker {
* @since 2.3.0
* @see get_term_link()
*
* @param object|string|int $tag Tag ID, object, or slug.
* @param int|object $tag Tag ID or object.
* @return string Link on success, empty string if tag does not exist.
*/
function get_tag_link( $tag ) {
return get_term_link( $tag, 'post_tag' );
if ( ! is_object( $tag ) )
$tag = (int) $tag;
$tag = get_term_link( $tag, 'post_tag' );
if ( is_wp_error( $tag ) )
return '';
return $tag;
}
/**

View File

@ -2815,7 +2815,7 @@ function _update_post_term_count( $terms, $taxonomy ) {
*
* @param object|int|string $term
* @param string $taxonomy (optional if $term is object)
* @return string HTML link to taxonomy term archive on success, empty string if term does not exist.
* @return string|WP_Error HTML link to taxonomy term archive on success, WP_Error if term does not exist.
*/
function get_term_link( $term, $taxonomy = '') {
global $wp_rewrite;
@ -2832,7 +2832,7 @@ function get_term_link( $term, $taxonomy = '') {
$term = new WP_Error('invalid_term', __('Empty Term'));
if ( is_wp_error( $term ) )
return '';
return $term;
$taxonomy = $term->taxonomy;