|
@@ -372,19 +372,21 @@ impl PlayerInternal {
|
|
|
fn handle_packet(&mut self, packet: Option<VorbisPacket>, normalisation_factor: f32) {
|
|
|
match packet {
|
|
|
Some(mut packet) => {
|
|
|
- if let Some(ref editor) = self.audio_filter {
|
|
|
- editor.modify_stream(&mut packet.data_mut())
|
|
|
- };
|
|
|
-
|
|
|
- if self.config.normalisation && normalisation_factor != 1.0 {
|
|
|
- for x in packet.data_mut().iter_mut() {
|
|
|
- *x = (*x as f32 * normalisation_factor) as i16;
|
|
|
+ if packet.data().len() > 0 {
|
|
|
+ if let Some(ref editor) = self.audio_filter {
|
|
|
+ editor.modify_stream(&mut packet.data_mut())
|
|
|
+ };
|
|
|
+
|
|
|
+ if self.config.normalisation && normalisation_factor != 1.0 {
|
|
|
+ for x in packet.data_mut().iter_mut() {
|
|
|
+ *x = (*x as f32 * normalisation_factor) as i16;
|
|
|
+ }
|
|
|
}
|
|
|
- }
|
|
|
|
|
|
- if let Err(err) = self.sink.write(&packet.data()) {
|
|
|
- error!("Could not write audio: {}", err);
|
|
|
- self.stop_sink();
|
|
|
+ if let Err(err) = self.sink.write(&packet.data()) {
|
|
|
+ error!("Could not write audio: {}", err);
|
|
|
+ self.stop_sink();
|
|
|
+ }
|
|
|
}
|
|
|
}
|
|
|
|