summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCorey Richardson <corey@octayn.net>2017-09-24 08:59:43 -0400
committerGraham Northup <grahamnorthup@yahoo.com>2017-09-24 19:01:22 -0400
commit5f1e73ab5bd0709dd408064c06f2717182777537 (patch)
treebc66a94450cc3ab7312f73df404463d44f1c1290
parentf4c1ee3bbd1d548ce9c0c4cf15e9bd867adca421 (diff)
Clean up some sub-optimal slice handling
Clippy noticed that update_from looked like a manual copy_from_slice, which alerted me to sum_into and mul_into also being suboptimal. With the new changes, the generated code is much cleaner: it lacks an extra "unnecessary" branch and is about 30% shorter (for those methods). I also think the code is a bit easier to read :)
-rw-r--r--src/synth/mod.rs45
1 files changed, 24 insertions, 21 deletions
diff --git a/src/synth/mod.rs b/src/synth/mod.rs
index 6ec55f1..fb9714b 100644
--- a/src/synth/mod.rs
+++ b/src/synth/mod.rs
@@ -80,9 +80,8 @@ impl SampleBuffer {
self.rate = other.rate;
match self.rate {
Rate::Sample => {
- for i in 0..cmp::min(self.len(), other.len()) {
- self.samples[i] = other.samples[i];
- }
+ let len = cmp::min(self.len(), other.len());
+ self.samples[..len].clone_from_slice(&other.samples[..len]);
},
Rate::Control => {
self.samples[0] = other.samples[0];
@@ -93,16 +92,18 @@ impl SampleBuffer {
pub fn sum_into(&mut self, other: &SampleBuffer) {
match self.rate {
Rate::Sample => {
- let bound = match other.rate {
- Rate::Sample => cmp::min(self.len(), other.len()),
- Rate::Control => self.len(),
+ match other.rate {
+ Rate::Sample => {
+ for (elt, oelt) in self.samples.iter_mut().zip(other.samples.iter()) {
+ *elt += *oelt;
+ }
+ }
+ Rate::Control => {
+ for elt in &mut self.samples {
+ *elt += other.samples[0];
+ }
+ }
};
- for i in 0..bound {
- self.samples[i] += match other.rate {
- Rate::Sample => other.samples[i],
- Rate::Control => other.samples[0],
- };
- }
},
Rate::Control => {
self.samples[0] += other.samples[0];
@@ -113,16 +114,18 @@ impl SampleBuffer {
pub fn mul_into(&mut self, other: &SampleBuffer) {
match self.rate {
Rate::Sample => {
- let bound = match other.rate {
- Rate::Sample => cmp::min(self.len(), other.len()),
- Rate::Control => self.len(),
+ match other.rate {
+ Rate::Sample => {
+ for (elt, oelt) in self.samples.iter_mut().zip(other.samples.iter()) {
+ *elt *= *oelt;
+ }
+ }
+ Rate::Control => {
+ for elt in &mut self.samples {
+ *elt *= other.samples[0];
+ }
+ }
};
- for i in 0..bound {
- self.samples[i] *= match other.rate {
- Rate::Sample => other.samples[i],
- Rate::Control => other.samples[0],
- };
- }
},
Rate::Control => {
self.samples[0] *= other.samples[0];