aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorKostya Shishkov <kostya.shishkov@gmail.com>2017-08-12 11:21:29 +0200
committerKostya Shishkov <kostya.shishkov@gmail.com>2017-08-12 11:21:29 +0200
commit83b49341aad5de030ee5503fa0873eb4d8c6be3a (patch)
tree6c10677222e4e9008a4aaed0fff3f84c6330b391 /src
parent098dcca9b5abe8064a3db7a280eb504d40bd5b2e (diff)
downloadnihav-83b49341aad5de030ee5503fa0873eb4d8c6be3a.tar.gz
io: mark some bitstream reading functions as inline
Diffstat (limited to 'src')
-rw-r--r--src/io/bitreader.rs8
-rw-r--r--src/io/intcode.rs1
2 files changed, 9 insertions, 0 deletions
diff --git a/src/io/bitreader.rs b/src/io/bitreader.rs
index b3e478e..ea5f27c 100644
--- a/src/io/bitreader.rs
+++ b/src/io/bitreader.rs
@@ -70,6 +70,7 @@ impl<'a> BitReader<'a> {
}
}
+ #[inline(always)]
fn refill(&mut self) -> BitReaderResult<()> {
if self.pos >= self.end { return Err(BitstreamEnd) }
while self.bits <= 32 {
@@ -106,6 +107,7 @@ impl<'a> BitReader<'a> {
Ok(())
}
+ #[inline(always)]
fn read_cache(&mut self, nbits: u8) -> u32 {
let res = match self.mode {
BitReaderMode::LE => ((1u64 << nbits) - 1) & self.cache,
@@ -122,6 +124,7 @@ impl<'a> BitReader<'a> {
res as i32
}
+ #[inline(always)]
fn skip_cache(&mut self, nbits: u8) {
match self.mode {
BitReaderMode::LE => self.cache >>= nbits,
@@ -130,11 +133,13 @@ impl<'a> BitReader<'a> {
self.bits -= nbits;
}
+ #[inline(always)]
fn reset_cache(&mut self) {
self.bits = 0;
self.cache = 0;
}
+ #[inline(always)]
pub fn read(&mut self, nbits: u8) -> BitReaderResult<u32> {
if nbits == 0 { return Ok(0) }
if nbits > 32 { return Err(TooManyBitsRequested) }
@@ -158,6 +163,7 @@ impl<'a> BitReader<'a> {
Ok(res)
}
+ #[inline(always)]
pub fn read_bool(&mut self) -> BitReaderResult<bool> {
if self.bits < 1 {
if let Err(err) = self.refill() { return Err(err) }
@@ -168,12 +174,14 @@ impl<'a> BitReader<'a> {
Ok(res == 1)
}
+ #[inline(always)]
pub fn peek(&mut self, nbits: u8) -> u32 {
if nbits > 32 { return 0 }
if self.bits < nbits { let _ = self.refill(); }
self.read_cache(nbits)
}
+ #[inline(always)]
pub fn skip(&mut self, nbits: u32) -> BitReaderResult<()> {
if self.bits as u32 >= nbits {
self.skip_cache(nbits as u8);
diff --git a/src/io/intcode.rs b/src/io/intcode.rs
index 141377d..5e35a15 100644
--- a/src/io/intcode.rs
+++ b/src/io/intcode.rs
@@ -96,6 +96,7 @@ fn uval_to_sval0pm(uval: u32) -> i32 {
}
impl<'a> IntCodeReader for BitReader<'a> {
+ #[inline(always)]
fn read_code(&mut self, t: UintCodeType) -> BitReaderResult<u32> {
match t {
UintCodeType::UnaryOnes => read_unary(self, 0),