X-Git-Url: http://gitweb.fperrin.net/?a=blobdiff_plain;f=src%2Fcom%2Fhughes%2Fandroid%2Fdictionary%2Fengine%2FPairEntry.java;h=a82063efed31c3b55d1a418b9b34dec0cbf56411;hb=83d9dc7cd871082a82c2dd0dbb7a0ceabd7c83a0;hp=d47ae893831cf2597fc776de9d4fbe3975d605d6;hpb=b602276836dba6fdd73b70538de5f115f36ce315;p=Dictionary.git diff --git a/src/com/hughes/android/dictionary/engine/PairEntry.java b/src/com/hughes/android/dictionary/engine/PairEntry.java index d47ae89..a82063e 100644 --- a/src/com/hughes/android/dictionary/engine/PairEntry.java +++ b/src/com/hughes/android/dictionary/engine/PairEntry.java @@ -15,7 +15,7 @@ package com.hughes.android.dictionary.engine; import com.hughes.util.StringUtil; -import com.hughes.util.raf.RAFListSerializer; +import com.hughes.util.raf.RAFListSerializerSkippable; import com.hughes.util.raf.RAFSerializable; import com.ibm.icu.text.Transliterator; @@ -24,6 +24,7 @@ import java.io.DataOutput; import java.io.IOException; import java.io.PrintStream; import java.util.ArrayList; +import java.util.Collections; import java.util.List; import java.util.regex.Pattern; @@ -34,7 +35,7 @@ public class PairEntry extends AbstractEntry implements RAFSerializable(1); + pairs = new ArrayList<>(1); } public PairEntry(final EntrySource entrySource, final String lang1, final String lang2) { @@ -46,9 +47,14 @@ public class PairEntry extends AbstractEntry implements RAFSerializable= 7 ? StringUtil.readVarInt(raf) : raf.readInt(); - pairs = new ArrayList(size); - for (int i = 0; i < size; ++i) { - pairs.add(new Pair(raf.readUTF(), raf.readUTF())); + // Use singletonList for better performance in common case + if (size == 1) pairs = Collections.singletonList(new Pair(raf.readUTF(), raf.readUTF())); + else + { + pairs = new ArrayList<>(size); + for (int i = 0; i < size; ++i) { + pairs.add(new Pair(raf.readUTF(), raf.readUTF())); + } } } @@ -63,7 +69,7 @@ public class PairEntry extends AbstractEntry implements RAFSerializable { + static final class Serializer implements RAFListSerializerSkippable { final Dictionary dictionary; @@ -76,6 +82,25 @@ public class PairEntry extends AbstractEntry implements RAFSerializable= 7) + { + StringUtil.readVarInt(raf); + size = StringUtil.readVarInt(raf); + } + else + { + raf.skipBytes(2); + size = raf.readInt(); + } + for (int i = 0; i < 2*size; ++i) { + int l = raf.readUnsignedShort(); + raf.skipBytes(l); + } + } + @Override public void write(DataOutput raf, PairEntry t) throws IOException { t.write(raf); @@ -172,7 +197,7 @@ public class PairEntry extends AbstractEntry implements RAFSerializable 0 && lang2.trim().length() > 0)) { - System.err.println("poop"); - } - assert lang1.trim().length() > 0 || lang2.trim().length() > 0 : "Empty pair!!!"; assert lang1.trim().length() > 0 && lang2.trim().length() > 0 : "Empty pair!!!"; } @@ -228,7 +250,7 @@ public class PairEntry extends AbstractEntry implements RAFSerializable