Reduce time to start PushTextSendJob.

fork-5.53.8
Cody Henthorne 2021-08-02 17:46:56 -04:00 zatwierdzone przez Alex Hart
rodzic e374f3afe6
commit 2830132b24
5 zmienionych plików z 28 dodań i 32 usunięć

Wyświetl plik

@ -61,6 +61,7 @@ public abstract class MessageDatabase extends Database implements MmsSmsColumns
private static final String TAG = Log.tag(MessageDatabase.class); private static final String TAG = Log.tag(MessageDatabase.class);
protected static final String THREAD_ID_WHERE = THREAD_ID + " = ?"; protected static final String THREAD_ID_WHERE = THREAD_ID + " = ?";
protected static final String[] THREAD_ID_PROJECTION = new String[] { THREAD_ID };
public MessageDatabase(Context context, SQLCipherOpenHelper databaseHelper) { public MessageDatabase(Context context, SQLCipherOpenHelper databaseHelper) {
super(context, databaseHelper); super(context, databaseHelper);

Wyświetl plik

@ -797,6 +797,18 @@ public class MmsSmsDatabase extends Database {
return databaseHelper.getReadableDatabase().rawQuery(query, null); return databaseHelper.getReadableDatabase().rawQuery(query, null);
} }
public static long getType(@NonNull Cursor cursor) {
String transportType = CursorUtil.requireString(cursor, TRANSPORT);
if (MmsSmsDatabase.MMS_TRANSPORT.equals(transportType)) {
return CursorUtil.requireLong(cursor, MmsDatabase.MESSAGE_BOX);
} else if (MmsSmsDatabase.SMS_TRANSPORT.equals(transportType)) {
return CursorUtil.requireLong(cursor, SmsDatabase.TYPE);
} else {
throw new AssertionError("Bad transport type: " + transportType);
}
}
public static Reader readerFor(@NonNull Cursor cursor) { public static Reader readerFor(@NonNull Cursor cursor) {
return new Reader(cursor); return new Reader(cursor);
} }

Wyświetl plik

@ -210,23 +210,13 @@ public class SmsDatabase extends MessageDatabase {
@Override @Override
public long getThreadIdForMessage(long id) { public long getThreadIdForMessage(long id) {
String sql = "SELECT " + THREAD_ID + " FROM " + TABLE_NAME + " WHERE " + ID + " = ?"; try (Cursor cursor = databaseHelper.getReadableDatabase().query(TABLE_NAME, THREAD_ID_PROJECTION, ID_WHERE, SqlUtil.buildArgs(id), null, null, null)) {
String[] sqlArgs = new String[] {id+""}; if (cursor.moveToFirst()) {
SQLiteDatabase db = databaseHelper.getReadableDatabase(); return CursorUtil.requireLong(cursor, THREAD_ID);
Cursor cursor = null;
try {
cursor = db.rawQuery(sql, sqlArgs);
if (cursor != null && cursor.moveToFirst())
return cursor.getLong(0);
else
return -1;
} finally {
if (cursor != null)
cursor.close();
} }
} }
return -1;
}
@Override @Override
int getMessageCountForThreadSummary(long threadId) { int getMessageCountForThreadSummary(long threadId) {

Wyświetl plik

@ -1278,14 +1278,10 @@ public class ThreadDatabase extends Database {
} }
public void updateSnippetTypeSilently(long threadId) { public void updateSnippetTypeSilently(long threadId) {
MmsSmsDatabase mmsSmsDatabase = DatabaseFactory.getMmsSmsDatabase(context); try (Cursor cursor = DatabaseFactory.getMmsSmsDatabase(context).getConversationSnippet(threadId)) {
if (cursor.moveToFirst()) {
try (MmsSmsDatabase.Reader reader = MmsSmsDatabase.readerFor(mmsSmsDatabase.getConversationSnippet(threadId))) {
MessageRecord record = reader.getNext();
if (record != null) {
ContentValues contentValues = new ContentValues(1); ContentValues contentValues = new ContentValues(1);
contentValues.put(SNIPPET_TYPE, record.getType()); contentValues.put(SNIPPET_TYPE, MmsSmsDatabase.getType(cursor));
databaseHelper.getWritableDatabase().update(TABLE_NAME, contentValues, ID_WHERE, SqlUtil.buildArgs(threadId)); databaseHelper.getWritableDatabase().update(TABLE_NAME, contentValues, ID_WHERE, SqlUtil.buildArgs(threadId));
} }

Wyświetl plik

@ -16,8 +16,6 @@ import org.thoughtcrime.securesms.jobmanager.persistence.FullSpec;
import org.thoughtcrime.securesms.jobmanager.persistence.JobSpec; import org.thoughtcrime.securesms.jobmanager.persistence.JobSpec;
import org.thoughtcrime.securesms.jobmanager.persistence.JobStorage; import org.thoughtcrime.securesms.jobmanager.persistence.JobStorage;
import org.thoughtcrime.securesms.util.Debouncer; import org.thoughtcrime.securesms.util.Debouncer;
import org.thoughtcrime.securesms.util.FeatureFlags;
import org.thoughtcrime.securesms.util.SetUtil;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collection; import java.util.Collection;
@ -28,7 +26,6 @@ import java.util.LinkedList;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Set; import java.util.Set;
import java.util.concurrent.TimeUnit;
/** /**
* Manages the queue of jobs. This is the only class that should write to {@link JobStorage} to * Manages the queue of jobs. This is the only class that should write to {@link JobStorage} to
@ -98,9 +95,9 @@ class JobController {
} }
insertJobChain(chain); insertJobChain(chain);
scheduleJobs(chain.get(0));
triggerOnSubmit(chain); triggerOnSubmit(chain);
notifyAll(); notifyAll();
scheduleJobs(chain.get(0));
} }
@WorkerThread @WorkerThread
@ -421,11 +418,11 @@ class JobController {
@WorkerThread @WorkerThread
private void scheduleJobs(@NonNull List<Job> jobs) { private void scheduleJobs(@NonNull List<Job> jobs) {
for (Job job : jobs) { for (Job job : jobs) {
List<Constraint> constraints = Stream.of(job.getParameters().getConstraintKeys()) List<String> constraintKeys = job.getParameters().getConstraintKeys();
.map(key -> new ConstraintSpec(job.getId(), key, job.getParameters().isMemoryOnly())) List<Constraint> constraints = new ArrayList<>(constraintKeys.size());
.map(ConstraintSpec::getFactoryKey) for (String key : constraintKeys) {
.map(constraintInstantiator::instantiate) constraints.add(constraintInstantiator.instantiate(key));
.toList(); }
scheduler.schedule(0, constraints); scheduler.schedule(0, constraints);
} }