Search bug fixed
This commit is contained in:
@@ -9,8 +9,8 @@ android {
|
||||
applicationId "xyz.quaver.pupil"
|
||||
minSdkVersion 16
|
||||
targetSdkVersion 28
|
||||
versionCode 4
|
||||
versionName "1.3"
|
||||
versionCode 5
|
||||
versionName "1.4"
|
||||
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
|
||||
}
|
||||
buildTypes {
|
||||
|
||||
@@ -6,6 +6,7 @@ import android.os.Bundle
|
||||
import android.preference.PreferenceManager
|
||||
import android.text.*
|
||||
import android.text.style.AlignmentSpan
|
||||
import android.util.Log
|
||||
import android.view.View
|
||||
import android.view.WindowManager
|
||||
import androidx.appcompat.app.AlertDialog
|
||||
@@ -357,6 +358,7 @@ class MainActivity : AppCompatActivity() {
|
||||
cancelFetch()
|
||||
clearGalleries()
|
||||
fetchGalleries(query)
|
||||
loadBlocks()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -7,7 +7,7 @@ buildscript {
|
||||
jcenter()
|
||||
}
|
||||
dependencies {
|
||||
classpath 'com.android.tools.build:gradle:3.4.0'
|
||||
classpath 'com.android.tools.build:gradle:3.4.1'
|
||||
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
|
||||
classpath "org.jetbrains.kotlin:kotlin-android-extensions:$kotlin_version"
|
||||
classpath "org.jetbrains.kotlin:kotlin-serialization:$kotlin_version"
|
||||
|
||||
@@ -15,7 +15,6 @@ fun doSearch(query: String) : List<Int> {
|
||||
.toLowerCase()
|
||||
.split(Regex("\\s+"))
|
||||
|
||||
val results = ArrayList<Int>()
|
||||
val positiveTerms = LinkedList<String>()
|
||||
val negativeTerms = LinkedList<String>()
|
||||
|
||||
@@ -26,33 +25,24 @@ fun doSearch(query: String) : List<Int> {
|
||||
positiveTerms.push(term)
|
||||
}
|
||||
|
||||
//first results
|
||||
results.addAll(
|
||||
if (positiveTerms.isEmpty())
|
||||
getGalleryIDsFromNozomi(null, "index", "all")
|
||||
else
|
||||
getGalleryIDsForQuery(positiveTerms.poll())
|
||||
)
|
||||
var results = when {
|
||||
positiveTerms.isEmpty() -> getGalleryIDsFromNozomi(null, "index", "all")
|
||||
else -> getGalleryIDsForQuery(positiveTerms.poll())
|
||||
}
|
||||
|
||||
runBlocking {
|
||||
@Synchronized fun filterPositive(newResults: List<Int>) {
|
||||
results.filter { newResults.binarySearch(it) >= 0 }.let {
|
||||
results.clear()
|
||||
results.addAll(it)
|
||||
}
|
||||
results = results.filter { newResults.binarySearch(it) >= 0 }
|
||||
}
|
||||
|
||||
@Synchronized fun filterNegative(newResults: List<Int>) {
|
||||
results.filterNot { newResults.binarySearch(it) >= 0 }.let {
|
||||
results.clear()
|
||||
results.addAll(it)
|
||||
}
|
||||
results = results.filter { newResults.binarySearch(it) < 0 }
|
||||
}
|
||||
|
||||
//positive results
|
||||
positiveTerms.map {
|
||||
launch(searchDispatcher) {
|
||||
filterPositive(getGalleryIDsForQuery(it).reversed())
|
||||
filterPositive(getGalleryIDsForQuery(it).sorted())
|
||||
}
|
||||
}.forEach {
|
||||
it.join()
|
||||
@@ -61,7 +51,7 @@ fun doSearch(query: String) : List<Int> {
|
||||
//negative results
|
||||
negativeTerms.map {
|
||||
launch(searchDispatcher) {
|
||||
filterNegative(getGalleryIDsForQuery(it).reversed())
|
||||
filterNegative(getGalleryIDsForQuery(it).sorted())
|
||||
}
|
||||
}.forEach {
|
||||
it.join()
|
||||
|
||||
@@ -21,10 +21,9 @@ class UnitTest {
|
||||
|
||||
@Test
|
||||
fun test_search() {
|
||||
val ids = getGalleryIDsForQuery("female:loli").reversed()
|
||||
val ids = getGalleryIDsForQuery("language:korean").reversed()
|
||||
|
||||
for (i in 0..100)
|
||||
println(ids[i])
|
||||
print(ids.size)
|
||||
}
|
||||
|
||||
@Test
|
||||
@@ -36,7 +35,7 @@ class UnitTest {
|
||||
|
||||
@Test
|
||||
fun test_doSearch() {
|
||||
val r = doSearch("type:artistcg language:korean female:loli female:mind_break -female:anal")
|
||||
val r = doSearch("female:loli female:bondage language:korean -male:yaoi -male:guro -female:guro")
|
||||
|
||||
print(r.size)
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user