don't crash when the user searches with no positive tags and multiple non-existent negative tags
This commit is contained in:
parent
2d0c942084
commit
d932178670
1 changed files with 13 additions and 5 deletions
|
@ -882,12 +882,14 @@ class Image
|
||||||
$positive_tag_id_array = [];
|
$positive_tag_id_array = [];
|
||||||
$positive_wildcard_id_array = [];
|
$positive_wildcard_id_array = [];
|
||||||
$negative_tag_id_array = [];
|
$negative_tag_id_array = [];
|
||||||
|
$all_nonexistent_negatives = true;
|
||||||
|
|
||||||
foreach ($tag_conditions as $tq) {
|
foreach ($tag_conditions as $tq) {
|
||||||
$tag_ids = self::tag_or_wildcard_to_ids($tq->tag);
|
$tag_ids = self::tag_or_wildcard_to_ids($tq->tag);
|
||||||
$tag_count = count($tag_ids);
|
$tag_count = count($tag_ids);
|
||||||
|
|
||||||
if ($tq->positive) {
|
if ($tq->positive) {
|
||||||
|
$all_nonexistent_negatives = false;
|
||||||
if ($tag_count== 0) {
|
if ($tag_count== 0) {
|
||||||
# one of the positive tags had zero results, therefor there
|
# one of the positive tags had zero results, therefor there
|
||||||
# can be no results; "where 1=0" should shortcut things
|
# can be no results; "where 1=0" should shortcut things
|
||||||
|
@ -901,14 +903,20 @@ class Image
|
||||||
$positive_wildcard_id_array[] = $tag_ids;
|
$positive_wildcard_id_array[] = $tag_ids;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
if ($tag_count > 0) {
|
||||||
|
$all_nonexistent_negatives = false;
|
||||||
// Unlike positive criteria, negative criteria are all handled in an OR fashion,
|
// Unlike positive criteria, negative criteria are all handled in an OR fashion,
|
||||||
// so we can just compile them all into a single sub-query.
|
// so we can just compile them all into a single sub-query.
|
||||||
$negative_tag_id_array = array_merge($negative_tag_id_array, $tag_ids);
|
$negative_tag_id_array = array_merge($negative_tag_id_array, $tag_ids);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
assert($positive_tag_id_array || $positive_wildcard_id_array || $negative_tag_id_array, @$_GET['q']);
|
assert($positive_tag_id_array || $positive_wildcard_id_array || $negative_tag_id_array || $all_nonexistent_negatives, @$_GET['q']);
|
||||||
if (!empty($positive_tag_id_array) || !empty($positive_wildcard_id_array)) {
|
|
||||||
|
if ($all_nonexistent_negatives) {
|
||||||
|
$query = new Querylet("SELECT images.* FROM images WHERE 1=1");
|
||||||
|
} elseif (!empty($positive_tag_id_array) || !empty($positive_wildcard_id_array)) {
|
||||||
$inner_joins = [];
|
$inner_joins = [];
|
||||||
if (!empty($positive_tag_id_array)) {
|
if (!empty($positive_tag_id_array)) {
|
||||||
foreach ($positive_tag_id_array as $tag) {
|
foreach ($positive_tag_id_array as $tag) {
|
||||||
|
|
Reference in a new issue