]> gitweb.fperrin.net Git - Dictionary.git/blobdiff - src/com/hughes/android/dictionary/engine/PairEntry.java
WebView links starting to work (still timing problem).
[Dictionary.git] / src / com / hughes / android / dictionary / engine / PairEntry.java
index 55c32d0dbb8d8d0d90902b5f4fcc64f4a63158e1..3453dc357f12e329f5536d023d860612c90fc31f 100644 (file)
@@ -1,52 +1,75 @@
+// Copyright 2011 Google Inc. All Rights Reserved.
+//
+// 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.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.IOException;
 import java.io.PrintStream;
 import java.io.RandomAccessFile;
+import java.util.ArrayList;
+import java.util.List;
+import java.util.regex.Pattern;
 
-import com.hughes.util.raf.RAFSerializable;
-import com.hughes.util.raf.RAFSerializer;
-
-public class PairEntry extends Entry implements RAFSerializable<PairEntry> {
+public class PairEntry extends AbstractEntry implements RAFSerializable<PairEntry>, Comparable<PairEntry> {
   
-  public static final class Pair {
-    final String lang1;
-    final String lang2;
-    public Pair(final String lang1, final String lang2) {
-      this.lang1 = lang1;
-      this.lang2 = lang2;
-    }
-    public String toString() {
-      return lang1 + "\t" + lang2;
-    }
+  public final List<Pair> pairs;
+
+  public PairEntry(final EntrySource entrySource) {
+    super(entrySource);
+    pairs = new ArrayList<Pair>(1);    
   }
-  
-  final Pair[] pairs;
-  
-  public PairEntry(final Pair[] pairs) {
-    this.pairs = pairs;
+
+  public PairEntry(final EntrySource entrySource, final String lang1, final String lang2) {
+    this(entrySource);
+    this.pairs.add(new Pair(lang1, lang2));
   }
   
-  public PairEntry(final RandomAccessFile raf) throws IOException {
-    pairs = new Pair[raf.readInt()];
-    for (int i = 0; i < pairs.length; ++i) {
-      pairs[i] = new Pair(raf.readUTF(), raf.readUTF());
+  public PairEntry(final Dictionary dictionary, final RandomAccessFile raf, final int index) throws IOException {
+    super(dictionary, raf, index);
+    final int size = raf.readInt();
+    pairs = new ArrayList<PairEntry.Pair>(size);
+    for (int i = 0; i < size; ++i) {
+      pairs.add(new Pair(raf.readUTF(), raf.readUTF()));
     }
   }
   @Override
   public void write(RandomAccessFile raf) throws IOException {
-    // TODO: this couls be a short.
-    raf.writeInt(pairs.length);
-    for (int i = 0; i < pairs.length; ++i) {
-      raf.writeUTF(pairs[i].lang1);
-      raf.writeUTF(pairs[i].lang2);
+    super.write(raf);
+    // TODO: this could be a short.
+    raf.writeInt(pairs.size());
+    for (int i = 0; i < pairs.size(); ++i) {
+      assert pairs.get(i).lang1.length() > 0;
+      raf.writeUTF(pairs.get(i).lang1);
+      raf.writeUTF(pairs.get(i).lang2);
     }
   }
   
-  static final RAFSerializer<PairEntry> SERIALIZER = new RAFSerializer<PairEntry>() {
+  static final class Serializer implements RAFListSerializer<PairEntry> {
+    
+    final Dictionary dictionary;
+    
+    Serializer(Dictionary dictionary) {
+      this.dictionary = dictionary;
+    }
+
     @Override
-    public PairEntry read(RandomAccessFile raf) throws IOException {
-      return new PairEntry(raf);
+    public PairEntry read(RandomAccessFile raf, int index) throws IOException {
+      return new PairEntry(dictionary, raf, index);
     }
 
     @Override
@@ -55,6 +78,21 @@ public class PairEntry extends Entry implements RAFSerializable<PairEntry> {
     }
   };
   
+  @Override
+  public void addToDictionary(final Dictionary dictionary) {
+    assert index == -1;
+    dictionary.pairEntries.add(this);
+    index = dictionary.pairEntries.size() - 1;
+  }
+  
+  @Override
+  public RowBase CreateRow(int rowIndex, Index dictionaryIndex) {
+    return new Row(this.index, rowIndex, dictionaryIndex);
+  }
+
+
+  // --------------------------------------------------------------------
+  
 
   public static class Row extends RowBase {
     
@@ -67,26 +105,137 @@ public class PairEntry extends Entry implements RAFSerializable<PairEntry> {
         final Index index) {
       super(referenceIndex, thisRowIndex, index);
     }
+    
+    @Override
+    public String toString() {
+      return getRawText(false);
+    }
 
     public PairEntry getEntry() {
       return index.dict.pairEntries.get(referenceIndex);
     }
     
     @Override
-    public Object draw(String searchText) {
-      // TODO Auto-generated method stub
-      return null;
+    public void print(PrintStream out) {
+      final PairEntry pairEntry = getEntry();
+      for (int i = 0; i < pairEntry.pairs.size(); ++i) {
+        out.print((i == 0 ? "  " : "    ") + pairEntry.pairs.get(i));
+        out.println();
+      }
     }
 
     @Override
-    public void print(PrintStream out) {
+    public String getRawText(boolean compact) {
       final PairEntry pairEntry = getEntry();
-      for (int i = 0; i < pairEntry.pairs.length; ++i) {
-        out.println((i == 0 ? "  " : "    ") + pairEntry.pairs[i]);
+      return pairEntry.getRawText(compact);
+    }
+
+    @Override
+    public RowMatchType matches(final List<String> searchTokens, final Pattern orderedMatchPattern, final Transliterator normalizer, final boolean swapPairEntries) {
+      final int side = swapPairEntries ? 1 : 0;
+      final List<Pair> pairs = getEntry().pairs;
+      final String[] pairSides = new String[pairs.size()];
+      for (int i = 0; i < pairs.size(); ++i) {
+        pairSides[i] = normalizer.transform(pairs.get(i).get(side));
       }
+      for (int i = searchTokens.size() - 1; i >= 0; --i) {
+        final String searchToken = searchTokens.get(i);
+        boolean found = false;
+        for (final String pairSide : pairSides) {
+          found |= pairSide.contains(searchToken);
+        }
+        if (!found) {
+          return RowMatchType.NO_MATCH;
+        }
+      }
+      for (final String pairSide : pairSides) {
+        if (orderedMatchPattern.matcher(pairSide).find()) {
+          return RowMatchType.ORDERED_MATCH;
+        }
+      }
+      return RowMatchType.BAG_OF_WORDS_MATCH;
+    }
+    
+    @Override
+    public int getSideLength(boolean swapPairEntries) {
+      int result = 0;
+      final int side = swapPairEntries ? 1 : 0;
+      for (final Pair pair : getEntry().pairs) {
+        result += pair.get(side).length();
+      }
+      return result;
+    }
+  
+  }
+
+  public String getRawText(final boolean compact) {
+    if (compact) {
+      return this.pairs.get(0).toStringTab();
     }
+    final StringBuilder builder = new StringBuilder();
+    for (int i = 0; i < this.pairs.size(); ++i) {
+      if (i > 0) {
+        builder.append(" | ");
+      }
+      builder.append(this.pairs.get(i).lang1);
+    }
+    builder.append("\t");
+    for (int i = 0; i < this.pairs.size(); ++i) {
+      if (i > 0) {
+        builder.append(" | ");
+      }
+      builder.append(this.pairs.get(i).lang2);
+    }
+    return builder.toString();
+  }
+
+  @Override
+  public int compareTo(final PairEntry that) {
+    return this.getRawText(false).compareTo(that.getRawText(false));
+  }
+  
+  @Override
+  public String toString() {
+    return getRawText(false);
   }
 
+  // -----------------------------------------------------------------------
+  
+  public static final class Pair {
+    
+    public final String lang1;
+    public final String lang2;
+    
+    public Pair(final String lang1, final String lang2) {
+      this.lang1 = lang1;
+      this.lang2 = lang2;
+      if (!(lang1.trim().length() > 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!!!";
+    }
+
+    public Pair(final String lang1, final String lang2, final boolean swap) {
+      this(swap ? lang2 : lang1, swap ? lang1 : lang2);
+    }
+
+    public String toString() {
+      return lang1 + " :: " + lang2;
+    }
+
+    public String toStringTab() {
+      return lang1 + "\t" + lang2;
+    }
 
+    public String get(int i) {
+      if (i == 0) {
+        return lang1;
+      } else if (i == 1) {
+        return lang2;
+      }
+      throw new IllegalArgumentException();
+    }
 
+  }
 }