summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorJames Ahlborn <jtahlborn@yahoo.com>2008-04-15 02:49:03 +0000
committerJames Ahlborn <jtahlborn@yahoo.com>2008-04-15 02:49:03 +0000
commita341781aa419d9b6eec105dc8a5d59ff52138e41 (patch)
treeb28efc336e161da3351704cee54d37d3fa25c9b2 /src
parent5ed9b04c403f5cc8f7316523b4f5a5b64b9e4419 (diff)
downloadjackcess-a341781aa419d9b6eec105dc8a5d59ff52138e41.tar.gz
jackcess-a341781aa419d9b6eec105dc8a5d59ff52138e41.zip
put entry validation inline with entry reading
git-svn-id: https://svn.code.sf.net/p/jackcess/code/jackcess/trunk@326 f203690c-595d-4dc9-a70b-905162fa7fd2
Diffstat (limited to 'src')
-rw-r--r--src/java/com/healthmarketscience/jackcess/Index.java20
1 files changed, 9 insertions, 11 deletions
diff --git a/src/java/com/healthmarketscience/jackcess/Index.java b/src/java/com/healthmarketscience/jackcess/Index.java
index 9eb3ca1..ec3629d 100644
--- a/src/java/com/healthmarketscience/jackcess/Index.java
+++ b/src/java/com/healthmarketscience/jackcess/Index.java
@@ -806,6 +806,7 @@ public abstract class Index implements Comparable<Index> {
TempBufferHolder.newHolder(TempBufferHolder.Type.HARD, true,
ByteOrder.BIG_ENDIAN);
+ Entry prevEntry = FIRST_ENTRY;
for (int i = 0; i < entryMaskLength; i++) {
byte entryMask = buffer.get(entryMaskPos + i);
for (int j = 0; j < 8; j++) {
@@ -823,8 +824,14 @@ public abstract class Index implements Comparable<Index> {
curEntryLen += entryPrefix.length;
}
totalEntrySize += curEntryLen;
+
+ Entry entry = newEntry(curEntryBuffer, curEntryLen, isLeaf);
+ if(prevEntry.compareTo(entry) >= 0) {
+ throw new IOException("Unexpected order in index entries, " +
+ prevEntry + " >= " + entry);
+ }
- entries.add(newEntry(curEntryBuffer, curEntryLen, isLeaf));
+ entries.add(entry);
if(entries.size() == 1) {
if(entryPrefixLength > 0) {
@@ -836,19 +843,10 @@ public abstract class Index implements Comparable<Index> {
}
lastStart += length;
+ prevEntry = entry;
}
}
}
-
- // check the entry order, just to be safe
- for(int i = 0; i < (entries.size() - 1); ++i) {
- Entry e1 = entries.get(i);
- Entry e2 = entries.get(i + 1);
- if(e1.compareTo(e2) > 0) {
- throw new IOException("Unexpected order in index entries, " +
- e1 + " is greater than " + e2);
- }
- }
dataPage.setEntryPrefix(entryPrefix != null ? entryPrefix : EMPTY_PREFIX);
dataPage.setEntries(entries);