Skip to content

Commit

Permalink
Support max_width/max_height options.
Browse files Browse the repository at this point in the history
  • Loading branch information
tdaede committed Sep 1, 2021
1 parent a6240d6 commit 202afe1
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 7 deletions.
2 changes: 1 addition & 1 deletion src/api/config/encoder.rs
Original file line number Diff line number Diff line change
Expand Up @@ -221,7 +221,7 @@ impl EncoderConfig {
// has the property that the scaled distortion of a 2Nx2N block is always
// equal to the sum of the scaled distortions of the NxN sub-blocks it's
// made of, this is a necessary property to be able to do RDO between
// multiple partition sizes properly. Unfortunately, when tx domains
// multiple partition sizes properly. Unfortunately, when tx domain
// distortion is used, distortion is only known at the tx block level which
// might be bigger than 8x8. So temporal RDO is always disabled in that case.
!self.speed_settings.tx_domain_distortion
Expand Down
30 changes: 24 additions & 6 deletions src/api/config/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -32,11 +32,21 @@ pub use crate::tiling::TilingInfo;
#[non_exhaustive]
pub enum InvalidConfig {
/// The width is invalid.
#[error("invalid width {0} (expected >= 16, <= 65535)")]
InvalidWidth(usize),
#[error("invalid width {0} (expected >= 16, <= {max})")]
InvalidWidth {
/// The actual value.
actual: usize,
/// The maximal supported value.
max: usize,
},
/// The height is invalid.
#[error("invalid height {0} (expected >= 16, <= 65535)")]
InvalidHeight(usize),
#[error("invalid height {0} (expected >= 16, <= {max})")]
InvalidHeight {
/// The actual value.
actual: usize,
/// The maximal supported value.
max: usize,
},
/// Aspect ratio numerator is invalid.
#[error("invalid aspect ratio numerator {0} (expected > 0)")]
InvalidAspectRatioNum(usize),
Expand Down Expand Up @@ -285,14 +295,22 @@ impl Config {
if (config.still_picture && config.width < 1)
|| (!config.still_picture && config.width < 16)
|| config.width > u16::max_value() as usize
|| (config.max_width != 0 && config.width > config.max_width)
{
return Err(InvalidWidth(config.width));
return Err(InvalidWidth {
actual: config.width,
max: if config.max_width != 0 { config.max_width } else { u16::max_value() as usize },
});
}
if (config.still_picture && config.height < 1)
|| (!config.still_picture && config.height < 16)
|| config.height > u16::max_value() as usize
|| (config.max_height != 0 && config.height > config.max_height)
{
return Err(InvalidHeight(config.height));
return Err(InvalidHeight {
actual: config.height,
max: if config.max_height != 0 { config.max_height } else { u16::max_value() as usize },
});
}

if config.sample_aspect_ratio.num == 0 {
Expand Down

0 comments on commit 202afe1

Please sign in to comment.