mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer-rs.git
synced 2025-01-11 01:35:26 +00:00
Store encoding profiles inside the container builder as a Vec
This commit is contained in:
parent
5d17718e3b
commit
8e413fa3c9
1 changed files with 7 additions and 19 deletions
|
@ -11,7 +11,6 @@ use glib::translate::*;
|
||||||
|
|
||||||
use auto::EncodingAudioProfile;
|
use auto::EncodingAudioProfile;
|
||||||
use auto::EncodingContainerProfile;
|
use auto::EncodingContainerProfile;
|
||||||
use auto::EncodingContainerProfileExt;
|
|
||||||
use auto::EncodingProfile;
|
use auto::EncodingProfile;
|
||||||
use auto::EncodingVideoProfile;
|
use auto::EncodingVideoProfile;
|
||||||
|
|
||||||
|
@ -419,15 +418,7 @@ impl<'a> EncodingVideoProfileBuilder<'a> {
|
||||||
|
|
||||||
pub struct EncodingContainerProfileBuilder<'a> {
|
pub struct EncodingContainerProfileBuilder<'a> {
|
||||||
base: EncodingProfileBuilderCommonData<'a>,
|
base: EncodingProfileBuilderCommonData<'a>,
|
||||||
/*
|
profiles: Vec<EncodingProfile>,
|
||||||
* Not proud of this.
|
|
||||||
* Couldn't figure out how to store a IsA<EncodingProfile> to be used
|
|
||||||
* only when building the final profile object. So I'm using a real
|
|
||||||
* EncodingContainerProfile object just as a means to store it under
|
|
||||||
* the ffi APIs. This preserves the public APIs of this builder as
|
|
||||||
* they should be at the end.
|
|
||||||
*/
|
|
||||||
helper_profile: EncodingContainerProfile,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
declare_encoding_profile_builder_common!(EncodingContainerProfileBuilder);
|
declare_encoding_profile_builder_common!(EncodingContainerProfileBuilder);
|
||||||
|
@ -436,12 +427,7 @@ impl<'a> EncodingContainerProfileBuilder<'a> {
|
||||||
pub fn new() -> Self {
|
pub fn new() -> Self {
|
||||||
EncodingContainerProfileBuilder {
|
EncodingContainerProfileBuilder {
|
||||||
base: EncodingProfileBuilderCommonData::new(),
|
base: EncodingProfileBuilderCommonData::new(),
|
||||||
helper_profile: EncodingContainerProfile::new(
|
profiles: Vec::new(),
|
||||||
"helper",
|
|
||||||
None,
|
|
||||||
&gst::Caps::new_any(),
|
|
||||||
None,
|
|
||||||
),
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -457,7 +443,7 @@ impl<'a> EncodingContainerProfileBuilder<'a> {
|
||||||
self.base.preset,
|
self.base.preset,
|
||||||
);
|
);
|
||||||
|
|
||||||
for profile in self.helper_profile.get_profiles() {
|
for profile in self.profiles {
|
||||||
container_profile
|
container_profile
|
||||||
.add_profile(&profile)
|
.add_profile(&profile)
|
||||||
.or_else(|_error| Err(EncodingProfileBuilderError))?;
|
.or_else(|_error| Err(EncodingProfileBuilderError))?;
|
||||||
|
@ -467,8 +453,10 @@ impl<'a> EncodingContainerProfileBuilder<'a> {
|
||||||
Ok(container_profile)
|
Ok(container_profile)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn add_profile<P: IsA<EncodingProfile>>(self, profile: &P) -> Self {
|
pub fn add_profile<P: IsA<EncodingProfile>>(mut self, profile: &P) -> Self {
|
||||||
self.helper_profile.add_profile(profile).unwrap();
|
unsafe {
|
||||||
|
self.profiles.push(from_glib_none(profile.to_glib_none().0));
|
||||||
|
}
|
||||||
self
|
self
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue