X-Git-Url: http://gitweb.fperrin.net/?a=blobdiff_plain;f=src%2Fcom%2Fhughes%2Fandroid%2Fdictionary%2Fengine%2FTextEntry.java;h=22f0af2abcd7294dba9fe92cb495491a6b5126a8;hb=83d9dc7cd871082a82c2dd0dbb7a0ceabd7c83a0;hp=ec5bc3905627d4c1e3aef3eaf3ab3ab4d1e43bb9;hpb=590af2616dcdacdd2c4d56e71e3a502a4b3b81da;p=Dictionary.git diff --git a/src/com/hughes/android/dictionary/engine/TextEntry.java b/src/com/hughes/android/dictionary/engine/TextEntry.java index ec5bc39..22f0af2 100644 --- a/src/com/hughes/android/dictionary/engine/TextEntry.java +++ b/src/com/hughes/android/dictionary/engine/TextEntry.java @@ -14,83 +14,92 @@ package com.hughes.android.dictionary.engine; +import com.hughes.util.raf.RAFListSerializer; +import com.hughes.util.raf.RAFSerializable; +import com.ibm.icu.text.Transliterator; + +import java.io.DataInput; +import java.io.DataOutput; import java.io.IOException; import java.io.PrintStream; -import java.io.RandomAccessFile; import java.util.List; - -import com.hughes.util.raf.RAFSerializable; -import com.hughes.util.raf.RAFSerializer; -import com.ibm.icu.text.Transliterator; +import java.util.regex.Pattern; public class TextEntry extends AbstractEntry implements RAFSerializable { - - final String text; - - public TextEntry(final Dictionary dictionary, final RandomAccessFile raf) throws IOException { - super(dictionary, raf); - text = raf.readUTF(); - throw new RuntimeException(); - } - @Override - public void write(RandomAccessFile raf) throws IOException { - super.write(raf); - raf.writeUTF(text); - } - - static final class Serializer implements RAFSerializer { - - final Dictionary dictionary; - - Serializer(Dictionary dictionary) { - this.dictionary = dictionary; - } - @Override - public TextEntry read(RandomAccessFile raf) throws IOException { - return new TextEntry(dictionary, raf); + private final String text; + + private TextEntry(final Dictionary dictionary, final DataInput raf, final int index) + throws IOException { + super(dictionary, raf, index); + text = raf.readUTF(); + throw new RuntimeException("TextEntry constructor should be unreachable"); } @Override - public void write(RandomAccessFile raf, TextEntry t) throws IOException { - t.write(raf); + public void write(DataOutput raf) throws IOException { + super.write(raf); + raf.writeUTF(text); } - }; - - - @Override - public int addToDictionary(final Dictionary dictionary) { - dictionary.textEntries.add(this); - return dictionary.textEntries.size() - 1; - } - - public static class Row extends RowBase { - - Row(final RandomAccessFile raf, final int thisRowIndex, - final Index index) throws IOException { - super(raf, thisRowIndex, index); - } - - public TextEntry getEntry() { - return index.dict.textEntries.get(referenceIndex); - } - - @Override - public void print(PrintStream out) { - out.println(" " + getEntry().text); + + static final class Serializer implements RAFListSerializer { + + final Dictionary dictionary; + + Serializer(Dictionary dictionary) { + this.dictionary = dictionary; + } + + @Override + public TextEntry read(DataInput raf, final int index) throws IOException { + return new TextEntry(dictionary, raf, index); + } + + @Override + public void write(DataOutput raf, TextEntry t) throws IOException { + t.write(raf); + } } @Override - public String getRawText(boolean compact) { - return getEntry().text; + public void addToDictionary(final Dictionary dictionary) { + assert index == -1; + dictionary.textEntries.add(this); + index = dictionary.textEntries.size() - 1; } - + @Override - public RowMatchType matches(List searchTokens, Transliterator normalizer, boolean swapPairEntries) { - return null; + public RowBase CreateRow(int rowIndex, Index dictionaryIndex) { + throw new UnsupportedOperationException("TextEntry's don't really exist."); } - } + public static class Row extends RowBase { + Row(final DataInput raf, final int thisRowIndex, + final Index index, int extra) throws IOException { + super(raf, thisRowIndex, index, extra); + } + + TextEntry getEntry() { + return index.dict.textEntries.get(referenceIndex); + } + + @Override + public void print(PrintStream out) { + out.println(" " + getEntry().text); + } + + @Override + public String getRawText(boolean compact) { + return getEntry().text; + } + + @Override + public RowMatchType matches(final List searchTokens, + final Pattern orderedMatchPattern, Transliterator normalizer, + boolean swapPairEntries) { + return null; + } + } }