strangedb-core/src/main/java/it/cavallium/strangedb/database/references/DatabaseReferencesIO.java

68 lines
2.1 KiB
Java
Raw Normal View History

2019-03-07 16:19:53 +01:00
package it.cavallium.strangedb.database.references;
import it.cavallium.strangedb.database.IReferencesIO;
import it.cavallium.strangedb.database.blocks.DatabaseBlocksIO;
import java.io.IOException;
import java.nio.ByteBuffer;
2019-04-20 15:54:40 +02:00
import java.util.concurrent.locks.ReentrantReadWriteLock;
2019-03-07 16:19:53 +01:00
import static it.cavallium.strangedb.database.IBlocksMetadata.EMPTY_BLOCK_ID;
public class DatabaseReferencesIO implements IReferencesIO {
private final DatabaseBlocksIO blocksIO;
private final DatabaseReferencesMetadata referencesMetadata;
2019-04-20 15:54:40 +02:00
private ReentrantReadWriteLock lock = new ReentrantReadWriteLock(false);
2019-03-07 16:19:53 +01:00
public DatabaseReferencesIO(DatabaseBlocksIO blocksIO, DatabaseReferencesMetadata referencesMetadata) {
this.blocksIO = blocksIO;
this.referencesMetadata = referencesMetadata;
}
@Override
public long allocateReference() throws IOException {
return referencesMetadata.newReference(EMPTY_BLOCK_ID);
}
@Override
public long allocateReference(int size, ByteBuffer data) throws IOException {
long blockId = (size == 0) ? EMPTY_BLOCK_ID : blocksIO.newBlock(size, data);
return referencesMetadata.newReference(blockId);
}
@Override
2019-04-20 15:54:40 +02:00
public void writeToReference(long reference, byte cleanerId, int size, ByteBuffer data) throws IOException {
2019-04-21 02:14:50 +02:00
long blockId = (size == 0) ? EMPTY_BLOCK_ID : blocksIO.newBlock(size, data);
2019-04-20 15:54:40 +02:00
lock.writeLock().lock();
try {
referencesMetadata.editReference(reference, cleanerId, blockId);
} finally {
lock.writeLock().unlock();
}
2019-03-07 16:19:53 +01:00
}
@Override
public ByteBuffer readFromReference(long reference) throws IOException {
2019-04-20 22:18:34 +02:00
long blockId;
2019-04-20 15:54:40 +02:00
lock.readLock().lock();
try {
2019-04-20 22:18:34 +02:00
blockId = referencesMetadata.getReferenceBlockId(reference);
2019-04-20 15:54:40 +02:00
} finally {
lock.readLock().unlock();
}
2019-04-20 22:18:34 +02:00
return blocksIO.readBlock(blockId);
2019-03-07 16:19:53 +01:00
}
2019-04-22 00:10:10 +02:00
public ByteBuffer readFromReferenceSizeAndLastElementOfReferencesList(long reference) throws IOException {
long blockId;
lock.readLock().lock();
try {
blockId = referencesMetadata.getReferenceBlockId(reference);
} finally {
lock.readLock().unlock();
}
return blocksIO.readBlockSizeAndLastElementOfReferencesList(blockId);
}
2019-03-07 16:19:53 +01:00
}