Make WordPress Core


Ignore:
Timestamp:
09/03/2007 06:14:05 PM (17 years ago)
Author:
ryan
Message:

Tag unions and intersections. fixes #4895

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/wp-includes/query.php

    r6012 r6021  
    421421
    422422        $array_keys = array('category__in', 'category__not_in', 'category__and',
    423             'tag__in', 'tag__not_in', 'tag__and');
     423            'tag__in', 'tag__not_in', 'tag__and', 'tag_slug__in', 'tag_slug__and');
    424424       
    425425        foreach ( $array_keys as $key ) {
     
    607607                $qv['tag__and'] = array_map('intval', $qv['tag__and']);
    608608                $this->is_category = true; 
     609            }
     610
     611            if ( !is_array($qv['tag_slug__in']) || empty($qv['tag_slug__in']) ) {
     612                $qv['tag_slug__in'] = array();
     613            } else {
     614                $qv['tag_slug__in'] = array_map('sanitize_title', $qv['tag_slug__in']);
     615                $this->is_tag = true;   
     616            }
     617
     618            if ( !is_array($qv['tag_slug__and']) || empty($qv['tag_slug__amd']) ) {
     619                $qv['tag_slug__and'] = array();
     620            } else {
     621                $qv['tag_slug__and'] = array_map('sanitize_title', $qv['tag_slug__and']);
     622                $this->is_tag = true;   
    609623            }
    610624
     
    985999        // Tags
    9861000        if ( '' != $q['tag'] ) {
    987             $reqtag = is_term( $q['tag'], 'post_tag' );
    988             if ( !empty($reqtag) )
    989                 $reqtag = $reqtag['term_id'];
    990             else
    991                 $reqtag = 0;
    992 
    993             $q['tag_id'] = $reqtag;
    994             $q['tag__in'][] = $reqtag;
    995         }
    996 
    997         if ( !empty($q['tag__in']) || !empty($q['tag__not_in']) || !empty($q['tag__and']) ) {
     1001            if ( strpos($q['tag'], ',') !== false ) {
     1002                $tags = preg_split('/[,\s]+/', $q['tag']);
     1003                foreach ( (array) $tags as $tag ) {
     1004                    $tag = sanitize_term_field('slug', $tag, 0, 'post_tag', 'db');
     1005                    $q['tag_slug__in'][] = $tag;
     1006                }
     1007            } else if ( preg_match('/[+\s]+/', $q['tag']) ) {
     1008                $tags = preg_split('/[+\s]+/', $q['tag']);
     1009                foreach ( (array) $tags as $tag ) {
     1010                    $tag = sanitize_term_field('slug', $tag, 0, 'post_tag', 'db');
     1011                    $q['tag_slug__and'][] = $tag;
     1012                }
     1013            } else {
     1014                $q['tag'] = sanitize_term_field('slug', $q['tag'], 0, 'post_tag', 'db');
     1015                $reqtag = is_term( $q['tag'], 'post_tag' );
     1016                if ( !empty($reqtag) )
     1017                    $reqtag = $reqtag['term_id'];
     1018                else
     1019                    $reqtag = 0;
     1020
     1021                $q['tag_id'] = $reqtag;
     1022                $q['tag__in'][] = $reqtag;
     1023            }
     1024        }
     1025
     1026        if ( !empty($q['tag__in']) || !empty($q['tag__not_in']) || !empty($q['tag__and']) ||
     1027            !empty($q['tag_slug__in']) || !empty($q['tag_slug__and']) ) {
    9981028            $groupby = "{$wpdb->posts}.ID";
    9991029        }
     
    10061036        }
    10071037
     1038        if ( !empty($q['tag_slug__in']) ) {
     1039            $join = " LEFT JOIN $wpdb->term_relationships ON ($wpdb->posts.ID = $wpdb->term_relationships.object_id) LEFT JOIN $wpdb->term_taxonomy ON ($wpdb->term_relationships.term_taxonomy_id = $wpdb->term_taxonomy.term_taxonomy_id) LEFT JOIN $wpdb->terms ON ($wpdb->term_taxonomy.term_id = $wpdb->terms.term_id) ";
     1040            $whichcat .= " AND $wpdb->term_taxonomy.taxonomy = 'post_tag' ";
     1041            $include_tags = "'" . implode("', '", $q['tag_slug__in']) . "'";
     1042            $whichcat .= " AND $wpdb->terms.slug IN ($include_tags) ";
     1043        }
     1044
    10081045        if ( !empty($q['tag__not_in']) ) {
    10091046            $ids = get_objects_in_term($q['tag__not_in'], 'post_tag');
     
    10141051        }
    10151052
    1016         if ( !empty($q['tag__and']) ) {
     1053        if ( !empty($q['tag_slug__and']) ) {
    10171054            $count = 0;
    1018             foreach ( $q['tag__and'] as $tag_and ) {
    1019                 $join .= " LEFT JOIN $wpdb->term_relationships AS tr$count ON ($wpdb->posts.ID = tr$count.object_id) LEFT JOIN $wpdb->term_taxonomy AS tt$count ON (tr$count.term_taxonomy_id = tt$count.term_taxonomy_id) ";
    1020                 $whichcat .= " AND tt$count.term_id = '$tag_and' ";
     1055            foreach ( $q['tag_slug__and'] as $tag_and ) {
     1056                $join .= " LEFT JOIN $wpdb->term_relationships AS tr$count ON ($wpdb->posts.ID = tr$count.object_id) LEFT JOIN $wpdb->term_taxonomy AS tt$count ON (tr$count.term_taxonomy_id = tt$count.term_taxonomy_id) LEFT JOIN $wpdb->terms AS term$count ON (tt$count.term_id = term$count.term_id) ";
     1057                $whichcat .= " AND term$count.slug = '$tag_and' ";
    10211058                $count++;
    10221059            }
Note: See TracChangeset for help on using the changeset viewer.