Merge "[TestPrep10] Add some comments"
This commit is contained in:
commit
62abc40d7d
1 changed files with 28 additions and 4 deletions
|
@ -38,12 +38,19 @@ import java.util.concurrent.TimeUnit;
|
||||||
/**
|
/**
|
||||||
* Logs the use of the LatinIME keyboard.
|
* Logs the use of the LatinIME keyboard.
|
||||||
*
|
*
|
||||||
* This class logs operations on the IME keyboard, including what the user has typed.
|
* This class logs operations on the IME keyboard, including what the user has typed. Data is
|
||||||
* Data is stored locally in a file in app-specific storage.
|
* written to a {@link JsonWriter}, which will write to a local file.
|
||||||
|
*
|
||||||
|
* The JsonWriter is created on-demand by calling {@link #getInitializedJsonWriterLocked}.
|
||||||
|
*
|
||||||
|
* This class uses an executor to perform file-writing operations on a separate thread. It also
|
||||||
|
* tries to avoid creating unnecessary files if there is nothing to write. It also handles
|
||||||
|
* flushing, making sure it happens, but not too frequently.
|
||||||
*
|
*
|
||||||
* This functionality is off by default. See {@link ProductionFlag#IS_EXPERIMENTAL}.
|
* This functionality is off by default. See {@link ProductionFlag#IS_EXPERIMENTAL}.
|
||||||
*/
|
*/
|
||||||
public class ResearchLog {
|
public class ResearchLog {
|
||||||
|
// TODO: Automatically initialize the JsonWriter rather than requiring the caller to manage it.
|
||||||
private static final String TAG = ResearchLog.class.getSimpleName();
|
private static final String TAG = ResearchLog.class.getSimpleName();
|
||||||
private static final boolean DEBUG = false && ProductionFlag.IS_EXPERIMENTAL_DEBUG;
|
private static final boolean DEBUG = false && ProductionFlag.IS_EXPERIMENTAL_DEBUG;
|
||||||
private static final long FLUSH_DELAY_IN_MS = 1000 * 5;
|
private static final long FLUSH_DELAY_IN_MS = 1000 * 5;
|
||||||
|
@ -87,6 +94,12 @@ public class ResearchLog {
|
||||||
mContext = context;
|
mContext = context;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Waits for any publication requests to finish and closes the {@link JsonWriter} used for
|
||||||
|
* output.
|
||||||
|
*
|
||||||
|
* See class comment for details about {@code JsonWriter} construction.
|
||||||
|
*/
|
||||||
public synchronized void close(final Runnable onClosed) {
|
public synchronized void close(final Runnable onClosed) {
|
||||||
mExecutor.submit(new Callable<Object>() {
|
mExecutor.submit(new Callable<Object>() {
|
||||||
@Override
|
@Override
|
||||||
|
@ -106,8 +119,7 @@ public class ResearchLog {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
Log.d(TAG, "error when closing ResearchLog:");
|
Log.d(TAG, "error when closing ResearchLog:", e);
|
||||||
e.printStackTrace();
|
|
||||||
} finally {
|
} finally {
|
||||||
if (mFile != null && mFile.exists()) {
|
if (mFile != null && mFile.exists()) {
|
||||||
mFile.setWritable(false, false);
|
mFile.setWritable(false, false);
|
||||||
|
@ -125,6 +137,12 @@ public class ResearchLog {
|
||||||
|
|
||||||
private boolean mIsAbortSuccessful;
|
private boolean mIsAbortSuccessful;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Waits for publication requests to finish, closes the {@link JsonWriter}, but then deletes the
|
||||||
|
* backing file used for output.
|
||||||
|
*
|
||||||
|
* See class comment for details about {@code JsonWriter} construction.
|
||||||
|
*/
|
||||||
public synchronized void abort() {
|
public synchronized void abort() {
|
||||||
mExecutor.submit(new Callable<Object>() {
|
mExecutor.submit(new Callable<Object>() {
|
||||||
@Override
|
@Override
|
||||||
|
@ -184,6 +202,12 @@ public class ResearchLog {
|
||||||
mFlushFuture = mExecutor.schedule(mFlushCallable, FLUSH_DELAY_IN_MS, TimeUnit.MILLISECONDS);
|
mFlushFuture = mExecutor.schedule(mFlushCallable, FLUSH_DELAY_IN_MS, TimeUnit.MILLISECONDS);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Queues up {@code logUnit} to be published in the background.
|
||||||
|
*
|
||||||
|
* @param logUnit the {@link LogUnit} to be published
|
||||||
|
* @param canIncludePrivateData whether private data in the LogUnit should be included
|
||||||
|
*/
|
||||||
public synchronized void publish(final LogUnit logUnit, final boolean canIncludePrivateData) {
|
public synchronized void publish(final LogUnit logUnit, final boolean canIncludePrivateData) {
|
||||||
try {
|
try {
|
||||||
mExecutor.submit(new Callable<Object>() {
|
mExecutor.submit(new Callable<Object>() {
|
||||||
|
|
Loading…
Reference in a new issue