build script: warn if building from data file which was not commited into Mercurial
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;
27 * @author Ing. František Kučera (frantovo.cz)
29 public class IndexEntry implements Comparable<IndexEntry> {
36 public IndexEntry(String name, long offset, long length) {
42 public void serialize(DataOutputStream indexOutputStream) throws IOException {
43 indexOutputStream.write(name.getBytes(StandardCharsets.UTF_8));
44 indexOutputStream.write(0);
45 indexOutputStream.writeInt((int) offset); // unsigned int 32
46 indexOutputStream.writeInt((int) length); // unsigned int 32
49 public void setOrdinal(long ordinal) {
50 this.ordinal = ordinal;
53 public long getOrdinal() {
58 public int compareTo(IndexEntry o) {
59 int nameDiff = name.compareTo(o.name);
61 int offsetDiff = ((Long) offset).compareTo(o.offset);
62 if (offsetDiff == 0) {
63 return ((Long) length).compareTo(o.length);
73 public boolean equals(Object o) {
74 return o instanceof IndexEntry && compareTo((IndexEntry) o) == 0;
78 public int hashCode() {
80 hash = 53 * hash + Objects.hashCode(this.name);
81 hash = 53 * hash + (int) (this.offset ^ (this.offset >>> 32));
82 hash = 53 * hash + (int) (this.length ^ (this.length >>> 32));