48160f9d84
Change-Id: Ie3b70e6eadc2a9af5ef45ddfad6a3398cea7bfe8
152 lines
5.7 KiB
Java
152 lines
5.7 KiB
Java
/*
|
|
* Copyright (C) 2012 The Android Open Source Project
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License"); you may not
|
|
* use this file except in compliance with the License. You may obtain a copy of
|
|
* the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
* License for the specific language governing permissions and limitations under
|
|
* the License.
|
|
*/
|
|
|
|
package com.android.inputmethod.research;
|
|
|
|
import com.android.inputmethod.research.ResearchLogger.LogStatement;
|
|
|
|
import java.util.ArrayList;
|
|
import java.util.List;
|
|
|
|
/**
|
|
* A group of log statements related to each other.
|
|
*
|
|
* A LogUnit is collection of LogStatements, each of which is generated by at a particular point
|
|
* in the code. (There is no LogStatement class; the data is stored across the instance variables
|
|
* here.) A single LogUnit's statements can correspond to all the calls made while in the same
|
|
* composing region, or all the calls between committing the last composing region, and the first
|
|
* character of the next composing region.
|
|
*
|
|
* Individual statements in a log may be marked as potentially private. If so, then they are only
|
|
* published to a ResearchLog if the ResearchLogger determines that publishing the entire LogUnit
|
|
* will not violate the user's privacy. Checks for this may include whether other LogUnits have
|
|
* been published recently, or whether the LogUnit contains numbers, etc.
|
|
*/
|
|
/* package */ class LogUnit {
|
|
private final ArrayList<LogStatement> mLogStatementList;
|
|
private final ArrayList<Object[]> mValuesList;
|
|
// Assume that mTimeList is sorted in increasing order. Do not insert null values into
|
|
// mTimeList.
|
|
private final ArrayList<Long> mTimeList;
|
|
private String mWord;
|
|
private boolean mMayContainDigit;
|
|
private boolean mIsPartOfMegaword;
|
|
|
|
public LogUnit() {
|
|
mLogStatementList = new ArrayList<LogStatement>();
|
|
mValuesList = new ArrayList<Object[]>();
|
|
mTimeList = new ArrayList<Long>();
|
|
mIsPartOfMegaword = false;
|
|
}
|
|
|
|
private LogUnit(final ArrayList<LogStatement> logStatementList,
|
|
final ArrayList<Object[]> valuesList,
|
|
final ArrayList<Long> timeList,
|
|
final boolean isPartOfMegaword) {
|
|
mLogStatementList = logStatementList;
|
|
mValuesList = valuesList;
|
|
mTimeList = timeList;
|
|
mIsPartOfMegaword = isPartOfMegaword;
|
|
}
|
|
|
|
private static final Object[] NULL_VALUES = new Object[0];
|
|
/**
|
|
* Adds a new log statement. The time parameter in successive calls to this method must be
|
|
* monotonically increasing, or splitByTime() will not work.
|
|
*/
|
|
public void addLogStatement(final LogStatement logStatement, final long time,
|
|
Object... values) {
|
|
if (values == null) {
|
|
values = NULL_VALUES;
|
|
}
|
|
mLogStatementList.add(logStatement);
|
|
mValuesList.add(values);
|
|
mTimeList.add(time);
|
|
}
|
|
|
|
public void publishTo(final ResearchLog researchLog, final boolean isIncludingPrivateData) {
|
|
final int size = mLogStatementList.size();
|
|
for (int i = 0; i < size; i++) {
|
|
final LogStatement logStatement = mLogStatementList.get(i);
|
|
if (!isIncludingPrivateData && logStatement.mIsPotentiallyPrivate) {
|
|
continue;
|
|
}
|
|
if (mIsPartOfMegaword && logStatement.mIsPotentiallyRevealing) {
|
|
continue;
|
|
}
|
|
researchLog.outputEvent(mLogStatementList.get(i), mValuesList.get(i), mTimeList.get(i));
|
|
}
|
|
}
|
|
|
|
public void setWord(String word) {
|
|
mWord = word;
|
|
}
|
|
|
|
public String getWord() {
|
|
return mWord;
|
|
}
|
|
|
|
public boolean hasWord() {
|
|
return mWord != null;
|
|
}
|
|
|
|
public void setMayContainDigit() {
|
|
mMayContainDigit = true;
|
|
}
|
|
|
|
public boolean mayContainDigit() {
|
|
return mMayContainDigit;
|
|
}
|
|
|
|
public boolean isEmpty() {
|
|
return mLogStatementList.isEmpty();
|
|
}
|
|
|
|
/**
|
|
* Split this logUnit, with all events before maxTime staying in the current logUnit, and all
|
|
* events after maxTime going into a new LogUnit that is returned.
|
|
*/
|
|
public LogUnit splitByTime(final long maxTime) {
|
|
// Assume that mTimeList is in sorted order.
|
|
final int length = mTimeList.size();
|
|
for (int index = 0; index < length; index++) {
|
|
if (mTimeList.get(index) > maxTime) {
|
|
final List<LogStatement> laterLogStatements =
|
|
mLogStatementList.subList(index, length);
|
|
final List<Object[]> laterValues = mValuesList.subList(index, length);
|
|
final List<Long> laterTimes = mTimeList.subList(index, length);
|
|
|
|
// Create the LogUnit containing the later logStatements and associated data.
|
|
final LogUnit newLogUnit = new LogUnit(
|
|
new ArrayList<LogStatement>(laterLogStatements),
|
|
new ArrayList<Object[]>(laterValues),
|
|
new ArrayList<Long>(laterTimes),
|
|
true /* isPartOfMegaword */);
|
|
newLogUnit.mWord = null;
|
|
newLogUnit.mMayContainDigit = mMayContainDigit;
|
|
|
|
// Purge the logStatements and associated data from this LogUnit.
|
|
laterLogStatements.clear();
|
|
laterValues.clear();
|
|
laterTimes.clear();
|
|
mIsPartOfMegaword = true;
|
|
|
|
return newLogUnit;
|
|
}
|
|
}
|
|
return new LogUnit();
|
|
}
|
|
}
|