Clarify chunk space/world space

This commit is contained in:
Ryan 2022-09-12 20:20:58 -07:00
parent adc927d319
commit dc64f06cac
2 changed files with 18 additions and 10 deletions

View file

@ -5,7 +5,7 @@ use vek::Vec3;
use crate::protocol::{Decode, Encode}; use crate::protocol::{Decode, Encode};
/// Represents an absolute block position in a world. /// Represents an absolute block position in world space.
#[derive(Clone, Copy, Default, PartialEq, Eq, Hash, Debug)] #[derive(Clone, Copy, Default, PartialEq, Eq, Hash, Debug)]
pub struct BlockPos { pub struct BlockPos {
pub x: i32, pub x: i32,

View file

@ -159,11 +159,11 @@ impl<C: Config> Chunks<C> {
self.chunks.par_iter_mut().map(|(&pos, chunk)| (pos, chunk)) self.chunks.par_iter_mut().map(|(&pos, chunk)| (pos, chunk))
} }
/// Gets the block state at a global position in the world. /// Gets the block state at an absolute block position in world space.
/// ///
/// If the position is not inside of a chunk, then `None` is returned. /// If the position is not inside of a chunk, then `None` is returned.
/// ///
/// Note: if you need to get a large number of blocks, it is more efficient /// **Note**: if you need to get a large number of blocks, it is more efficient
/// to read from the chunks directly with [`Chunk::get_block_state`]. /// to read from the chunks directly with [`Chunk::get_block_state`].
pub fn get_block_state(&self, pos: impl Into<BlockPos>) -> Option<BlockState> { pub fn get_block_state(&self, pos: impl Into<BlockPos>) -> Option<BlockState> {
let pos = pos.into(); let pos = pos.into();
@ -186,13 +186,13 @@ impl<C: Config> Chunks<C> {
} }
} }
/// Sets the block state at a global position in the world. /// Sets the block state at an absolute block position in world space.
/// ///
/// If the position is inside of a chunk, then `true` is returned. /// If the position is inside of a chunk, then `true` is returned and the
/// Otherwise, `false` is returned. The function has no effect if `false` is /// block is set. Otherwise, `false` is returned and the function has no
/// returned. /// effect.
/// ///
/// Note: if you need to set a large number of blocks, it may be more /// **Note**: if you need to set a large number of blocks, it may be more
/// efficient write to the chunks directly with /// efficient write to the chunks directly with
/// [`Chunk::set_block_state`]. /// [`Chunk::set_block_state`].
pub fn set_block_state(&mut self, pos: impl Into<BlockPos>, block: BlockState) -> bool { pub fn set_block_state(&mut self, pos: impl Into<BlockPos>, block: BlockState) -> bool {
@ -249,6 +249,10 @@ pub trait Chunk {
/// Gets the block state at the provided offsets in the chunk. /// Gets the block state at the provided offsets in the chunk.
/// ///
/// **Note**: The arguments to this function are offsets from the minimum
/// corner of the chunk in _chunk space_ rather than _world space_. You
/// might be looking for [`Chunks::get_block_state`] instead.
///
/// # Panics /// # Panics
/// ///
/// Panics if the offsets are outside the bounds of the chunk. /// Panics if the offsets are outside the bounds of the chunk.
@ -256,6 +260,10 @@ pub trait Chunk {
/// Sets the block state at the provided offsets in the chunk. /// Sets the block state at the provided offsets in the chunk.
/// ///
/// **Note**: The arguments to this function are offsets from the minimum
/// corner of the chunk in _chunk space_ rather than _world space_. You
/// might be looking for [`Chunks::set_block_state`] instead.
///
/// # Panics /// # Panics
/// ///
/// Panics if the offsets are outside the bounds of the chunk. /// Panics if the offsets are outside the bounds of the chunk.
@ -263,7 +271,7 @@ pub trait Chunk {
/// Gets the biome at the provided biome offsets in the chunk. /// Gets the biome at the provided biome offsets in the chunk.
/// ///
/// Note: the arguments are **not** block positions. Biomes are 4x4x4 /// **Note**: the arguments are **not** block positions. Biomes are 4x4x4
/// segments of a chunk, so `x` and `z` are in `0..=4`. /// segments of a chunk, so `x` and `z` are in `0..=4`.
/// ///
/// # Panics /// # Panics
@ -273,7 +281,7 @@ pub trait Chunk {
/// Sets the biome at the provided biome offsets in the chunk. /// Sets the biome at the provided biome offsets in the chunk.
/// ///
/// Note: the arguments are **not** block positions. Biomes are 4x4x4 /// **Note**: the arguments are **not** block positions. Biomes are 4x4x4
/// segments of a chunk, so `x` and `z` are in `0..=4`. /// segments of a chunk, so `x` and `z` are in `0..=4`.
/// ///
/// # Panics /// # Panics