Class RegionFile
java.lang.Object
net.minecraft.world.level.chunk.storage.RegionFile
- All Implemented Interfaces:
AutoCloseable
This class handles a single region (or anvil) file and all files for single chunks at chunk positions for that one region file.
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescription(package private) class
(package private) static interface
-
Field Summary
FieldsModifier and TypeFieldDescriptionprivate static final int
private static final int
private static final int
private static final String
private static final int
private final Path
private final FileChannel
private final ByteBuffer
private static final int
(package private) final RegionStorageInfo
private static final org.slf4j.Logger
private final IntBuffer
private static final ByteBuffer
private final Path
private static final int
protected static final int
private final IntBuffer
protected final RegionBitmap
(package private) final RegionFileVersion
-
Constructor Summary
ConstructorsConstructorDescriptionRegionFile
(RegionStorageInfo info, Path path, Path externalFileDir, boolean sync) RegionFile
(RegionStorageInfo info, Path path, Path externalFileDir, RegionFileVersion version, boolean sync) -
Method Summary
Modifier and TypeMethodDescriptionvoid
void
close()
private DataInputStream
createChunkInputStream
(ChunkPos chunkPos, byte versionByte, InputStream inputStream) private DataInputStream
createExternalChunkInputStream
(ChunkPos chunkPos, byte versionByte) private ByteBuffer
private static ByteArrayInputStream
createStream
(ByteBuffer sourceBuffer, int length) boolean
doesChunkExist
(ChunkPos chunkPos) void
flush()
getChunkDataInputStream
(ChunkPos chunkPos) getChunkDataOutputStream
(ChunkPos chunkPos) Creates a newInputStream
for a chunk stored in a separate file.private Path
getExternalChunkPath
(ChunkPos chunkPos) Gets the path to store a chunk that can not be stored within the region file because it's larger than 1 MiB.private static byte
getExternalChunkVersion
(byte versionByte) private static int
getNumSectors
(int packedSectorOffset) Gets the amount of 4 KiB sectors used to store a chunk.private int
private static int
getOffsetIndex
(ChunkPos chunkPos) Gets the offset within the region file where the chunk metadata for a chunk can be found.getPath()
private static int
getSectorNumber
(int packedSectorOffset) Gets the offset in 4 KiB sectors from the start of the region file, where the data for a chunk starts.private static int
boolean
private static boolean
isExternalStreamChunk
(byte versionByte) private int
packSectorOffset
(int sectorOffset, int sectorCount) Packs the offset in 4 KiB sectors from the region file start and the amount of 4 KiB sectors used to store a chunk into oneint
.private void
private static int
sizeToSectors
(int size) Gets the amount of sectors required to store chunk data of a certain size in bytes.protected void
write
(ChunkPos chunkPos, ByteBuffer chunkData) private void
private RegionFile.CommitOp
writeToExternalFile
(Path externalChunkFile, ByteBuffer chunkData) Writes a chunk to a separate file with only that chunk.
-
Field Details
-
LOGGER
private static final org.slf4j.Logger LOGGER -
SECTOR_BYTES
private static final int SECTOR_BYTES- See Also:
-
SECTOR_INTS
protected static final int SECTOR_INTS- See Also:
-
CHUNK_HEADER_SIZE
private static final int CHUNK_HEADER_SIZE- See Also:
-
HEADER_OFFSET
private static final int HEADER_OFFSET- See Also:
-
PADDING_BUFFER
-
EXTERNAL_FILE_EXTENSION
- See Also:
-
EXTERNAL_STREAM_FLAG
private static final int EXTERNAL_STREAM_FLAG- See Also:
-
EXTERNAL_CHUNK_THRESHOLD
private static final int EXTERNAL_CHUNK_THRESHOLD- See Also:
-
CHUNK_NOT_PRESENT
private static final int CHUNK_NOT_PRESENT- See Also:
-
info
-
path
-
file
-
externalFileDir
-
version
-
header
-
offsets
-
timestamps
-
usedSectors
-
-
Constructor Details
-
RegionFile
public RegionFile(RegionStorageInfo info, Path path, Path externalFileDir, boolean sync) throws IOException - Throws:
IOException
-
RegionFile
public RegionFile(RegionStorageInfo info, Path path, Path externalFileDir, RegionFileVersion version, boolean sync) throws IOException - Throws:
IOException
-
-
Method Details
-
getPath
-
getExternalChunkPath
Gets the path to store a chunk that can not be stored within the region file because it's larger than 1 MiB. -
getChunkDataInputStream
- Throws:
IOException
-
getTimestamp
private static int getTimestamp() -
isExternalStreamChunk
private static boolean isExternalStreamChunk(byte versionByte) -
getExternalChunkVersion
private static byte getExternalChunkVersion(byte versionByte) -
createChunkInputStream
@Nullable private DataInputStream createChunkInputStream(ChunkPos chunkPos, byte versionByte, InputStream inputStream) throws IOException - Throws:
IOException
-
createExternalChunkInputStream
@Nullable private DataInputStream createExternalChunkInputStream(ChunkPos chunkPos, byte versionByte) throws IOException - Throws:
IOException
-
createStream
-
packSectorOffset
private int packSectorOffset(int sectorOffset, int sectorCount) Packs the offset in 4 KiB sectors from the region file start and the amount of 4 KiB sectors used to store a chunk into oneint
. -
getNumSectors
private static int getNumSectors(int packedSectorOffset) Gets the amount of 4 KiB sectors used to store a chunk. -
getSectorNumber
private static int getSectorNumber(int packedSectorOffset) Gets the offset in 4 KiB sectors from the start of the region file, where the data for a chunk starts. -
sizeToSectors
private static int sizeToSectors(int size) Gets the amount of sectors required to store chunk data of a certain size in bytes. -
doesChunkExist
-
getChunkDataOutputStream
Creates a newInputStream
for a chunk stored in a separate file.- Throws:
IOException
-
flush
- Throws:
IOException
-
clear
- Throws:
IOException
-
write
- Throws:
IOException
-
createExternalStub
-
writeToExternalFile
private RegionFile.CommitOp writeToExternalFile(Path externalChunkFile, ByteBuffer chunkData) throws IOException Writes a chunk to a separate file with only that chunk. This is used for chunks larger than 1 MiB- Throws:
IOException
-
writeHeader
- Throws:
IOException
-
getOffset
-
hasChunk
-
getOffsetIndex
Gets the offset within the region file where the chunk metadata for a chunk can be found. -
close
- Specified by:
close
in interfaceAutoCloseable
- Throws:
IOException
-
padToFullSector
- Throws:
IOException
-