2014-02-13 09:43:48 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2014 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.latin;
|
|
|
|
|
|
|
|
import com.android.inputmethod.keyboard.internal.KeySpecParser;
|
2014-10-23 09:37:32 +00:00
|
|
|
import com.android.inputmethod.latin.common.Constants;
|
2014-10-28 12:31:09 +00:00
|
|
|
import com.android.inputmethod.latin.common.StringUtils;
|
2014-02-13 09:43:48 +00:00
|
|
|
|
|
|
|
import java.util.ArrayList;
|
|
|
|
import java.util.Arrays;
|
|
|
|
|
2015-01-13 19:32:08 +00:00
|
|
|
import javax.annotation.Nullable;
|
|
|
|
|
2014-02-13 09:43:48 +00:00
|
|
|
/**
|
|
|
|
* The extended {@link SuggestedWords} class to represent punctuation suggestions.
|
|
|
|
*
|
|
|
|
* Each punctuation specification string is the key specification that can be parsed by
|
|
|
|
* {@link KeySpecParser}.
|
|
|
|
*/
|
|
|
|
public final class PunctuationSuggestions extends SuggestedWords {
|
|
|
|
private PunctuationSuggestions(final ArrayList<SuggestedWordInfo> punctuationsList) {
|
|
|
|
super(punctuationsList,
|
|
|
|
null /* rawSuggestions */,
|
2014-11-07 08:10:36 +00:00
|
|
|
null /* typedWord */,
|
2014-02-13 09:43:48 +00:00
|
|
|
false /* typedWordValid */,
|
|
|
|
false /* hasAutoCorrectionCandidate */,
|
|
|
|
false /* isObsoleteSuggestions */,
|
2014-11-07 08:10:36 +00:00
|
|
|
INPUT_STYLE_NONE /* inputStyle */,
|
|
|
|
SuggestedWords.NOT_A_SEQUENCE_NUMBER);
|
2014-02-13 09:43:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create new instance of {@link PunctuationSuggestions} from the array of punctuation key
|
|
|
|
* specifications.
|
|
|
|
*
|
|
|
|
* @param punctuationSpecs The array of punctuation key specifications.
|
|
|
|
* @return The {@link PunctuationSuggestions} object.
|
|
|
|
*/
|
|
|
|
public static PunctuationSuggestions newPunctuationSuggestions(
|
2015-01-13 19:32:08 +00:00
|
|
|
@Nullable final String[] punctuationSpecs) {
|
|
|
|
if (punctuationSpecs == null || punctuationSpecs.length == 0) {
|
|
|
|
return new PunctuationSuggestions(new ArrayList<SuggestedWordInfo>(0));
|
|
|
|
}
|
|
|
|
final ArrayList<SuggestedWordInfo> punctuationList =
|
|
|
|
new ArrayList<>(punctuationSpecs.length);
|
|
|
|
for (String spec : punctuationSpecs) {
|
|
|
|
punctuationList.add(newHardCodedWordInfo(spec));
|
2014-02-13 09:43:48 +00:00
|
|
|
}
|
2015-01-13 19:32:08 +00:00
|
|
|
return new PunctuationSuggestions(punctuationList);
|
2014-02-13 09:43:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* {@inheritDoc}
|
2014-10-22 05:04:07 +00:00
|
|
|
* Note that {@link SuggestedWords#getWord(int)} returns a punctuation key specification text.
|
2014-02-13 09:43:48 +00:00
|
|
|
* The suggested punctuation should be gotten by parsing the key specification.
|
|
|
|
*/
|
|
|
|
@Override
|
|
|
|
public String getWord(final int index) {
|
|
|
|
final String keySpec = super.getWord(index);
|
|
|
|
final int code = KeySpecParser.getCode(keySpec);
|
|
|
|
return (code == Constants.CODE_OUTPUT_TEXT)
|
|
|
|
? KeySpecParser.getOutputText(keySpec)
|
|
|
|
: StringUtils.newSingleCodePointString(code);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* {@inheritDoc}
|
2014-10-22 05:04:07 +00:00
|
|
|
* Note that {@link SuggestedWords#getWord(int)} returns a punctuation key specification text.
|
2014-02-13 09:43:48 +00:00
|
|
|
* The displayed text should be gotten by parsing the key specification.
|
|
|
|
*/
|
|
|
|
@Override
|
|
|
|
public String getLabel(final int index) {
|
|
|
|
final String keySpec = super.getWord(index);
|
|
|
|
return KeySpecParser.getLabel(keySpec);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* {@inheritDoc}
|
|
|
|
* Note that {@link #getWord(int)} returns a suggested punctuation. We should create a
|
2014-10-22 05:04:07 +00:00
|
|
|
* {@link SuggestedWords.SuggestedWordInfo} object that represents a hard coded word.
|
2014-02-13 09:43:48 +00:00
|
|
|
*/
|
|
|
|
@Override
|
|
|
|
public SuggestedWordInfo getInfo(final int index) {
|
|
|
|
return newHardCodedWordInfo(getWord(index));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The predicator to tell whether this object represents punctuation suggestions.
|
|
|
|
* @return true if this object represents punctuation suggestions.
|
|
|
|
*/
|
|
|
|
@Override
|
|
|
|
public boolean isPunctuationSuggestions() {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public String toString() {
|
|
|
|
return "PunctuationSuggestions: "
|
|
|
|
+ " words=" + Arrays.toString(mSuggestedWordInfoList.toArray());
|
|
|
|
}
|
|
|
|
|
|
|
|
private static SuggestedWordInfo newHardCodedWordInfo(final String keySpec) {
|
2015-03-19 23:07:04 +00:00
|
|
|
return new SuggestedWordInfo(keySpec, "" /* prevWordsContext */,
|
|
|
|
SuggestedWordInfo.MAX_SCORE,
|
2014-02-13 09:43:48 +00:00
|
|
|
SuggestedWordInfo.KIND_HARDCODED,
|
|
|
|
Dictionary.DICTIONARY_HARDCODED,
|
|
|
|
SuggestedWordInfo.NOT_AN_INDEX /* indexOfTouchPointOfSecondWord */,
|
|
|
|
SuggestedWordInfo.NOT_A_CONFIDENCE /* autoCommitFirstWordConfidence */);
|
|
|
|
}
|
|
|
|
}
|