Refactoring

pull/214/head
M66B 1 year ago
parent 8be1db079e
commit aba9e355ef

@ -199,41 +199,41 @@ public class Fts4DbHelper extends SQLiteOpenHelper {
BoundaryCallbackMessages.SearchCriteria criteria, String query) { BoundaryCallbackMessages.SearchCriteria criteria, String query) {
String search = escape(processBreakText(query)); String search = escape(processBreakText(query));
String select = ""; StringBuilder select = new StringBuilder();
List<String> args = new ArrayList<>(); List<String> args = new ArrayList<>();
if (account != null) { if (account != null) {
select += "account = ? AND "; select.append("account = ? AND ");
args.add(Long.toString(account)); args.add(Long.toString(account));
} }
if (folder != null) { if (folder != null) {
select += "folder = ? AND "; select.append("folder = ? AND ");
args.add(Long.toString(folder)); args.add(Long.toString(folder));
} }
if (exclude.length > 0) { if (exclude.length > 0) {
select += "NOT folder IN ("; select.append("NOT folder IN (");
for (int i = 0; i < exclude.length; i++) { for (int i = 0; i < exclude.length; i++) {
if (i > 0) if (i > 0)
select += ", "; select.append(", ");
select += "?"; select.append("?");
args.add(Long.toString(exclude[i])); args.add(Long.toString(exclude[i]));
} }
select += ") AND "; select.append(") AND ");
} }
if (criteria.after != null) { if (criteria.after != null) {
select += "time > ? AND "; select.append("time > ? AND ");
args.add(Long.toString(criteria.after)); args.add(Long.toString(criteria.after));
} }
if (criteria.before != null) { if (criteria.before != null) {
select += "time < ? AND "; select.append("time < ? AND ");
args.add(Long.toString(criteria.before)); args.add(Long.toString(criteria.before));
} }
select += "message MATCH ?"; select.append("message MATCH ?");
args.add(search); args.add(search);
Log.i("FTS select=" + select + Log.i("FTS select=" + select +
@ -243,7 +243,7 @@ public class Fts4DbHelper extends SQLiteOpenHelper {
// TODO CASA // TODO CASA
try (Cursor cursor = db.query( try (Cursor cursor = db.query(
"message", new String[]{"rowid"}, "message", new String[]{"rowid"},
select, select.toString(),
args.toArray(new String[0]), args.toArray(new String[0]),
null, null, "time DESC", null)) { null, null, "time DESC", null)) {
while (cursor != null && cursor.moveToNext()) while (cursor != null && cursor.moveToNext())

@ -199,41 +199,41 @@ public class Fts5DbHelper extends SQLiteOpenHelper {
String search = (sb.length() > 0 ? sb.toString() : escape(criteria.query)); String search = (sb.length() > 0 ? sb.toString() : escape(criteria.query));
String select = ""; StringBuilder select = new StringBuilder();
List<String> args = new ArrayList<>(); List<String> args = new ArrayList<>();
if (account != null) { if (account != null) {
select += "account = ? AND "; select.append("account = ? AND ");
args.add(Long.toString(account)); args.add(Long.toString(account));
} }
if (folder != null) { if (folder != null) {
select += "folder = ? AND "; select.append("folder = ? AND ");
args.add(Long.toString(folder)); args.add(Long.toString(folder));
} }
if (exclude.length > 0) { if (exclude.length > 0) {
select += "NOT folder IN ("; select.append("NOT folder IN (");
for (int i = 0; i < exclude.length; i++) { for (int i = 0; i < exclude.length; i++) {
if (i > 0) if (i > 0)
select += ", "; select.append(", ");
select += "?"; select.append("?");
args.add(Long.toString(exclude[i])); args.add(Long.toString(exclude[i]));
} }
select += ") AND "; select.append(") AND ");
} }
if (criteria.after != null) { if (criteria.after != null) {
select += "time > ? AND "; select.append("time > ? AND ");
args.add(Long.toString(criteria.after)); args.add(Long.toString(criteria.after));
} }
if (criteria.before != null) { if (criteria.before != null) {
select += "time < ? AND "; select.append("time < ? AND ");
args.add(Long.toString(criteria.before)); args.add(Long.toString(criteria.before));
} }
select += "message MATCH ?"; select.append("message MATCH ?");
args.add(search); args.add(search);
Log.i("FTS select=" + select + Log.i("FTS select=" + select +
@ -243,7 +243,7 @@ public class Fts5DbHelper extends SQLiteOpenHelper {
// TODO CASA // TODO CASA
try (Cursor cursor = db.query( try (Cursor cursor = db.query(
"message", new String[]{"rowid"}, "message", new String[]{"rowid"},
select, select.toString(),
args.toArray(new String[0]), args.toArray(new String[0]),
null, null, "time DESC", null)) { null, null, "time DESC", null)) {
while (cursor != null && cursor.moveToNext()) while (cursor != null && cursor.moveToNext())

Loading…
Cancel
Save