2 * Free Telco Dictionary
3 * Copyright © 2013 František Kučera (frantovo.cz)
5 * This program is free software: you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation, either version 3 of the License, or
8 * (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this program. If not, see <http://www.gnu.org/licenses/>.
18 package cz.frantovo.telco.dictionary;
20 import java.io.DataOutputStream;
21 import java.io.IOException;
22 import java.nio.charset.StandardCharsets;
23 import java.util.Objects;
26 * Represents one item in StarDict index file (.idx)
27 * which links the term and its position and length in data file (.dict)
29 * @author Ing. František Kučera (frantovo.cz)
31 public class IndexEntry implements Comparable<IndexEntry> {
38 public IndexEntry(String name, long offset, long length) {
44 public void serialize(DataOutputStream indexOutputStream) throws IOException {
45 indexOutputStream.write(name.getBytes(StandardCharsets.UTF_8));
46 indexOutputStream.write(0);
47 indexOutputStream.writeInt((int) offset); // unsigned int 32
48 indexOutputStream.writeInt((int) length); // unsigned int 32
51 public void setOrdinal(long ordinal) {
52 this.ordinal = ordinal;
55 public long getOrdinal() {
60 public int compareTo(IndexEntry o) {
61 int nameDiff = name.compareTo(o.name);
63 int offsetDiff = ((Long) offset).compareTo(o.offset);
64 if (offsetDiff == 0) {
65 return ((Long) length).compareTo(o.length);
75 public boolean equals(Object o) {
76 return o instanceof IndexEntry && compareTo((IndexEntry) o) == 0;
80 public int hashCode() {
82 hash = 53 * hash + Objects.hashCode(this.name);
83 hash = 53 * hash + (int) (this.offset ^ (this.offset >>> 32));
84 hash = 53 * hash + (int) (this.length ^ (this.length >>> 32));