1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64
use crate::result::SQLiteError;
use alloc::format;
use super::ParseBytes;
use core::ops::Deref;
/// # Page Size (2 Bytes)
/// The two-byte value beginning at offset 16 determines the page size of the
/// database. For SQLite versions 3.7.0.1 (2010-08-04) and earlier, this value
/// is interpreted as a big-endian integer and must be a power of two between
/// 512 and 32768, inclusive. Beginning with SQLite version 3.7.1 (2010-08-23),
/// a page size of 65536 bytes is supported. The value 65536 will not fit in a
/// two-byte integer, so to specify a 65536-byte page size, the value at offset
/// 16 is 0x00 0x01. This value can be interpreted as a big-endian 1 and
/// thought of as a magic number to represent the 65536 page size. Or one can
/// view the two-byte field as a little endian number and say that it
/// represents the page size divided by 256. These two interpretations of the
/// page-size field are equivalent.
#[derive(Debug)]
pub struct PageSize(u32);
impl PageSize {
pub fn get(&self) -> u32 {
self.0
}
}
impl Deref for PageSize {
type Target = u32;
fn deref(&self) -> &Self::Target {
&self.0
}
}
impl ParseBytes<&[u8]> for PageSize {
fn struct_name() -> &'static str {
"PageSize"
}
fn bytes_length() -> usize {
2
}
fn parsing_handler(bytes: &[u8]) -> crate::result::SQLiteResult<Self> {
use core::ops::Not;
let buf: [u8; 2] = bytes.try_into()?;
let page_size = u16::from_be_bytes(buf);
if page_size == 1 {
Ok(Self(65_536))
} else {
if page_size < 512 {
return Err(SQLiteError::Custom(format!(
"Page size [{page_size}] can't be less than 512"
)));
}
if page_size.is_power_of_two().not() {
return Err(SQLiteError::msg("Page size must be power of two"));
}
Ok(Self(page_size.into()))
}
}
}