summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNiels Egberts <nielse@google.com>2014-07-08 13:45:14 +0100
committerNiels Egberts <nielse@google.com>2014-07-08 14:53:35 +0100
commit34d4ac88f70c37cbe143ab01b40f343bcf02035f (patch)
tree63f666ed2dd0dc90f98effb6b59a68b157a5aa6b
parent4143bc5f09a0ff73ca92caf3b2012c0ffd780555 (diff)
Remove Markup and Utterance classes.
Markup is replaced by TtsSpan, and the Utterance class will be replaced by TtsSpanBuilder. Change-Id: I443786681f065ad8458fc05825de3ef182db8062
-rw-r--r--api/current.txt101
-rw-r--r--core/java/android/speech/tts/Markup.java537
-rw-r--r--core/java/android/speech/tts/Utterance.java595
-rw-r--r--tests/TtsTests/src/com/android/speech/tts/AbstractTtsSemioticClassTest.java189
-rw-r--r--tests/TtsTests/src/com/android/speech/tts/AbstractTtsTest.java106
-rw-r--r--tests/TtsTests/src/com/android/speech/tts/MarkupTest.java510
-rw-r--r--tests/TtsTests/src/com/android/speech/tts/TtsCardinalTest.java119
-rw-r--r--tests/TtsTests/src/com/android/speech/tts/TtsTextTest.java74
-rw-r--r--tests/TtsTests/src/com/android/speech/tts/UtteranceTest.java248
9 files changed, 0 insertions, 2479 deletions
diff --git a/api/current.txt b/api/current.txt
index 8890d6d408b4..66801426139b 100644
--- a/api/current.txt
+++ b/api/current.txt
@@ -26580,28 +26580,6 @@ package android.speech {
package android.speech.tts {
- public final class Markup implements android.os.Parcelable {
- ctor public Markup();
- ctor public Markup(java.lang.String);
- ctor public Markup(android.speech.tts.Markup);
- method public android.speech.tts.Markup addNestedMarkup(android.speech.tts.Markup);
- method public int describeContents();
- method public android.speech.tts.Markup getNestedMarkup(int);
- method public java.util.List<android.speech.tts.Markup> getNestedMarkups();
- method public java.lang.String getParameter(java.lang.String);
- method public java.lang.String getPlainText();
- method public java.lang.String getType();
- method public static android.speech.tts.Markup markupFromString(java.lang.String) throws java.lang.IllegalArgumentException;
- method public int nestedMarkupSize();
- method public int parametersSize();
- method public boolean removeNestedMarkup(android.speech.tts.Markup);
- method public void removeParameter(java.lang.String);
- method public android.speech.tts.Markup setParameter(java.lang.String, java.lang.String);
- method public void setPlainText(java.lang.String);
- method public void setType(java.lang.String);
- method public void writeToParcel(android.os.Parcel, int);
- }
-
public abstract interface SynthesisCallback {
method public abstract int audioAvailable(byte[], int, int);
method public abstract int done();
@@ -26751,85 +26729,6 @@ package android.speech.tts {
method protected abstract void onSynthesizeText(android.speech.tts.SynthesisRequest, android.speech.tts.SynthesisCallback);
}
- public class Utterance {
- ctor public Utterance();
- method public android.speech.tts.Utterance append(android.speech.tts.Utterance.AbstractTts<? extends android.speech.tts.Utterance.AbstractTts<?>>);
- method public android.speech.tts.Utterance append(java.lang.String);
- method public android.speech.tts.Utterance append(int);
- method public android.speech.tts.Markup createMarkup();
- method public android.speech.tts.Utterance.AbstractTts<? extends android.speech.tts.Utterance.AbstractTts<?>> get(int);
- method public android.speech.tts.Utterance setNoWarningOnFallback(boolean);
- method public int size();
- method public static android.speech.tts.Utterance utteranceFromString(java.lang.String) throws java.lang.IllegalArgumentException;
- field public static final int ANIMACY_ANIMATE = 1; // 0x1
- field public static final int ANIMACY_INANIMATE = 2; // 0x2
- field public static final int ANIMACY_UNKNOWN = 0; // 0x0
- field public static final int CASE_ABLATIVE = 4; // 0x4
- field public static final int CASE_ACCUSATIVE = 2; // 0x2
- field public static final int CASE_DATIVE = 3; // 0x3
- field public static final int CASE_GENITIVE = 5; // 0x5
- field public static final int CASE_INSTRUMENTAL = 8; // 0x8
- field public static final int CASE_LOCATIVE = 7; // 0x7
- field public static final int CASE_NOMINATIVE = 1; // 0x1
- field public static final int CASE_UNKNOWN = 0; // 0x0
- field public static final int CASE_VOCATIVE = 6; // 0x6
- field public static final int GENDER_FEMALE = 3; // 0x3
- field public static final int GENDER_MALE = 2; // 0x2
- field public static final int GENDER_NEUTRAL = 1; // 0x1
- field public static final int GENDER_UNKNOWN = 0; // 0x0
- field public static final java.lang.String KEY_NO_WARNING_ON_FALLBACK = "no_warning_on_fallback";
- field public static final int MULTIPLICITY_DUAL = 2; // 0x2
- field public static final int MULTIPLICITY_PLURAL = 3; // 0x3
- field public static final int MULTIPLICITY_SINGLE = 1; // 0x1
- field public static final int MULTIPLICITY_UNKNOWN = 0; // 0x0
- field public static final java.lang.String TYPE_UTTERANCE = "utterance";
- }
-
- public static abstract class Utterance.AbstractTts {
- ctor protected Utterance.AbstractTts();
- ctor protected Utterance.AbstractTts(android.speech.tts.Markup);
- method public java.lang.String generatePlainText();
- method public android.speech.tts.Markup getMarkup();
- method protected java.lang.String getParameter(java.lang.String);
- method public java.lang.String getPlainText();
- method public java.lang.String getType();
- method protected C removeParameter(java.lang.String);
- method protected C setParameter(java.lang.String, java.lang.String);
- method public C setPlainText(java.lang.String);
- field protected android.speech.tts.Markup mMarkup;
- }
-
- public static abstract class Utterance.AbstractTtsSemioticClass extends android.speech.tts.Utterance.AbstractTts {
- ctor protected Utterance.AbstractTtsSemioticClass();
- ctor protected Utterance.AbstractTtsSemioticClass(android.speech.tts.Markup);
- method public int getAnimacy();
- method public int getCase();
- method public int getGender();
- method public int getMultiplicity();
- method public C setAnimacy(int);
- method public C setCase(int);
- method public C setGender(int);
- method public C setMultiplicity(int);
- }
-
- public static class Utterance.TtsCardinal extends android.speech.tts.Utterance.AbstractTtsSemioticClass {
- ctor public Utterance.TtsCardinal();
- ctor public Utterance.TtsCardinal(int);
- ctor public Utterance.TtsCardinal(java.lang.String);
- method public java.lang.String getInteger();
- method public android.speech.tts.Utterance.TtsCardinal setInteger(int);
- method public android.speech.tts.Utterance.TtsCardinal setInteger(java.lang.String);
- field protected static final java.lang.String TYPE_CARDINAL = "cardinal";
- }
-
- public static class Utterance.TtsText extends android.speech.tts.Utterance.AbstractTtsSemioticClass {
- ctor public Utterance.TtsText();
- ctor public Utterance.TtsText(java.lang.String);
- method public java.lang.String getText();
- method public android.speech.tts.Utterance.TtsText setText(java.lang.String);
- field protected static final java.lang.String TYPE_TEXT = "text";
- }
-
public abstract class UtteranceProgressListener {
ctor public UtteranceProgressListener();
method public abstract void onDone(java.lang.String);
diff --git a/core/java/android/speech/tts/Markup.java b/core/java/android/speech/tts/Markup.java
deleted file mode 100644
index c886e5d57e84..000000000000
--- a/core/java/android/speech/tts/Markup.java
+++ /dev/null
@@ -1,537 +0,0 @@
-package android.speech.tts;
-
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.List;
-import java.util.Map;
-import java.util.Set;
-import java.util.SortedMap;
-import java.util.TreeMap;
-import java.util.regex.Matcher;
-import java.util.regex.Pattern;
-
-import android.os.Bundle;
-import android.os.Parcel;
-import android.os.Parcelable;
-
-/**
- * A class that provides markup to a synthesis request to control aspects of speech.
- * <p>
- * Markup itself is a feature agnostic data format; the {@link Utterance} class defines the currently
- * available set of features and should be used to construct instances of the Markup class.
- * </p>
- * <p>
- * A marked up sentence is a tree. Each node has a type, an optional plain text, a set of
- * parameters, and a list of children.
- * The <b>type</b> defines what it contains, e.g. "text", "date", "measure", etc. A Markup node
- * can be either a part of sentence (often a leaf node), or node altering some property of its
- * children (node with children). The top level node has to be of type "utterance" and its children
- * are synthesized in order.
- * The <b>plain text</b> is optional except for the top level node. If the synthesis engine does not
- * support Markup at all, it should use the plain text of the top level node. If an engine does not
- * recognize or support a node type, it will try to use the plain text of that node if provided. If
- * the plain text is null, it will synthesize its children in order.
- * <b>Parameters</b> are key-value pairs specific to each node type. In case of a date node the
- * parameters may be for example "month: 7" and "day: 10".
- * The <b>nested markups</b> are children and can for example be used to nest semiotic classes (a
- * measure may have a node of type "decimal" as its child) or to modify some property of its
- * children. See "plain text" on how they are processed if the parent of the children is unknown to
- * the engine.
- * <p>
- */
-public final class Markup implements Parcelable {
-
- private String mType;
- private String mPlainText;
-
- private Bundle mParameters = new Bundle();
- private List<Markup> mNestedMarkups = new ArrayList<Markup>();
-
- private static final String TYPE = "type";
- private static final String PLAIN_TEXT = "plain_text";
- private static final String MARKUP = "markup";
-
- private static final String IDENTIFIER_REGEX = "([0-9a-z_]+)";
- private static final Pattern legalIdentifierPattern = Pattern.compile(IDENTIFIER_REGEX);
-
- /**
- * Constructs an empty markup.
- */
- public Markup() {}
-
- /**
- * Constructs a markup of the given type.
- */
- public Markup(String type) {
- setType(type);
- }
-
- /**
- * Returns the type of this node; can be null.
- */
- public String getType() {
- return mType;
- }
-
- /**
- * Sets the type of this node. can be null. May only contain [0-9a-z_].
- */
- public void setType(String type) {
- if (type != null) {
- Matcher matcher = legalIdentifierPattern.matcher(type);
- if (!matcher.matches()) {
- throw new IllegalArgumentException("Type cannot be empty and may only contain " +
- "0-9, a-z and underscores.");
- }
- }
- mType = type;
- }
-
- /**
- * Returns this node's plain text; can be null.
- */
- public String getPlainText() {
- return mPlainText;
- }
-
- /**
- * Sets this nodes's plain text; can be null.
- */
- public void setPlainText(String plainText) {
- mPlainText = plainText;
- }
-
- /**
- * Adds or modifies a parameter.
- * @param key The key; may only contain [0-9a-z_] and cannot be "type" or "plain_text".
- * @param value The value.
- * @throws An {@link IllegalArgumentException} if the key is null or empty.
- * @return this
- */
- public Markup setParameter(String key, String value) {
- if (key == null || key.isEmpty()) {
- throw new IllegalArgumentException("Key cannot be null or empty.");
- }
- if (key.equals("type")) {
- throw new IllegalArgumentException("Key cannot be \"type\".");
- }
- if (key.equals("plain_text")) {
- throw new IllegalArgumentException("Key cannot be \"plain_text\".");
- }
- Matcher matcher = legalIdentifierPattern.matcher(key);
- if (!matcher.matches()) {
- throw new IllegalArgumentException("Key may only contain 0-9, a-z and underscores.");
- }
-
- if (value != null) {
- mParameters.putString(key, value);
- } else {
- removeParameter(key);
- }
- return this;
- }
-
- /**
- * Removes the parameter with the given key
- */
- public void removeParameter(String key) {
- mParameters.remove(key);
- }
-
- /**
- * Returns the value of the parameter.
- * @param key The parameter key.
- * @return The value of the parameter or null if the parameter is not set.
- */
- public String getParameter(String key) {
- return mParameters.getString(key);
- }
-
- /**
- * Returns the number of parameters that have been set.
- */
- public int parametersSize() {
- return mParameters.size();
- }
-
- /**
- * Appends a child to the list of children
- * @param markup The child.
- * @return This instance.
- * @throws {@link IllegalArgumentException} if markup is null.
- */
- public Markup addNestedMarkup(Markup markup) {
- if (markup == null) {
- throw new IllegalArgumentException("Nested markup cannot be null");
- }
- mNestedMarkups.add(markup);
- return this;
- }
-
- /**
- * Removes the given node from its children.
- * @param markup The child to remove.
- * @return True if this instance was modified by this operation, false otherwise.
- */
- public boolean removeNestedMarkup(Markup markup) {
- return mNestedMarkups.remove(markup);
- }
-
- /**
- * Returns the index'th child.
- * @param i The index of the child.
- * @return The child.
- * @throws {@link IndexOutOfBoundsException} if i < 0 or i >= nestedMarkupSize()
- */
- public Markup getNestedMarkup(int i) {
- return mNestedMarkups.get(i);
- }
-
-
- /**
- * Returns the number of children.
- */
- public int nestedMarkupSize() {
- return mNestedMarkups.size();
- }
-
- /**
- * Returns a string representation of this Markup instance. Can be deserialized back to a Markup
- * instance with markupFromString().
- */
- public String toString() {
- StringBuilder out = new StringBuilder();
- if (mType != null) {
- out.append(TYPE + ": \"" + mType + "\"");
- }
- if (mPlainText != null) {
- out.append(out.length() > 0 ? " " : "");
- out.append(PLAIN_TEXT + ": \"" + escapeQuotedString(mPlainText) + "\"");
- }
- // Sort the parameters alphabetically by key so we have a stable output.
- SortedMap<String, String> sortedMap = new TreeMap<String, String>();
- for (String key : mParameters.keySet()) {
- sortedMap.put(key, mParameters.getString(key));
- }
- for (Map.Entry<String, String> entry : sortedMap.entrySet()) {
- out.append(out.length() > 0 ? " " : "");
- out.append(entry.getKey() + ": \"" + escapeQuotedString(entry.getValue()) + "\"");
- }
- for (Markup m : mNestedMarkups) {
- out.append(out.length() > 0 ? " " : "");
- String nestedStr = m.toString();
- if (nestedStr.isEmpty()) {
- out.append(MARKUP + " {}");
- } else {
- out.append(MARKUP + " { " + m.toString() + " }");
- }
- }
- return out.toString();
- }
-
- /**
- * Escapes backslashes and double quotes in the plain text and parameter values before this
- * instance is written to a string.
- * @param str The string to escape.
- * @return The escaped string.
- */
- private static String escapeQuotedString(String str) {
- StringBuilder out = new StringBuilder();
- for (int i = 0; i < str.length(); i++) {
- char c = str.charAt(i);
- if (c == '"') {
- out.append("\\\"");
- } else if (str.charAt(i) == '\\') {
- out.append("\\\\");
- } else {
- out.append(c);
- }
- }
- return out.toString();
- }
-
- /**
- * The reverse of the escape method, returning plain text and parameter values to their original
- * form.
- * @param str An escaped string.
- * @return The unescaped string.
- */
- private static String unescapeQuotedString(String str) {
- StringBuilder out = new StringBuilder();
- for (int i = 0; i < str.length(); i++) {
- char c = str.charAt(i);
- if (c == '\\') {
- i++;
- if (i >= str.length()) {
- throw new IllegalArgumentException("Unterminated escape sequence in string: " +
- str);
- }
- c = str.charAt(i);
- if (c == '\\') {
- out.append("\\");
- } else if (c == '"') {
- out.append("\"");
- } else {
- throw new IllegalArgumentException("Unsupported escape sequence: \\" + c +
- " in string " + str);
- }
- } else {
- out.append(c);
- }
- }
- return out.toString();
- }
-
- /**
- * Returns true if the given string consists only of whitespace.
- * @param str The string to check.
- * @return True if the given string consists only of whitespace.
- */
- private static boolean isWhitespace(String str) {
- return Pattern.matches("\\s*", str);
- }
-
- /**
- * Parses the given string, and overrides the values of this instance with those contained
- * in the given string.
- * @param str The string to parse; can have superfluous whitespace.
- * @return An empty string on success, else the remainder of the string that could not be
- * parsed.
- */
- private String fromReadableString(String str) {
- while (!isWhitespace(str)) {
- String newStr = matchValue(str);
- if (newStr == null) {
- newStr = matchMarkup(str);
-
- if (newStr == null) {
- return str;
- }
- }
- str = newStr;
- }
- return "";
- }
-
- // Matches: key : "value"
- // where key is an identifier and value can contain escaped quotes
- // there may be superflouous whitespace
- // The value string may contain quotes and backslashes.
- private static final String OPTIONAL_WHITESPACE = "\\s*";
- private static final String VALUE_REGEX = "((\\\\.|[^\\\"])*)";
- private static final String KEY_VALUE_REGEX =
- "\\A" + OPTIONAL_WHITESPACE + // start of string
- IDENTIFIER_REGEX + OPTIONAL_WHITESPACE + ":" + OPTIONAL_WHITESPACE + // key:
- "\"" + VALUE_REGEX + "\""; // "value"
- private static final Pattern KEY_VALUE_PATTERN = Pattern.compile(KEY_VALUE_REGEX);
-
- /**
- * Tries to match a key-value pair at the start of the string. If found, add that as a parameter
- * of this instance.
- * @param str The string to parse.
- * @return The remainder of the string without the parsed key-value pair on success, else null.
- */
- private String matchValue(String str) {
- // Matches: key: "value"
- Matcher matcher = KEY_VALUE_PATTERN.matcher(str);
- if (!matcher.find()) {
- return null;
- }
- String key = matcher.group(1);
- String value = matcher.group(2);
-
- if (key == null || value == null) {
- return null;
- }
- String unescapedValue = unescapeQuotedString(value);
- if (key.equals(TYPE)) {
- this.mType = unescapedValue;
- } else if (key.equals(PLAIN_TEXT)) {
- this.mPlainText = unescapedValue;
- } else {
- setParameter(key, unescapedValue);
- }
-
- return str.substring(matcher.group(0).length());
- }
-
- // matches 'markup {'
- private static final Pattern OPEN_MARKUP_PATTERN =
- Pattern.compile("\\A" + OPTIONAL_WHITESPACE + MARKUP + OPTIONAL_WHITESPACE + "\\{");
- // matches '}'
- private static final Pattern CLOSE_MARKUP_PATTERN =
- Pattern.compile("\\A" + OPTIONAL_WHITESPACE + "\\}");
-
- /**
- * Tries to parse a Markup specification from the start of the string. If so, add that markup to
- * the list of nested Markup's of this instance.
- * @param str The string to parse.
- * @return The remainder of the string without the parsed Markup on success, else null.
- */
- private String matchMarkup(String str) {
- // find and strip "markup {"
- Matcher matcher = OPEN_MARKUP_PATTERN.matcher(str);
-
- if (!matcher.find()) {
- return null;
- }
- String strRemainder = str.substring(matcher.group(0).length());
- // parse and strip markup contents
- Markup nestedMarkup = new Markup();
- strRemainder = nestedMarkup.fromReadableString(strRemainder);
-
- // find and strip "}"
- Matcher matcherClose = CLOSE_MARKUP_PATTERN.matcher(strRemainder);
- if (!matcherClose.find()) {
- return null;
- }
- strRemainder = strRemainder.substring(matcherClose.group(0).length());
-
- // Everything parsed, add markup
- this.addNestedMarkup(nestedMarkup);
-
- // Return remainder
- return strRemainder;
- }
-
- /**
- * Returns a Markup instance from the string representation generated by toString().
- * @param string The string representation generated by toString().
- * @return The new Markup instance.
- * @throws {@link IllegalArgumentException} if the input cannot be correctly parsed.
- */
- public static Markup markupFromString(String string) throws IllegalArgumentException {
- Markup m = new Markup();
- if (m.fromReadableString(string).isEmpty()) {
- return m;
- } else {
- throw new IllegalArgumentException("Cannot parse input to Markup");
- }
- }
-
- /**
- * Compares the specified object with this Markup for equality.
- * @return True if the given object is a Markup instance with the same type, plain text,
- * parameters and the nested markups are also equal to each other and in the same order.
- */
- @Override
- public boolean equals(Object o) {
- if ( this == o ) return true;
- if ( !(o instanceof Markup) ) return false;
- Markup m = (Markup) o;
-
- if (nestedMarkupSize() != this.nestedMarkupSize()) {
- return false;
- }
-
- if (!(mType == null ? m.mType == null : mType.equals(m.mType))) {
- return false;
- }
- if (!(mPlainText == null ? m.mPlainText == null : mPlainText.equals(m.mPlainText))) {
- return false;
- }
- if (!equalBundles(mParameters, m.mParameters)) {
- return false;
- }
-
- for (int i = 0; i < this.nestedMarkupSize(); i++) {
- if (!mNestedMarkups.get(i).equals(m.mNestedMarkups.get(i))) {
- return false;
- }
- }
-
- return true;
- }
-
- /**
- * Checks if two bundles are equal to each other. Used by equals(o).
- */
- private boolean equalBundles(Bundle one, Bundle two) {
- if (one == null || two == null) {
- return false;
- }
-
- if(one.size() != two.size()) {
- return false;
- }
-
- Set<String> valuesOne = one.keySet();
- for(String key : valuesOne) {
- Object valueOne = one.get(key);
- Object valueTwo = two.get(key);
- if (valueOne instanceof Bundle && valueTwo instanceof Bundle &&
- !equalBundles((Bundle) valueOne, (Bundle) valueTwo)) {
- return false;
- } else if (valueOne == null) {
- if (valueTwo != null || !two.containsKey(key)) {
- return false;
- }
- } else if(!valueOne.equals(valueTwo)) {
- return false;
- }
- }
- return true;
- }
-
- /**
- * Returns an unmodifiable list of the children.
- * @return An unmodifiable list of children that throws an {@link UnsupportedOperationException}
- * if an attempt is made to modify it
- */
- public List<Markup> getNestedMarkups() {
- return Collections.unmodifiableList(mNestedMarkups);
- }
-
- /**
- * @hide
- */
- public Markup(Parcel in) {
- mType = in.readString();
- mPlainText = in.readString();
- mParameters = in.readBundle();
- in.readList(mNestedMarkups, Markup.class.getClassLoader());
- }
-
- /**
- * Creates a deep copy of the given markup.
- */
- public Markup(Markup markup) {
- mType = markup.mType;
- mPlainText = markup.mPlainText;
- mParameters = markup.mParameters;
- for (Markup nested : markup.getNestedMarkups()) {
- addNestedMarkup(new Markup(nested));
- }
- }
-
- /**
- * @hide
- */
- public int describeContents() {
- return 0;
- }
-
- /**
- * @hide
- */
- public void writeToParcel(Parcel dest, int flags) {
- dest.writeString(mType);
- dest.writeString(mPlainText);
- dest.writeBundle(mParameters);
- dest.writeList(mNestedMarkups);
- }
-
- /**
- * @hide
- */
- public static final Parcelable.Creator CREATOR = new Parcelable.Creator() {
- public Markup createFromParcel(Parcel in) {
- return new Markup(in);
- }
-
- public Markup[] newArray(int size) {
- return new Markup[size];
- }
- };
-}
-
diff --git a/core/java/android/speech/tts/Utterance.java b/core/java/android/speech/tts/Utterance.java
deleted file mode 100644
index 0a2928300e12..000000000000
--- a/core/java/android/speech/tts/Utterance.java
+++ /dev/null
@@ -1,595 +0,0 @@
-package android.speech.tts;
-
-import java.util.ArrayList;
-import java.util.List;
-
-/**
- * This class acts as a builder for {@link Markup} instances.
- * <p>
- * Each Utterance consists of a list of the semiotic classes ({@link Utterance.TtsCardinal} and
- * {@link Utterance.TtsText}).
- * <p>Each semiotic class can be supplied with morphosyntactic features
- * (gender, animacy, multiplicity and case), it is up to the synthesis engine to use this
- * information during synthesis.
- * Examples where morphosyntactic features matter:
- * <ul>
- * <li>In French, the number one is verbalized differently based on the gender of the noun
- * it modifies. "un homme" (one man) versus "une femme" (one woman).
- * <li>In German the grammatical case (accusative, locative, etc) needs to be included to be
- * verbalize correctly. In German you'd have the sentence "Sie haben 1 kilometer vor Ihnen" (You
- * have 1 kilometer ahead of you), "1" in this case needs to become inflected to the accusative
- * form ("einen") instead of the nominative form "ein".
- * </p>
- * <p>
- * Utterance usage example:
- * Markup m1 = new Utterance().append("The Eiffel Tower is")
- * .append(new TtsCardinal(324))
- * .append("meters tall.");
- * Markup m2 = new Utterance().append("Sie haben")
- * .append(new TtsCardinal(1).setGender(Utterance.GENDER_MALE)
- * .append("Tag frei.");
- * </p>
- */
-public class Utterance {
-
- /***
- * Toplevel type of markup representation.
- */
- public static final String TYPE_UTTERANCE = "utterance";
- /***
- * The no_warning_on_fallback parameter can be set to "false" or "true", true indicating that
- * no warning will be given when the synthesizer does not support Markup. This is used when
- * the user only provides a string to the API instead of a markup.
- */
- public static final String KEY_NO_WARNING_ON_FALLBACK = "no_warning_on_fallback";
-
- // Gender.
- public final static int GENDER_UNKNOWN = 0;
- public final static int GENDER_NEUTRAL = 1;
- public final static int GENDER_MALE = 2;
- public final static int GENDER_FEMALE = 3;
-
- // Animacy.
- public final static int ANIMACY_UNKNOWN = 0;
- public final static int ANIMACY_ANIMATE = 1;
- public final static int ANIMACY_INANIMATE = 2;
-
- // Multiplicity.
- public final static int MULTIPLICITY_UNKNOWN = 0;
- public final static int MULTIPLICITY_SINGLE = 1;
- public final static int MULTIPLICITY_DUAL = 2;
- public final static int MULTIPLICITY_PLURAL = 3;
-
- // Case.
- public final static int CASE_UNKNOWN = 0;
- public final static int CASE_NOMINATIVE = 1;
- public final static int CASE_ACCUSATIVE = 2;
- public final static int CASE_DATIVE = 3;
- public final static int CASE_ABLATIVE = 4;
- public final static int CASE_GENITIVE = 5;
- public final static int CASE_VOCATIVE = 6;
- public final static int CASE_LOCATIVE = 7;
- public final static int CASE_INSTRUMENTAL = 8;
-
- private List<AbstractTts<? extends AbstractTts<?>>> says =
- new ArrayList<AbstractTts<? extends AbstractTts<?>>>();
- Boolean mNoWarningOnFallback = null;
-
- /**
- * Objects deriving from this class can be appended to a Utterance. This class uses generics
- * so method from this class can return instances of its child classes, resulting in a better
- * API (CRTP pattern).
- */
- public static abstract class AbstractTts<C extends AbstractTts<C>> {
-
- protected Markup mMarkup = new Markup();
-
- /**
- * Empty constructor.
- */
- protected AbstractTts() {
- }
-
- /**
- * Construct with Markup.
- * @param markup
- */
- protected AbstractTts(Markup markup) {
- mMarkup = markup;
- }
-
- /**
- * Returns the type of this class, e.g. "cardinal" or "measure".
- * @return The type.
- */
- public String getType() {
- return mMarkup.getType();
- }
-
- /**
- * A fallback plain text can be provided, in case the engine does not support this class
- * type, or even Markup altogether.
- * @param plainText A string with the plain text.
- * @return This instance.
- */
- @SuppressWarnings("unchecked")
- public C setPlainText(String plainText) {
- mMarkup.setPlainText(plainText);
- return (C) this;
- }
-
- /**
- * Returns the plain text (fallback) string.
- * @return Plain text string or null if not set.
- */
- public String getPlainText() {
- return mMarkup.getPlainText();
- }
-
- /**
- * Populates the plainText if not set and builds a Markup instance.
- * @return The Markup object describing this instance.
- */
- public Markup getMarkup() {
- return new Markup(mMarkup);
- }
-
- @SuppressWarnings("unchecked")
- protected C setParameter(String key, String value) {
- mMarkup.setParameter(key, value);
- return (C) this;
- }
-
- protected String getParameter(String key) {
- return mMarkup.getParameter(key);
- }
-
- @SuppressWarnings("unchecked")
- protected C removeParameter(String key) {
- mMarkup.removeParameter(key);
- return (C) this;
- }
-
- /**
- * Returns a string representation of this instance, can be deserialized to an equal
- * Utterance instance.
- */
- public String toString() {
- return mMarkup.toString();
- }
-
- /**
- * Returns a generated plain text alternative for this instance if this instance isn't
- * better representated by the list of it's children.
- * @return Best effort plain text representation of this instance, can be null.
- */
- public String generatePlainText() {
- return null;
- }
- }
-
- public static abstract class AbstractTtsSemioticClass<C extends AbstractTtsSemioticClass<C>>
- extends AbstractTts<C> {
- // Keys.
- private static final String KEY_GENDER = "gender";
- private static final String KEY_ANIMACY = "animacy";
- private static final String KEY_MULTIPLICITY = "multiplicity";
- private static final String KEY_CASE = "case";
-
- protected AbstractTtsSemioticClass() {
- super();
- }
-
- protected AbstractTtsSemioticClass(Markup markup) {
- super(markup);
- }
-
- @SuppressWarnings("unchecked")
- public C setGender(int gender) {
- if (gender < 0 || gender > 3) {
- throw new IllegalArgumentException("Only four types of gender can be set: " +
- "unknown, neutral, maculine and female.");
- }
- if (gender != GENDER_UNKNOWN) {
- setParameter(KEY_GENDER, String.valueOf(gender));
- } else {
- setParameter(KEY_GENDER, null);
- }
- return (C) this;
- }
-
- public int getGender() {
- String gender = mMarkup.getParameter(KEY_GENDER);
- return gender != null ? Integer.valueOf(gender) : GENDER_UNKNOWN;
- }
-
- @SuppressWarnings("unchecked")
- public C setAnimacy(int animacy) {
- if (animacy < 0 || animacy > 2) {
- throw new IllegalArgumentException(
- "Only two types of animacy can be set: unknown, animate and inanimate");
- }
- if (animacy != ANIMACY_UNKNOWN) {
- setParameter(KEY_ANIMACY, String.valueOf(animacy));
- } else {
- setParameter(KEY_ANIMACY, null);
- }
- return (C) this;
- }
-
- public int getAnimacy() {
- String animacy = getParameter(KEY_ANIMACY);
- return animacy != null ? Integer.valueOf(animacy) : ANIMACY_UNKNOWN;
- }
-
- @SuppressWarnings("unchecked")
- public C setMultiplicity(int multiplicity) {
- if (multiplicity < 0 || multiplicity > 3) {
- throw new IllegalArgumentException(
- "Only four types of multiplicity can be set: unknown, single, dual and " +
- "plural.");
- }
- if (multiplicity != MULTIPLICITY_UNKNOWN) {
- setParameter(KEY_MULTIPLICITY, String.valueOf(multiplicity));
- } else {
- setParameter(KEY_MULTIPLICITY, null);
- }
- return (C) this;
- }
-
- public int getMultiplicity() {
- String multiplicity = mMarkup.getParameter(KEY_MULTIPLICITY);
- return multiplicity != null ? Integer.valueOf(multiplicity) : MULTIPLICITY_UNKNOWN;
- }
-
- @SuppressWarnings("unchecked")
- public C setCase(int grammaticalCase) {
- if (grammaticalCase < 0 || grammaticalCase > 8) {
- throw new IllegalArgumentException(
- "Only nine types of grammatical case can be set.");
- }
- if (grammaticalCase != CASE_UNKNOWN) {
- setParameter(KEY_CASE, String.valueOf(grammaticalCase));
- } else {
- setParameter(KEY_CASE, null);
- }
- return (C) this;
- }
-
- public int getCase() {
- String grammaticalCase = mMarkup.getParameter(KEY_CASE);
- return grammaticalCase != null ? Integer.valueOf(grammaticalCase) : CASE_UNKNOWN;
- }
- }
-
- /**
- * Class that contains regular text, synthesis engine pronounces it using its regular pipeline.
- * Parameters:
- * <ul>
- * <li>Text: the text to synthesize</li>
- * </ul>
- */
- public static class TtsText extends AbstractTtsSemioticClass<TtsText> {
-
- // The type of this node.
- protected static final String TYPE_TEXT = "text";
- // The text parameter stores the text to be synthesized.
- private static final String KEY_TEXT = "text";
-
- /**
- * Default constructor.
- */
- public TtsText() {
- mMarkup.setType(TYPE_TEXT);
- }
-
- /**
- * Constructor that sets the text to be synthesized.
- * @param text The text to be synthesized.
- */
- public TtsText(String text) {
- this();
- setText(text);
- }
-
- /**
- * Constructs a TtsText with the values of the Markup, does not check if the given Markup is
- * of the right type.
- */
- private TtsText(Markup markup) {
- super(markup);
- }
-
- /**
- * Sets the text to be synthesized.
- * @return This instance.
- */
- public TtsText setText(String text) {
- setParameter(KEY_TEXT, text);
- return this;
- }
-
- /**
- * Returns the text to be synthesized.
- * @return This instance.
- */
- public String getText() {
- return getParameter(KEY_TEXT);
- }
-
- /**
- * Generates a best effort plain text, in this case simply the text.
- */
- @Override
- public String generatePlainText() {
- return getText();
- }
- }
-
- /**
- * Contains a cardinal.
- * Parameters:
- * <ul>
- * <li>integer: the integer to synthesize</li>
- * </ul>
- */
- public static class TtsCardinal extends AbstractTtsSemioticClass<TtsCardinal> {
-
- // The type of this node.
- protected static final String TYPE_CARDINAL = "cardinal";
- // The parameter integer stores the integer to synthesize.
- private static final String KEY_INTEGER = "integer";
-
- /**
- * Default constructor.
- */
- public TtsCardinal() {
- mMarkup.setType(TYPE_CARDINAL);
- }
-
- /**
- * Constructor that sets the integer to be synthesized.
- */
- public TtsCardinal(int integer) {
- this();
- setInteger(integer);
- }
-
- /**
- * Constructor that sets the integer to be synthesized.
- */
- public TtsCardinal(String integer) {
- this();
- setInteger(integer);
- }
-
- /**
- * Constructs a TtsText with the values of the Markup.
- * Does not check if the given Markup is of the right type.
- */
- private TtsCardinal(Markup markup) {
- super(markup);
- }
-
- /**
- * Sets the integer.
- * @return This instance.
- */
- public TtsCardinal setInteger(int integer) {
- return setInteger(String.valueOf(integer));
- }
-
- /**
- * Sets the integer.
- * @param integer A non-empty string of digits with an optional '-' in front.
- * @return This instance.
- */
- public TtsCardinal setInteger(String integer) {
- if (!integer.matches("-?\\d+")) {
- throw new IllegalArgumentException("Expected a cardinal: \"" + integer + "\"");
- }
- setParameter(KEY_INTEGER, integer);
- return this;
- }
-
- /**
- * Returns the integer parameter.
- */
- public String getInteger() {
- return getParameter(KEY_INTEGER);
- }
-
- /**
- * Generates a best effort plain text, in this case simply the integer.
- */
- @Override
- public String generatePlainText() {
- return getInteger();
- }
- }
-
- /**
- * Default constructor.
- */
- public Utterance() {}
-
- /**
- * Returns the plain text of a given Markup if it was set; if it's not set, recursively call the
- * this same method on its children.
- */
- private String constructPlainText(Markup m) {
- StringBuilder plainText = new StringBuilder();
- if (m.getPlainText() != null) {
- plainText.append(m.getPlainText());
- } else {
- for (Markup nestedMarkup : m.getNestedMarkups()) {
- String nestedPlainText = constructPlainText(nestedMarkup);
- if (!nestedPlainText.isEmpty()) {
- if (plainText.length() != 0) {
- plainText.append(" ");
- }
- plainText.append(nestedPlainText);
- }
- }
- }
- return plainText.toString();
- }
-
- /**
- * Creates a Markup instance with auto generated plain texts for the relevant nodes, in case the
- * user has not provided one already.
- * @return A Markup instance representing this utterance.
- */
- public Markup createMarkup() {
- Markup markup = new Markup(TYPE_UTTERANCE);
- StringBuilder plainText = new StringBuilder();
- for (AbstractTts<? extends AbstractTts<?>> say : says) {
- // Get a copy of this markup, and generate a plaintext for it if is not set.
- Markup sayMarkup = say.getMarkup();
- if (sayMarkup.getPlainText() == null) {
- sayMarkup.setPlainText(say.generatePlainText());
- }
- if (plainText.length() != 0) {
- plainText.append(" ");
- }
- plainText.append(constructPlainText(sayMarkup));
- markup.addNestedMarkup(sayMarkup);
- }
- if (mNoWarningOnFallback != null) {
- markup.setParameter(KEY_NO_WARNING_ON_FALLBACK,
- mNoWarningOnFallback ? "true" : "false");
- }
- markup.setPlainText(plainText.toString());
- return markup;
- }
-
- /**
- * Appends an element to this Utterance instance.
- * @return this instance
- */
- public Utterance append(AbstractTts<? extends AbstractTts<?>> say) {
- says.add(say);
- return this;
- }
-
- private Utterance append(Markup markup) {
- if (markup.getType().equals(TtsText.TYPE_TEXT)) {
- append(new TtsText(markup));
- } else if (markup.getType().equals(TtsCardinal.TYPE_CARDINAL)) {
- append(new TtsCardinal(markup));
- } else {
- // Unknown node, a class we don't know about.
- if (markup.getPlainText() != null) {
- append(new TtsText(markup.getPlainText()));
- } else {
- // No plainText specified; add its children
- // seperately. In case of a new prosody node,
- // we would still verbalize it correctly.
- for (Markup nested : markup.getNestedMarkups()) {
- append(nested);
- }
- }
- }
- return this;
- }
-
- /**
- * Returns a string representation of this Utterance instance. Can be deserialized back to an
- * Utterance instance with utteranceFromString(). Can be used to store utterances to be used
- * at a later time.
- */
- public String toString() {
- String out = "type: \"" + TYPE_UTTERANCE + "\"";
- if (mNoWarningOnFallback != null) {
- out += " no_warning_on_fallback: \"" + (mNoWarningOnFallback ? "true" : "false") + "\"";
- }
- for (AbstractTts<? extends AbstractTts<?>> say : says) {
- out += " markup { " + say.getMarkup().toString() + " }";
- }
- return out;
- }
-
- /**
- * Returns an Utterance instance from the string representation generated by toString().
- * @param string The string representation generated by toString().
- * @return The new Utterance instance.
- * @throws {@link IllegalArgumentException} if the input cannot be correctly parsed.
- */
- static public Utterance utteranceFromString(String string) throws IllegalArgumentException {
- Utterance utterance = new Utterance();
- Markup markup = Markup.markupFromString(string);
- if (!markup.getType().equals(TYPE_UTTERANCE)) {
- throw new IllegalArgumentException("Top level markup should be of type \"" +
- TYPE_UTTERANCE + "\", but was of type \"" +
- markup.getType() + "\".") ;
- }
- for (Markup nestedMarkup : markup.getNestedMarkups()) {
- utterance.append(nestedMarkup);
- }
- return utterance;
- }
-
- /**
- * Appends a new TtsText with the given text.
- * @param text The text to synthesize.
- * @return This instance.
- */
- public Utterance append(String text) {
- return append(new TtsText(text));
- }
-
- /**
- * Appends a TtsCardinal representing the given number.
- * @param integer The integer to synthesize.
- * @return this
- */
- public Utterance append(int integer) {
- return append(new TtsCardinal(integer));
- }
-
- /**
- * Returns the n'th element in this Utterance.
- * @param i The index.
- * @return The n'th element in this Utterance.
- * @throws {@link IndexOutOfBoundsException} - if i < 0 || i >= size()
- */
- public AbstractTts<? extends AbstractTts<?>> get(int i) {
- return says.get(i);
- }
-
- /**
- * Returns the number of elements in this Utterance.
- * @return The number of elements in this Utterance.
- */
- public int size() {
- return says.size();
- }
-
- @Override
- public boolean equals(Object o) {
- if ( this == o ) return true;
- if ( !(o instanceof Utterance) ) return false;
- Utterance utt = (Utterance) o;
-
- if (says.size() != utt.says.size()) {
- return false;
- }
-
- for (int i = 0; i < says.size(); i++) {
- if (!says.get(i).getMarkup().equals(utt.says.get(i).getMarkup())) {
- return false;
- }
- }
- return true;
- }
-
- /**
- * Can be set to true or false, true indicating that the user provided only a string to the API,
- * at which the system will not issue a warning if the synthesizer falls back onto the plain
- * text when the synthesizer does not support Markup.
- */
- public Utterance setNoWarningOnFallback(boolean noWarning) {
- mNoWarningOnFallback = noWarning;
- return this;
- }
-}
diff --git a/tests/TtsTests/src/com/android/speech/tts/AbstractTtsSemioticClassTest.java b/tests/TtsTests/src/com/android/speech/tts/AbstractTtsSemioticClassTest.java
deleted file mode 100644
index 31484f448775..000000000000
--- a/tests/TtsTests/src/com/android/speech/tts/AbstractTtsSemioticClassTest.java
+++ /dev/null
@@ -1,189 +0,0 @@
-/*
- * 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.speech.tts;
-
-import android.test.InstrumentationTestCase;
-
-import android.speech.tts.Markup;
-import android.speech.tts.Utterance;
-import android.speech.tts.Utterance.AbstractTtsSemioticClass;
-
-public class AbstractTtsSemioticClassTest extends InstrumentationTestCase {
-
- public static class TtsMock extends AbstractTtsSemioticClass<TtsMock> {
- public TtsMock() {
- super();
- }
-
- public TtsMock(Markup markup) {
- super();
- }
-
- public void setType(String type) {
- mMarkup.setType(type);
- }
- }
-
- public void testFluentAPI() {
- new TtsMock()
- .setPlainText("a plaintext") // from AbstractTts
- .setGender(Utterance.GENDER_MALE) // from AbstractTtsSemioticClass
- .setType("test"); // from TtsMock
- }
-
- public void testDefaultConstructor() {
- new TtsMock();
- }
-
- public void testMarkupConstructor() {
- Markup markup = new Markup();
- new TtsMock(markup);
- }
-
- public void testGetType() {
- TtsMock t = new TtsMock();
- t.setType("type1");
- assertEquals("type1", t.getType());
- t.setType(null);
- assertEquals(null, t.getType());
- t.setType("type2");
- assertEquals("type2", t.getType());
- }
-
-
- public void testDefaultGender() {
- assertEquals(Utterance.GENDER_UNKNOWN, new TtsMock().getGender());
- }
-
- public void testSetGender() {
- assertEquals(Utterance.GENDER_MALE,
- new TtsMock().setGender(Utterance.GENDER_MALE).getGender());
- }
-
- public void testSetGenderNegative() {
- try {
- new TtsMock().setGender(-1);
- fail("Expected IllegalArgumentException");
- } catch (IllegalArgumentException e) {}
- }
-
- public void testSetGenderOutOfBounds() {
- try {
- new TtsMock().setGender(4);
- fail("Expected IllegalArgumentException");
- } catch (IllegalArgumentException e) {}
- }
-
- public void testDefaultAnimacy() {
- assertEquals(Utterance.ANIMACY_UNKNOWN, new TtsMock().getAnimacy());
- }
-
- public void testSetAnimacy() {
- assertEquals(Utterance.ANIMACY_ANIMATE,
- new TtsMock().setAnimacy(Utterance.ANIMACY_ANIMATE).getAnimacy());
- }
-
- public void testSetAnimacyNegative() {
- try {
- new TtsMock().setAnimacy(-1);
- fail("Expected IllegalArgumentException");
- } catch (IllegalArgumentException e) {}
- }
-
- public void testSetAnimacyOutOfBounds() {
- try {
- new TtsMock().setAnimacy(4);
- fail("Expected IllegalArgumentException");
- } catch (IllegalArgumentException e) {}
- }
-
- public void testDefaultMultiplicity() {
- assertEquals(Utterance.MULTIPLICITY_UNKNOWN, new TtsMock().getMultiplicity());
- }
-
- public void testSetMultiplicity() {
- assertEquals(Utterance.MULTIPLICITY_DUAL,
- new TtsMock().setMultiplicity(Utterance.MULTIPLICITY_DUAL).getMultiplicity());
- }
-
- public void testSetMultiplicityNegative() {
- try {
- new TtsMock().setMultiplicity(-1);
- fail("Expected IllegalArgumentException");
- } catch (IllegalArgumentException e) {}
- }
-
- public void testSetMultiplicityOutOfBounds() {
- try {
- new TtsMock().setMultiplicity(4);
- fail("Expected IllegalArgumentException");
- } catch (IllegalArgumentException e) {}
- }
-
- public void testDefaultCase() {
- assertEquals(Utterance.CASE_UNKNOWN, new TtsMock().getCase());
- }
-
- public void testSetCase() {
- assertEquals(Utterance.CASE_VOCATIVE,
- new TtsMock().setCase(Utterance.CASE_VOCATIVE).getCase());
- }
-
- public void testSetCaseNegative() {
- try {
- new TtsMock().setCase(-1);
- fail("Expected IllegalArgumentException");
- } catch (IllegalArgumentException e) {}
- }
-
- public void testSetCaseOutOfBounds() {
- try {
- new TtsMock().setCase(9);
- fail("Expected IllegalArgumentException");
- } catch (IllegalArgumentException e) {}
- }
-
- public void testToString() {
- TtsMock t = new TtsMock()
- .setAnimacy(Utterance.ANIMACY_INANIMATE)
- .setCase(Utterance.CASE_INSTRUMENTAL)
- .setGender(Utterance.GENDER_FEMALE)
- .setMultiplicity(Utterance.MULTIPLICITY_PLURAL);
- String str =
- "animacy: \"2\" " +
- "case: \"8\" " +
- "gender: \"3\" " +
- "multiplicity: \"3\"";
- assertEquals(str, t.toString());
- }
-
- public void testToStringSetToUnkown() {
- TtsMock t = new TtsMock()
- .setAnimacy(Utterance.ANIMACY_INANIMATE)
- .setCase(Utterance.CASE_INSTRUMENTAL)
- .setGender(Utterance.GENDER_FEMALE)
- .setMultiplicity(Utterance.MULTIPLICITY_PLURAL)
- // set back to unknown
- .setAnimacy(Utterance.ANIMACY_UNKNOWN)
- .setCase(Utterance.CASE_UNKNOWN)
- .setGender(Utterance.GENDER_UNKNOWN)
- .setMultiplicity(Utterance.MULTIPLICITY_UNKNOWN);
- String str = "";
- assertEquals(str, t.toString());
- }
-
-}
diff --git a/tests/TtsTests/src/com/android/speech/tts/AbstractTtsTest.java b/tests/TtsTests/src/com/android/speech/tts/AbstractTtsTest.java
deleted file mode 100644
index 281c97f4eee5..000000000000
--- a/tests/TtsTests/src/com/android/speech/tts/AbstractTtsTest.java
+++ /dev/null
@@ -1,106 +0,0 @@
-/*
- * 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.speech.tts;
-
-import android.test.InstrumentationTestCase;
-
-import android.speech.tts.Markup;
-import android.speech.tts.Utterance.AbstractTts;
-
-public class AbstractTtsTest extends InstrumentationTestCase {
-
- public static class TtsMock extends AbstractTts<TtsMock> {
- public TtsMock() {
- super();
- }
-
- public TtsMock(Markup markup) {
- super();
- }
-
- public void setType(String type) {
- mMarkup.setType(type);
- }
-
- @Override
- public TtsMock setParameter(String key, String value) {
- return super.setParameter(key, value);
- }
-
- @Override
- public TtsMock removeParameter(String key) {
- return super.removeParameter(key);
- }
- }
-
- public void testDefaultConstructor() {
- new TtsMock();
- }
-
- public void testMarkupConstructor() {
- Markup markup = new Markup();
- new TtsMock(markup);
- }
-
- public void testGetType() {
- TtsMock t = new TtsMock();
- t.setType("type1");
- assertEquals("type1", t.getType());
- t.setType(null);
- assertEquals(null, t.getType());
- t.setType("type2");
- assertEquals("type2", t.getType());
- }
-
- public void testGeneratePlainText() {
- assertNull(new TtsMock().generatePlainText());
- }
-
- public void testToString() {
- TtsMock t = new TtsMock();
- t.setType("a_type");
- t.setPlainText("a plaintext");
- t.setParameter("key1", "value1");
- t.setParameter("aaa", "value2");
- String str =
- "type: \"a_type\" " +
- "plain_text: \"a plaintext\" " +
- "aaa: \"value2\" " +
- "key1: \"value1\"";
- assertEquals(str, t.toString());
- }
-
- public void testRemoveParameter() {
- TtsMock t = new TtsMock();
- t.setParameter("key1", "value 1");
- t.setParameter("aaa", "value a");
- t.removeParameter("key1");
- String str =
- "aaa: \"value a\"";
- assertEquals(str, t.toString());
- }
-
- public void testRemoveParameterBySettingNull() {
- TtsMock t = new TtsMock();
- t.setParameter("key1", "value 1");
- t.setParameter("aaa", "value a");
- t.setParameter("aaa", null);
- String str =
- "key1: \"value 1\"";
- assertEquals(str, t.toString());
- }
-}
diff --git a/tests/TtsTests/src/com/android/speech/tts/MarkupTest.java b/tests/TtsTests/src/com/android/speech/tts/MarkupTest.java
deleted file mode 100644
index 7ef93ce56028..000000000000
--- a/tests/TtsTests/src/com/android/speech/tts/MarkupTest.java
+++ /dev/null
@@ -1,510 +0,0 @@
-/*
- * 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.speech.tts;
-
-import junit.framework.Assert;
-import android.os.Parcel;
-import android.test.InstrumentationTestCase;
-
-import android.speech.tts.Markup;
-
-public class MarkupTest extends InstrumentationTestCase {
-
- public void testEmptyMarkup() {
- Markup markup = new Markup();
- assertNull(markup.getType());
- assertNull(markup.getPlainText());
- assertEquals(0, markup.parametersSize());
- assertEquals(0, markup.nestedMarkupSize());
- }
-
- public void testGetSetType() {
- Markup markup = new Markup();
- markup.setType("one");
- assertEquals("one", markup.getType());
- markup.setType(null);
- assertNull(markup.getType());
- markup.setType("two");
- assertEquals("two", markup.getType());
- }
-
- public void testGetSetPlainText() {
- Markup markup = new Markup();
- markup.setPlainText("one");
- assertEquals("one", markup.getPlainText());
- markup.setPlainText(null);
- assertNull(markup.getPlainText());
- markup.setPlainText("two");
- assertEquals("two", markup.getPlainText());
- }
-
- public void testParametersSize1() {
- Markup markup = new Markup();
- markup.addNestedMarkup(new Markup());
- assertEquals(1, markup.nestedMarkupSize());
- }
-
- public void testParametersSize2() {
- Markup markup = new Markup();
- markup.addNestedMarkup(new Markup());
- markup.addNestedMarkup(new Markup());
- assertEquals(2, markup.nestedMarkupSize());
- }
-
- public void testRemoveParameter() {
- Markup m = new Markup("type");
- m.setParameter("key1", "value1");
- m.setParameter("key2", "value2");
- m.setParameter("key3", "value3");
- assertEquals(3, m.parametersSize());
- m.removeParameter("key1");
- assertEquals(2, m.parametersSize());
- m.removeParameter("key3");
- assertEquals(1, m.parametersSize());
- assertNull(m.getParameter("key1"));
- assertEquals("value2", m.getParameter("key2"));
- assertNull(m.getParameter("key3"));
- }
-
- public void testEmptyEqual() {
- Markup m1 = new Markup();
- Markup m2 = new Markup();
- assertTrue(m1.equals(m2));
- }
-
- public void testFilledEqual() {
- Markup m1 = new Markup();
- m1.setType("type");
- m1.setPlainText("plain text");
- m1.setParameter("key1", "value1");
- m1.addNestedMarkup(new Markup());
- Markup m2 = new Markup();
- m2.setType("type");
- m2.setPlainText("plain text");
- m2.setParameter("key1", "value1");
- m2.addNestedMarkup(new Markup());
- assertTrue(m1.equals(m2));
- }
-
- public void testDifferentTypeEqual() {
- Markup m1 = new Markup();
- m1.setType("type1");
- Markup m2 = new Markup();
- m2.setType("type2");
- assertFalse(m1.equals(m2));
- }
-
- public void testDifferentPlainTextEqual() {
- Markup m1 = new Markup();
- m1.setPlainText("plainText1");
- Markup m2 = new Markup();
- m2.setPlainText("plainText2");
- assertFalse(m1.equals(m2));
- }
-
- public void testDifferentParamEqual() {
- Markup m1 = new Markup();
- m1.setParameter("test", "value1");
- Markup m2 = new Markup();
- m2.setParameter("test", "value2");
- assertFalse(m1.equals(m2));
- }
-
- public void testDifferentParameterKeyEqual() {
- Markup m1 = new Markup();
- m1.setParameter("test1", "value");
- Markup m2 = new Markup();
- m2.setParameter("test2", "value");
- assertFalse(m1.equals(m2));
- }
-
- public void testDifferentParameterValueEqual() {
- Markup m1 = new Markup();
- m1.setParameter("test", "value1");
- Markup m2 = new Markup();
- m2.setParameter("test", "value2");
- assertFalse(m1.equals(m2));
- }
-
- public void testDifferentNestedMarkupEqual() {
- Markup m1 = new Markup();
- Markup nested = new Markup();
- nested.setParameter("key", "value");
- m1.addNestedMarkup(nested);
- Markup m2 = new Markup();
- m2.addNestedMarkup(new Markup());
- assertFalse(m1.equals(m2));
- }
-
- public void testEmptyToFromString() {
- Markup m1 = new Markup();
- String str = m1.toString();
- assertEquals("", str);
-
- Markup m2 = Markup.markupFromString(str);
- assertEquals(m1, m2);
- }
-
- public void testTypeToFromString() {
- Markup m1 = new Markup("atype");
- String str = m1.toString();
- assertEquals("type: \"atype\"", str);
- Markup m2 = Markup.markupFromString(str);
- assertEquals(m1, m2);
- }
-
- public void testPlainTextToFromString() {
- Markup m1 = new Markup();
- m1.setPlainText("some_plainText");
- String str = m1.toString();
- assertEquals("plain_text: \"some_plainText\"", str);
-
- Markup m2 = Markup.markupFromString(str);
- assertEquals(m1, m2);
- }
-
- public void testParameterToFromString() {
- Markup m1 = new Markup("cardinal");
- m1.setParameter("integer", "-22");
- String str = m1.toString();
- assertEquals("type: \"cardinal\" integer: \"-22\"", str);
- Markup m2 = Markup.markupFromString(str);
- assertEquals(m1, m2);
- }
-
- // Parameters should be ordered alphabettically, so the output is stable.
- public void testParameterOrderToFromString() {
- Markup m1 = new Markup("cardinal");
- m1.setParameter("ccc", "-");
- m1.setParameter("aaa", "-");
- m1.setParameter("aa", "-");
- m1.setParameter("bbb", "-");
- String str = m1.toString();
- assertEquals(
- "type: \"cardinal\" " +
- "aa: \"-\" " +
- "aaa: \"-\" " +
- "bbb: \"-\" " +
- "ccc: \"-\"",
- str);
- Markup m2 = Markup.markupFromString(str);
- assertEquals(m1, m2);
- }
-
- public void testEmptyNestedToFromString() {
- Markup m1 = new Markup("atype");
- m1.addNestedMarkup(new Markup());
- String str = m1.toString();
- assertEquals("type: \"atype\" markup {}", str);
- Markup m2 = Markup.markupFromString(str);
- assertEquals(m1, m2);
- }
-
- public void testNestedWithTypeToFromString() {
- Markup m1 = new Markup("atype");
- m1.addNestedMarkup(new Markup("nested_type"));
- String str = m1.toString();
- assertEquals(
- "type: \"atype\" " +
- "markup { type: \"nested_type\" }",
- str);
- Markup m2 = Markup.markupFromString(str);
- assertEquals(m1, m2);
- }
-
- public void testRemoveNestedMarkup() {
- Markup m = new Markup("atype");
- Markup m1 = new Markup("nested_type1");
- Markup m2 = new Markup("nested_type2");
- Markup m3 = new Markup("nested_type3");
- m.addNestedMarkup(m1);
- m.addNestedMarkup(m2);
- m.addNestedMarkup(m3);
- m.removeNestedMarkup(m1);
- m.removeNestedMarkup(m3);
- String str = m.toString();
- assertEquals(
- "type: \"atype\" " +
- "markup { type: \"nested_type2\" }",
- str);
- Markup mFromString = Markup.markupFromString(str);
- assertEquals(m, mFromString);
- }
-
- public void testLotsofNestingToFromString() {
- Markup m1 = new Markup("top")
- .addNestedMarkup(new Markup("top_child1")
- .addNestedMarkup(new Markup("top_child1_child1"))
- .addNestedMarkup(new Markup("top_child1_child2")))
- .addNestedMarkup(new Markup("top_child2")
- .addNestedMarkup(new Markup("top_child2_child2"))
- .addNestedMarkup(new Markup("top_child2_child2")));
-
- String str = m1.toString();
- assertEquals(
- "type: \"top\" " +
- "markup { " +
- "type: \"top_child1\" " +
- "markup { type: \"top_child1_child1\" } " +
- "markup { type: \"top_child1_child2\" } " +
- "} " +
- "markup { " +
- "type: \"top_child2\" " +
- "markup { type: \"top_child2_child2\" } " +
- "markup { type: \"top_child2_child2\" } " +
- "}",
- str);
- Markup m2 = Markup.markupFromString(str);
- assertEquals(m1, m2);
- }
-
- public void testFilledToFromString() {
- Markup m1 = new Markup("measure");
- m1.setPlainText("fifty-five amps");
- m1.setParameter("unit", "meter");
- m1.addNestedMarkup(new Markup("cardinal").setParameter("integer", "55"));
- String str = m1.toString();
- assertEquals(
- "type: \"measure\" " +
- "plain_text: \"fifty-five amps\" " +
- "unit: \"meter\" " +
- "markup { type: \"cardinal\" integer: \"55\" }",
- str);
-
- Markup m2 = Markup.markupFromString(str);
- assertEquals(m1, m2);
- }
-
- public void testErrorFromString() {
- String str = "type: \"atype\" markup {mistake}";
- try {
- Markup.markupFromString(str);
- Assert.fail("Expected IllegalArgumentException");
- } catch (IllegalArgumentException e) {}
- }
-
- public void testEscapeQuotes() {
- Markup m1 = new Markup("text")
- .setParameter("something_unknown", "\"this\" is \"a sentence \" with quotes\"");
- String str = m1.toString();
- assertEquals(
- "type: \"text\" " +
- "something_unknown: \"\\\"this\\\" is \\\"a sentence \\\" with quotes\\\"\"",
- str);
-
- Markup m2 = Markup.markupFromString(str);
- assertEquals(m1.toString(), m2.toString());
- assertEquals(m1, m2);
- }
-
- public void testEscapeSlashes1() {
- Markup m1 = new Markup("text")
- .setParameter("something_unknown", "\\ \\\\ \t \n \"");
- String str = m1.toString();
- assertEquals(
- "type: \"text\" " +
- "something_unknown: \"\\\\ \\\\\\\\ \t \n \\\"\"",
- str);
-
- Markup m2 = Markup.markupFromString(str);
- assertEquals(m1.toString(), m2.toString());
- assertEquals(m1, m2);
- }
-
- public void testEscapeSlashes2() {
- Markup m1 = new Markup("text")
- .setParameter("something_unknown", "\\\"\\\"\\\\\"\"\\\\\\\"\"\"");
- String str = m1.toString();
- assertEquals(
- "type: \"text\" " +
- "something_unknown: \"\\\\\\\"\\\\\\\"\\\\\\\\\\\"\\\"\\\\\\\\\\\\\\\"\\\"\\\"\"",
- str);
-
- Markup m2 = Markup.markupFromString(str);
- assertEquals(m1.toString(), m2.toString());
- assertEquals(m1, m2);
- }
-
- public void testBadInput1() {
- String str = "type: \"text\" text: \"\\\"";
- try {
- Markup.markupFromString(str);
- fail("Expected IllegalArgumentException");
- } catch (IllegalArgumentException e) {}
- }
-
- public void testBadInput2() {
- String str = "type: \"text\" text: \"\\a\"";
- try {
- Markup.markupFromString(str);
- fail("Expected IllegalArgumentException");
- } catch (IllegalArgumentException e) {}
- }
-
- public void testValidParameterKey() {
- Markup m = new Markup();
- m.setParameter("ke9__yk_88ey_za7_", "test");
- }
-
- public void testInValidParameterKeyEmpty() {
- Markup m = new Markup();
- try {
- m.setParameter("", "test");
- fail("Expected IllegalArgumentException");
- } catch (IllegalArgumentException e) {}
- }
-
- public void testInValidParameterKeyDollar() {
- Markup m = new Markup();
- try {
- m.setParameter("ke9y$k88ey7", "test");
- fail("Expected IllegalArgumentException");
- } catch (IllegalArgumentException e) {}
- }
-
- public void testInValidParameterKeySpace() {
- Markup m = new Markup();
- try {
- m.setParameter("ke9yk88ey7 ", "test");
- fail("Expected IllegalArgumentException");
- } catch (IllegalArgumentException e) {}
- }
-
- public void testValidType() {
- new Markup("_this_is_1_valid_type_222");
- }
-
- public void testInValidTypeAmpersand() {
- try {
- new Markup("abcde1234&");
- fail("Expected IllegalArgumentException");
- } catch (IllegalArgumentException e) {}
- }
-
- public void testInValidTypeSpace() {
- try {
- new Markup(" ");
- fail("Expected IllegalArgumentException");
- } catch (IllegalArgumentException e) {}
- }
-
- public void testSimpleParcelable() {
- Markup markup = new Markup();
-
- Parcel parcel = Parcel.obtain();
- markup.writeToParcel(parcel, 0);
- parcel.setDataPosition(0);
-
- Markup fromParcel = (Markup) Markup.CREATOR.createFromParcel(parcel);
-
- assertFalse(markup == fromParcel);
- assertEquals(markup, fromParcel);
- }
-
- public void testTypeParcelable() {
- Markup markup = new Markup("text");
-
- Parcel parcel = Parcel.obtain();
- markup.writeToParcel(parcel, 0);
- parcel.setDataPosition(0);
-
- Markup fromParcel = (Markup) Markup.CREATOR.createFromParcel(parcel);
-
- assertFalse(markup == fromParcel);
- assertEquals(markup, fromParcel);
- }
-
- public void testPlainTextsParcelable() {
- Markup markup = new Markup();
- markup.setPlainText("plainText");
-
- Parcel parcel = Parcel.obtain();
- markup.writeToParcel(parcel, 0);
- parcel.setDataPosition(0);
-
- Markup fromParcel = (Markup) Markup.CREATOR.createFromParcel(parcel);
-
- assertFalse(markup == fromParcel);
- assertEquals(markup, fromParcel);
- }
-
- public void testParametersParcelable() {
- Markup markup = new Markup();
- markup.setParameter("key1", "value1");
- markup.setParameter("key2", "value2");
- markup.setParameter("key3", "value3");
-
- Parcel parcel = Parcel.obtain();
- markup.writeToParcel(parcel, 0);
- parcel.setDataPosition(0);
-
- Markup fromParcel = (Markup) Markup.CREATOR.createFromParcel(parcel);
-
- assertFalse(markup == fromParcel);
- assertEquals(markup, fromParcel);
- }
-
- public void testNestedParcelable() {
- Markup markup = new Markup();
- markup.addNestedMarkup(new Markup("first"));
- markup.addNestedMarkup(new Markup("second"));
- markup.addNestedMarkup(new Markup("third"));
-
- Parcel parcel = Parcel.obtain();
- markup.writeToParcel(parcel, 0);
- parcel.setDataPosition(0);
-
- Markup fromParcel = (Markup) Markup.CREATOR.createFromParcel(parcel);
-
- assertFalse(markup == fromParcel);
- assertEquals(markup, fromParcel);
- }
-
- public void testAllFieldsParcelable() {
- Markup markup = new Markup("text");
- markup.setPlainText("plain text");
- markup.setParameter("key1", "value1");
- markup.setParameter("key2", "value2");
- markup.setParameter("key3", "value3");
- markup.addNestedMarkup(new Markup("first"));
- markup.addNestedMarkup(new Markup("second"));
- markup.addNestedMarkup(new Markup("third"));
-
- Parcel parcel = Parcel.obtain();
- markup.writeToParcel(parcel, 0);
- parcel.setDataPosition(0);
-
- Markup fromParcel = (Markup) Markup.CREATOR.createFromParcel(parcel);
-
- assertFalse(markup == fromParcel);
- assertEquals(markup, fromParcel);
- }
-
- public void testKeyCannotBeType() {
- try {
- new Markup().setParameter("type", "vale");
- fail("Expected IllegalArgumentException");
- } catch (IllegalArgumentException e) {}
- }
-
- public void testKeyCannotBePlainText() {
- try {
- new Markup().setParameter("plain_text", "value");
- fail("Expected IllegalArgumentException");
- } catch (IllegalArgumentException e) {}
- }
-}
diff --git a/tests/TtsTests/src/com/android/speech/tts/TtsCardinalTest.java b/tests/TtsTests/src/com/android/speech/tts/TtsCardinalTest.java
deleted file mode 100644
index c34f4acccbe8..000000000000
--- a/tests/TtsTests/src/com/android/speech/tts/TtsCardinalTest.java
+++ /dev/null
@@ -1,119 +0,0 @@
-/*
- * 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.speech.tts;
-
-import junit.framework.Assert;
-import android.test.InstrumentationTestCase;
-import android.test.MoreAsserts;
-
-import android.speech.tts.Markup;
-import android.speech.tts.Utterance;
-import android.speech.tts.Utterance.TtsCardinal;
-import android.speech.tts.Utterance.TtsText;
-
-public class TtsCardinalTest extends InstrumentationTestCase {
-
- public void testConstruct() {
- assertNotNull(new TtsCardinal(0));
- }
-
- public void testFluentAPI() {
- new TtsCardinal()
- .setPlainText("a plaintext") // from AbstractTts
- .setGender(Utterance.GENDER_MALE) // from AbstractTtsSemioticClass
- .setInteger("-10001"); // from TtsText
- }
-
- public void testZero() {
- assertEquals("0", new TtsCardinal(0).getInteger());
- }
-
- public void testThirtyOne() {
- assertEquals("31", new TtsCardinal(31).getInteger());
- }
-
- public void testMarkupZero() {
- TtsCardinal c = new TtsCardinal(0);
- Markup m = c.getMarkup();
- assertEquals("0", m.getParameter("integer"));
- }
-
- public void testMarkupThirtyOne() {
- TtsCardinal c = new TtsCardinal(31);
- Markup m = c.getMarkup();
- assertEquals("31", m.getParameter("integer"));
- }
-
- public void testMarkupThirtyOneString() {
- TtsCardinal c = new TtsCardinal("31");
- Markup m = c.getMarkup();
- assertEquals("31", m.getParameter("integer"));
- }
-
- public void testMarkupNegativeThirtyOne() {
- TtsCardinal c = new TtsCardinal(-31);
- Markup m = c.getMarkup();
- assertEquals("-31", m.getParameter("integer"));
- }
-
- public void testMarkupMinusZero() {
- TtsCardinal c = new TtsCardinal("-0");
- Markup m = c.getMarkup();
- assertEquals("-0", m.getParameter("integer"));
- }
-
- public void testMarkupNegativeThirtyOneString() {
- TtsCardinal c = new TtsCardinal("-31");
- Markup m = c.getMarkup();
- assertEquals("-31", m.getParameter("integer"));
- }
-
- public void testOnlyLetters() {
- try {
- new TtsCardinal("abc");
- Assert.fail("Expected IllegalArgumentException");
- } catch (IllegalArgumentException e) {}
- }
-
- public void testOnlyMinus() {
- try {
- new TtsCardinal("-");
- Assert.fail("Expected IllegalArgumentException");
- } catch (IllegalArgumentException e) {}
- }
-
- public void testNegativeLetters() {
- try {
- new TtsCardinal("-abc");
- Assert.fail("Expected IllegalArgumentException");
- } catch (IllegalArgumentException e) {}
- }
-
- public void testLetterNumberMix() {
- try {
- new TtsCardinal("-0a1b2c");
- Assert.fail("Expected IllegalArgumentException");
- } catch (IllegalArgumentException e) {}
- }
-
- public void letterNumberMix2() {
- try {
- new TtsCardinal("-a0b1c2");
- Assert.fail("Expected IllegalArgumentException");
- } catch (IllegalArgumentException e) {}
- }
-}
diff --git a/tests/TtsTests/src/com/android/speech/tts/TtsTextTest.java b/tests/TtsTests/src/com/android/speech/tts/TtsTextTest.java
deleted file mode 100644
index 35fd4537d946..000000000000
--- a/tests/TtsTests/src/com/android/speech/tts/TtsTextTest.java
+++ /dev/null
@@ -1,74 +0,0 @@
-/*
- * 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.speech.tts;
-
-import android.test.InstrumentationTestCase;
-
-import android.speech.tts.Markup;
-import android.speech.tts.Utterance;
-import android.speech.tts.Utterance.TtsText;
-
-public class TtsTextTest extends InstrumentationTestCase {
-
- public void testConstruct() {
- assertNotNull(new TtsText());
- }
-
- public void testFluentAPI() {
- new TtsText()
- .setPlainText("a plaintext") // from AbstractTts
- .setGender(Utterance.GENDER_MALE) // from AbstractTtsSemioticClass
- .setText("text"); // from TtsText
- }
-
- public void testConstructEmptyString() {
- assertTrue(new TtsText("").getText().isEmpty());
- }
-
- public void testConstructString() {
- assertEquals("this is a test.", new TtsText("this is a test.").getText());
- }
-
- public void testSetText() {
- assertEquals("This is a test.", new TtsText().setText("This is a test.").getText());
- }
-
- public void testEmptyMarkup() {
- TtsText t = new TtsText();
- Markup m = t.getMarkup();
- assertEquals("text", m.getType());
- assertNull(m.getPlainText());
- assertEquals(0, m.nestedMarkupSize());
- }
-
- public void testConstructStringMarkup() {
- TtsText t = new TtsText("test");
- Markup m = t.getMarkup();
- assertEquals("text", m.getType());
- assertEquals("test", m.getParameter("text"));
- assertEquals(0, m.nestedMarkupSize());
- }
-
- public void testSetStringMarkup() {
- TtsText t = new TtsText();
- t.setText("test");
- Markup m = t.getMarkup();
- assertEquals("text", m.getType());
- assertEquals("test", m.getParameter("text"));
- assertEquals(0, m.nestedMarkupSize());
- }
-}
diff --git a/tests/TtsTests/src/com/android/speech/tts/UtteranceTest.java b/tests/TtsTests/src/com/android/speech/tts/UtteranceTest.java
deleted file mode 100644
index 8014dd17704a..000000000000
--- a/tests/TtsTests/src/com/android/speech/tts/UtteranceTest.java
+++ /dev/null
@@ -1,248 +0,0 @@
-/*
- * 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.speech.tts;
-
-import android.speech.tts.Markup;
-import android.speech.tts.Utterance;
-import android.speech.tts.Utterance.TtsCardinal;
-import android.speech.tts.Utterance.TtsText;
-
-import android.test.InstrumentationTestCase;
-
-public class UtteranceTest extends InstrumentationTestCase {
-
- public void testEmptyUtterance() {
- Utterance utt = new Utterance();
- assertEquals(0, utt.size());
- }
-
- public void testSizeCardinal() {
- Utterance utt = new Utterance()
- .append(new TtsCardinal(42));
- assertEquals(1, utt.size());
- }
-
- public void testSizeCardinalString() {
- Utterance utt = new Utterance()
- .append(new TtsCardinal(42))
- .append(new TtsText("is the answer"));
- assertEquals(2, utt.size());
- }
-
- public void testMarkupEmpty() {
- Markup m = new Utterance().createMarkup();
- assertEquals("utterance", m.getType());
- assertEquals("", m.getPlainText());
- }
-
- public void testMarkupCardinal() {
- Utterance utt = new Utterance()
- .append(new TtsCardinal(42));
- Markup markup = utt.createMarkup();
- assertEquals("utterance", markup.getType());
- assertEquals("42", markup.getPlainText());
- assertEquals("42", markup.getNestedMarkup(0).getParameter("integer"));
- assertEquals("42", markup.getNestedMarkup(0).getPlainText());
- }
-
- public void testMarkupCardinalString() {
- Utterance utt = new Utterance()
- .append(new TtsCardinal(42))
- .append(new TtsText("is not just a number."));
- Markup markup = utt.createMarkup();
- assertEquals("utterance", markup.getType());
- assertEquals("42 is not just a number.", markup.getPlainText());
- assertEquals("cardinal", markup.getNestedMarkup(0).getType());
- assertEquals("42", markup.getNestedMarkup(0).getParameter("integer"));
- assertEquals("42", markup.getNestedMarkup(0).getPlainText());
- assertEquals("text", markup.getNestedMarkup(1).getType());
- assertEquals("is not just a number.", markup.getNestedMarkup(1).getParameter("text"));
- assertEquals("is not just a number.", markup.getNestedMarkup(1).getPlainText());
- }
-
- public void testTextCardinalToFromString() {
- Utterance utt = new Utterance()
- .append(new TtsCardinal(55))
- .append(new TtsText("this is a text."));
- String str = utt.toString();
- assertEquals(
- "type: \"utterance\" " +
- "markup { " +
- "type: \"cardinal\" " +
- "integer: \"55\" " +
- "} " +
- "markup { " +
- "type: \"text\" " +
- "text: \"this is a text.\" " +
- "}"
- , str);
-
- Utterance utt_new = Utterance.utteranceFromString(str);
- assertEquals(str, utt_new.toString());
- }
-
- public void testNotUtteranceFromString() {
- String str =
- "type: \"this_is_not_an_utterance\" " +
- "markup { " +
- "type: \"cardinal\" " +
- "plain_text: \"55\" " +
- "integer: \"55\" " +
- "}";
- try {
- Utterance.utteranceFromString(str);
- fail("Expected IllegalArgumentException");
- } catch (IllegalArgumentException e) {}
- }
-
- public void testFromMarkup() {
- String markup_str =
- "type: \"utterance\" " +
- "markup { " +
- "type: \"cardinal\" " +
- "plain_text: \"55\" " +
- "integer: \"55\" " +
- "} " +
- "markup { " +
- "type: \"text\" " +
- "plain_text: \"this is a text.\" " +
- "text: \"this is a text.\" " +
- "}";
- Utterance utt = Utterance.utteranceFromString(markup_str);
- assertEquals(markup_str, utt.toString());
- }
-
- public void testsetPlainText() {
- Utterance utt = new Utterance()
- .append(new TtsCardinal(-100).setPlainText("minus one hundred"));
- assertEquals("minus one hundred", utt.get(0).getPlainText());
- }
-
- public void testRemoveTextThroughSet() {
- Utterance utt = new Utterance()
- .append(new TtsText().setText("test").setText(null));
- assertNull(((TtsText) utt.get(0)).getText());
- }
-
- public void testUnknownNodeWithPlainText() {
- String str =
- "type: \"utterance\" " +
- "markup { " +
- "type: \"some_future_feature\" " +
- "plain_text: \"biep bob bob\" " +
- "bombom: \"lorum ipsum\" " +
- "}";
- Utterance utt = Utterance.utteranceFromString(str);
- assertNotNull(utt);
- assertEquals("text", utt.get(0).getType());
- assertEquals("biep bob bob", ((TtsText) utt.get(0)).getText());
- }
-
- public void testUnknownNodeWithNoPlainTexts() {
- String str =
- "type: \"utterance\" " +
- "markup { " +
- "type: \"some_future_feature\" " +
- "bombom: \"lorum ipsum\" " +
- "markup { type: \"cardinal\" integer: \"10\" } " +
- "markup { type: \"text\" text: \"pears\" } " +
- "}";
- Utterance utt = Utterance.utteranceFromString(str);
- assertEquals(
- "type: \"utterance\" " +
- "markup { type: \"cardinal\" integer: \"10\" } " +
- "markup { type: \"text\" text: \"pears\" }", utt.toString());
- }
-
- public void testCreateWarningOnFallbackTrue() {
- Utterance utt = new Utterance()
- .append(new TtsText("test"))
- .setNoWarningOnFallback(true);
- assertEquals(
- "type: \"utterance\" " +
- "no_warning_on_fallback: \"true\" " +
- "markup { " +
- "type: \"text\" " +
- "text: \"test\" " +
- "}", utt.toString());
- }
-
- public void testCreateWarningOnFallbackFalse() {
- Utterance utt = new Utterance()
- .append(new TtsText("test"))
- .setNoWarningOnFallback(false);
- assertEquals(
- "type: \"utterance\" " +
- "no_warning_on_fallback: \"false\" " +
- "markup { " +
- "type: \"text\" " +
- "text: \"test\" " +
- "}", utt.toString());
- }
-
- public void testCreatePlainTexts() {
- Utterance utt = new Utterance()
- .append(new TtsText("test"))
- .append(new TtsCardinal(-55));
- assertEquals(
- "type: \"utterance\" " +
- "plain_text: \"test -55\" " +
- "markup { type: \"text\" plain_text: \"test\" text: \"test\" } " +
- "markup { type: \"cardinal\" plain_text: \"-55\" integer: \"-55\" }",
- utt.createMarkup().toString()
- );
- }
-
- public void testDontOverwritePlainTexts() {
- Utterance utt = new Utterance()
- .append(new TtsText("test").setPlainText("else"))
- .append(new TtsCardinal(-55).setPlainText("44"));
- assertEquals(
- "type: \"utterance\" " +
- "plain_text: \"else 44\" " +
- "markup { type: \"text\" plain_text: \"else\" text: \"test\" } " +
- "markup { type: \"cardinal\" plain_text: \"44\" integer: \"-55\" }",
- utt.createMarkup().toString()
- );
- }
-
- public void test99BottlesOnWallMarkup() {
- Utterance utt = new Utterance()
- .append("there are")
- .append(99)
- .append("bottles on the wall.");
- assertEquals(
- "type: \"utterance\" " +
- "plain_text: \"there are 99 bottles on the wall.\" " +
- "markup { type: \"text\" plain_text: \"there are\" text: \"there are\" } " +
- "markup { type: \"cardinal\" plain_text: \"99\" integer: \"99\" } " +
- "markup { type: \"text\" plain_text: \"bottles on the wall.\" text: \"bottles on the wall.\" }",
- utt.createMarkup().toString());
- assertEquals("99", utt.createMarkup().getNestedMarkup(1).getPlainText());
- Markup markup = new Markup(utt.createMarkup());
- assertEquals("99", markup.getNestedMarkup(1).getPlainText());
- }
-
- public void testWhat() {
- Utterance utt = new Utterance()
- .append("there are")
- .append(99)
- .append("bottles on the wall.");
- Markup m = utt.createMarkup();
- m.getNestedMarkup(1).getPlainText().equals("99");
- }
-}