X-Git-Url: http://gitweb.fperrin.net/?a=blobdiff_plain;f=src%2Fcom%2Fhughes%2Fandroid%2Fdictionary%2Fengine%2FAbstractEntry.java;h=4563017bcc2a15afc44c0bcaf6c439c8311524ab;hb=8674b09eae371994e01e0af541b546fced86c366;hp=24a1d82afb26e8ede46aca8f42cde3f1eac02370;hpb=f16d8ed40c49c70cf6c4e80e0392f9c01793cd25;p=Dictionary.git diff --git a/src/com/hughes/android/dictionary/engine/AbstractEntry.java b/src/com/hughes/android/dictionary/engine/AbstractEntry.java index 24a1d82..4563017 100644 --- a/src/com/hughes/android/dictionary/engine/AbstractEntry.java +++ b/src/com/hughes/android/dictionary/engine/AbstractEntry.java @@ -14,31 +14,39 @@ package com.hughes.android.dictionary.engine; +import java.io.DataInput; +import java.io.DataOutput; import java.io.IOException; -import java.io.RandomAccessFile; - - -public abstract class AbstractEntry { - - final EntrySource entrySource; - - protected AbstractEntry(EntrySource entrySource) { - this.entrySource = entrySource; - } - - public AbstractEntry(Dictionary dictionary, RandomAccessFile raf) throws IOException { - if (dictionary.dictFileVersion >= 1) { - final int entrySouceIdx = raf.readShort(); - this.entrySource = dictionary.sources.get(entrySouceIdx); - } else { - this.entrySource = null; + +import com.hughes.util.IndexedObject; +import com.hughes.util.StringUtil; + +public abstract class AbstractEntry extends IndexedObject { + + public final EntrySource entrySource; + + AbstractEntry(EntrySource entrySource) { + super(-1); + this.entrySource = entrySource; + } + + AbstractEntry(Dictionary dictionary, DataInput raf, final int index) + throws IOException { + super(index); + if (dictionary.dictFileVersion >= 1) { + final int entrySourceIdx = dictionary.dictFileVersion >= 7 ? StringUtil.readVarInt(raf) : raf.readShort(); + this.entrySource = dictionary.sources.get(entrySourceIdx); + } else { + this.entrySource = null; + } + } + + void write(DataOutput raf) throws IOException { + StringUtil.writeVarInt(raf, entrySource.index()); } - } - public void write(RandomAccessFile raf) throws IOException { - raf.writeShort(entrySource.index()); - } + public abstract void addToDictionary(final Dictionary dictionary); - public abstract int addToDictionary(final Dictionary dictionary); + public abstract RowBase CreateRow(int rowIndex, Index dictionaryIndex); }