added sixcoolers patch and more checks/removed unnecessary code

git-svn-id: https://svn.berlios.de/svnroot/repos/yacy/trunk@6636 6c8d7289-2bf4-0310-a012-ef5d649a1542
pull/1/head
orbiter 15 years ago
parent d8d8562c59
commit 3751ab4ae2

@ -29,7 +29,6 @@ import java.io.DataInputStream;
import java.io.File; import java.io.File;
import java.io.FileInputStream; import java.io.FileInputStream;
import java.io.IOException; import java.io.IOException;
import java.util.Arrays;
import java.util.Iterator; import java.util.Iterator;
import java.util.Map; import java.util.Map;
import java.util.Map.Entry; import java.util.Map.Entry;
@ -555,11 +554,12 @@ public class HeapReader {
private Map.Entry<byte[], byte[]> next0() { private Map.Entry<byte[], byte[]> next0() {
try { try {
byte b; byte b;
int len;
byte[] payload; byte[] payload;
byte[] key; byte[] key;
final int keylen1 = this.keylen - 1; final int keylen1 = this.keylen - 1;
while (true) { while (true) {
int len = is.readInt(); len = is.readInt();
if (len == 0) continue; // rare, but possible: zero length record (takes 4 bytes) if (len == 0) continue; // rare, but possible: zero length record (takes 4 bytes)
b = is.readByte(); // read a single by te to check for empty record b = is.readByte(); // read a single by te to check for empty record
if (b == 0) { if (b == 0) {
@ -575,6 +575,10 @@ public class HeapReader {
// so far we have read this.keylen - 1 + 1 = this.keylen bytes. // so far we have read this.keylen - 1 + 1 = this.keylen bytes.
// there must be a remaining number of len - this.keylen bytes left for the BLOB // there must be a remaining number of len - this.keylen bytes left for the BLOB
if (len < this.keylen) return null; // a strange case that can only happen in case of corrupted data if (len < this.keylen) return null; // a strange case that can only happen in case of corrupted data
if (is.available() < (len - this.keylen)) { // this really indicates corrupted data
Log.logWarning("HeapReader", "corrupted data by entry of " + len + " bytes");
return null;
}
payload = new byte[len - this.keylen]; // the remaining record entries payload = new byte[len - this.keylen]; // the remaining record entries
if (is.read(payload) < payload.length) return null; if (is.read(payload) < payload.length) return null;
return new entry(key, payload); return new entry(key, payload);

@ -100,18 +100,17 @@ public final class HeapWriter {
assert blob.length > 0; assert blob.length > 0;
key = HeapReader.normalizeKey(key, this.keylength); key = HeapReader.normalizeKey(key, this.keylength);
assert index.row().primaryKeyLength == this.keylength : index.row().primaryKeyLength + "!=" + key.length; assert index.row().primaryKeyLength == this.keylength : index.row().primaryKeyLength + "!=" + key.length;
assert key.length == this.keylength : "key.length == " + key.length + ", this.keylength = " + this.keylength; // after normalizing they should be equal in length
assert index.get(key) < 0 : "index.get(key) = " + index.get(key) + ", index.size() = " + index.size() + ", file.length() = " + this.heapFileTMP.length() + ", key = " + new String(key); // must not occur before assert index.get(key) < 0 : "index.get(key) = " + index.get(key) + ", index.size() = " + index.size() + ", file.length() = " + this.heapFileTMP.length() + ", key = " + new String(key); // must not occur before
if ((blob == null) || (blob.length == 0)) return; if ((blob == null) || (blob.length == 0)) return;
index.putUnique(key, this.seek); index.putUnique(key, this.seek);
int chunkl = this.keylength + blob.length; int chunkl = this.keylength + blob.length;
os.writeInt(chunkl); os.writeInt(chunkl);
os.write(key); os.write(key);
if (this.keylength > key.length) {
for (int i = 0; i < this.keylength - key.length; i++) os.write(ZERO);
}
os.write(blob); os.write(blob);
//assert (this.doublecheck.add(new String(key))) : "doublecheck failed for " + new String(key); //assert (this.doublecheck.add(new String(key))) : "doublecheck failed for " + new String(key);
this.seek += chunkl + 4; this.seek += chunkl + 4;
os.flush(); // necessary? may cause bad IO performance :-(
} }
protected static File fingerprintIndexFile(File f, String fingerprint) { protected static File fingerprintIndexFile(File f, String fingerprint) {

Loading…
Cancel
Save