codec: refactor decoder and encoder

This commit is contained in:
meh
2015-05-16 17:28:25 +02:00
parent bdc4c427a8
commit 757088f46c
13 changed files with 567 additions and 288 deletions

View File

@ -0,0 +1,31 @@
use std::ops::Deref;
use libc::c_int;
use ffi::*;
use super::Encoder;
use ::{Packet, Error};
use ::frame;
pub struct Audio(pub Encoder);
impl Audio {
pub fn encode(&self, frame: &frame::Audio, out: &mut Packet) -> Result<bool, Error> {
unsafe {
let mut got: c_int = 0;
match avcodec_encode_audio2(self.ptr, &mut out.val, frame.ptr, &mut got) {
e if e < 0 => Err(Error::new(e)),
_ => Ok(got != 0)
}
}
}
}
impl Deref for Audio {
type Target = Encoder;
fn deref(&self) -> &<Self as Deref>::Target {
&self.0
}
}

83
src/codec/encoder/mod.rs Normal file
View File

@ -0,0 +1,83 @@
pub mod video;
pub use self::video::Video;
pub mod audio;
pub use self::audio::Audio;
pub mod subtitle;
pub use self::subtitle::Subtitle;
use std::ffi::CString;
use std::ptr;
use std::ops::Deref;
use ffi::*;
use super::Id;
use super::context::Opened;
use ::{Codec, Error};
use ::media;
pub struct Encoder(pub Opened);
impl Encoder {
pub fn video(self) -> Result<Video, Error> {
if self.medium() == media::Type::Video {
Ok(Video(self))
}
else {
Err(Error::from(AVERROR_INVALIDDATA))
}
}
pub fn audio(self) -> Result<Audio, Error> {
if self.medium() == media::Type::Audio {
Ok(Audio(self))
}
else {
Err(Error::from(AVERROR_INVALIDDATA))
}
}
pub fn subtitle(self) -> Result<Subtitle, Error> {
if self.medium() == media::Type::Subtitle {
Ok(Subtitle(self))
}
else {
Err(Error::from(AVERROR_INVALIDDATA))
}
}
}
impl Deref for Encoder {
type Target = Opened;
fn deref(&self) -> &<Self as Deref>::Target {
&self.0
}
}
pub fn find(id: Id) -> Option<Codec<'static>> {
unsafe {
let ptr = avcodec_find_encoder(id.into());
if ptr == ptr::null_mut() {
None
}
else {
Some(Codec::wrap(ptr))
}
}
}
pub fn find_by_name(name: &str) -> Option<Codec<'static>> {
unsafe {
let ptr = avcodec_find_encoder_by_name(CString::new(name).unwrap().as_ptr());
if ptr == ptr::null_mut() {
None
}
else {
Some(Codec::wrap(ptr))
}
}
}

View File

@ -0,0 +1,28 @@
use std::ops::Deref;
use libc::c_int;
use ffi::*;
use super::Encoder;
use ::Error;
pub struct Subtitle(pub Encoder);
impl Subtitle {
pub fn encode(&self, subtitle: &::Subtitle, out: &mut [u8]) -> Result<bool, Error> {
unsafe {
match avcodec_encode_subtitle(self.ptr, out.as_mut_ptr(), out.len() as c_int, &subtitle.val) {
e if e < 0 => Err(Error::new(e)),
_ => Ok(true)
}
}
}
}
impl Deref for Subtitle {
type Target = Encoder;
fn deref(&self) -> &<Self as Deref>::Target {
&self.0
}
}

View File

@ -0,0 +1,31 @@
use std::ops::Deref;
use libc::c_int;
use ffi::*;
use super::Encoder;
use ::{Packet, Error};
use ::frame;
pub struct Video(pub Encoder);
impl Video {
pub fn encode(&self, frame: &frame::Video, out: &mut Packet) -> Result<bool, Error> {
unsafe {
let mut got: c_int = 0;
match avcodec_encode_video2(self.ptr, &mut out.val, frame.ptr, &mut got) {
e if e < 0 => Err(Error::new(e)),
_ => Ok(got != 0)
}
}
}
}
impl Deref for Video {
type Target = Encoder;
fn deref(&self) -> &<Self as Deref>::Target {
&self.0
}
}