don't crash when the user searches with no positive tags and multiple non-existent negative tags

This commit is contained in:
Shish 2021-10-06 17:02:25 +00:00
parent 2d0c942084
commit d932178670

View file

@ -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) {