--- /dev/null
+pub struct GenericCache<T: Copy> {
+ pub height: usize,
+ pub stride: usize,
+ pub xpos: usize,
+ pub data: Vec<T>,
+ pub default: T,
+}
+
+impl<T:Copy> GenericCache<T> {
+ pub fn new(height: usize, stride: usize, default: T) -> Self {
+ let mut ret = Self {
+ stride,
+ height,
+ xpos: 0,
+ data: Vec::with_capacity((height + 1) * stride),
+ default,
+ };
+ ret.reset();
+ ret
+ }
+ pub fn full_size(&self) -> usize { self.stride * (self.height + 1) }
+ pub fn reset(&mut self) {
+ self.data.truncate(0);
+ let size = self.full_size();
+ self.data.resize(size, self.default);
+ self.xpos = self.stride + 1;
+ }
+ pub fn update_row(&mut self) {
+ for i in 0..self.stride {
+ self.data[i] = self.data[self.height * self.stride + i];
+ }
+ self.data.truncate(self.stride);
+ let size = self.full_size();
+ self.data.resize(size, self.default);
+ self.xpos = self.stride + 1;
+ }
+}
+
#[allow(clippy::unreadable_literal)]
pub mod dsp;
+pub mod data;
+
pub mod test;
use nihav_core::codecs::*;
+use nihav_core::data::GenericCache;
use nihav_core::io::bitreader::*;
use super::vpcommon::*;
}
}
-pub struct GenericCache<T: Copy> {
- pub height: usize,
- pub stride: usize,
- pub xpos: usize,
- pub data: Vec<T>,
- pub default: T,
-}
-
-impl<T:Copy> GenericCache<T> {
- fn new(height: usize, stride: usize, default: T) -> Self {
- let mut ret = Self {
- stride,
- height,
- xpos: 0,
- data: Vec::with_capacity((height + 1) * stride),
- default,
- };
- ret.reset();
- ret
- }
- fn full_size(&self) -> usize { self.stride * (self.height + 1) }
- fn reset(&mut self) {
- self.data.truncate(0);
- let size = self.full_size();
- self.data.resize(size, self.default);
- self.xpos = self.stride + 1;
- }
- fn update_row(&mut self) {
- for i in 0..self.stride {
- self.data[i] = self.data[self.height * self.stride + i];
- }
- self.data.truncate(self.stride);
- let size = self.full_size();
- self.data.resize(size, self.default);
- self.xpos = self.stride + 1;
- }
-}
-
pub struct VP56Decoder {
version: u8,
has_alpha: bool,
use nihav_core::codecs::{NADecoderSupport, MV, ZERO_MV, DecoderError, DecoderResult, IPBShuffler};
use nihav_core::io::bitreader::{BitReader,BitReaderMode};
use nihav_core::io::intcode::*;
+use nihav_core::data::GenericCache;
use std::mem;
use super::rv34codes::*;
use super::rv34dsp::*;
-pub struct GenericCache<T: Copy> {
- pub height: usize,
- pub stride: usize,
- pub xpos: usize,
- pub data: Vec<T>,
- pub default: T,
-}
-
-impl<T:Copy> GenericCache<T> {
- pub fn new(height: usize, stride: usize, default: T) -> Self {
- let mut ret = Self {
- stride,
- height,
- xpos: 0,
- data: Vec::with_capacity((height + 1) * stride),
- default,
- };
- ret.reset();
- ret
- }
- fn full_size(&self) -> usize { self.stride * (self.height + 1) }
- pub fn reset(&mut self) {
- self.data.truncate(0);
- let size = self.full_size();
- self.data.resize(size, self.default);
- self.xpos = self.stride + 1;
- }
- pub fn update_row(&mut self) {
- for i in 0..self.stride {
- self.data[i] = self.data[self.height * self.stride + i];
- }
- self.data.truncate(self.stride);
- let size = self.full_size();
- self.data.resize(size, self.default);
- self.xpos = self.stride + 1;
- }
-}
-
trait RV34MVScale {
fn scale(&self, trd: u16, trb: u16) -> (MV, MV);
}