mirror of
https://github.com/dredozubov/polyrhythmix.git
synced 2024-11-22 11:57:43 +00:00
Add a test for recursive note groups
This commit is contained in:
parent
1582b47194
commit
58bb2ba87c
1 changed files with 33 additions and 9 deletions
|
@ -419,7 +419,7 @@ fn test_known_length_groups() {
|
||||||
length: SIXTEENTH.clone(),
|
length: SIXTEENTH.clone(),
|
||||||
times: Times(1),
|
times: Times(1),
|
||||||
}]);
|
}]);
|
||||||
assert_eq!(groups.to_128th(), 96);
|
assert_eq!(groups.to_128th(), 64);
|
||||||
}
|
}
|
||||||
|
|
||||||
fn hit(input: &str) -> IResult<&str, Note> {
|
fn hit(input: &str) -> IResult<&str, Note> {
|
||||||
|
@ -488,7 +488,7 @@ fn times(input: &str) -> IResult<&str, Times> {
|
||||||
|
|
||||||
fn group(input: &str) -> IResult<&str, Group<GroupOrNote>> {
|
fn group(input: &str) -> IResult<&str, Group<GroupOrNote>> {
|
||||||
let repeated = map(
|
let repeated = map(
|
||||||
tuple((times, char(','), length, many1(note)),
|
tuple((times, char(','), length, many1(note))),
|
||||||
|(t, _, l, n)| (t, l, n),
|
|(t, _, l, n)| (t, l, n),
|
||||||
);
|
);
|
||||||
let single = map(tuple((length, many1(note))), |(l, vn)| (Times(1), l, vn));
|
let single = map(tuple((length, many1(note))), |(l, vn)| (Times(1), l, vn));
|
||||||
|
@ -523,21 +523,32 @@ pub fn flatten_group(input: Group<GroupOrNote>) -> Groups {
|
||||||
let mut out_groups = Vec::new();
|
let mut out_groups = Vec::new();
|
||||||
input.notes.iter().for_each(|g| match g {
|
input.notes.iter().for_each(|g| match g {
|
||||||
SingleGroup(group) => {
|
SingleGroup(group) => {
|
||||||
let isolated_group = Group { notes: note_group.clone(), length: input.length, times: Times(1) };
|
let isolated_group = Group {
|
||||||
|
notes: note_group.clone(),
|
||||||
|
length: input.length,
|
||||||
|
times: Times(1),
|
||||||
|
};
|
||||||
out_groups.push(isolated_group);
|
out_groups.push(isolated_group);
|
||||||
note_group.clear();
|
note_group.clear();
|
||||||
out_groups.extend(flatten_group(group.clone()).0);
|
out_groups.extend(flatten_group(group.clone()).0);
|
||||||
},
|
}
|
||||||
SingleNote(note) => {
|
SingleNote(note) => {
|
||||||
note_group.push(*note);
|
note_group.push(*note);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
Groups(out_groups.iter().cloned().cycle().take(out_groups.len() * (input.times.0 as usize)).collect())
|
Groups(
|
||||||
|
out_groups
|
||||||
|
.iter()
|
||||||
|
.cloned()
|
||||||
|
.cycle()
|
||||||
|
.take(out_groups.len() * (input.times.0 as usize))
|
||||||
|
.collect(),
|
||||||
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn flatten_groups<I>(input_groups: I) -> Groups
|
pub fn flatten_groups<I>(input_groups: I) -> Groups
|
||||||
where
|
where
|
||||||
I: IntoIterator<Item = Group<GroupOrNote>>
|
I: IntoIterator<Item = Group<GroupOrNote>>,
|
||||||
{
|
{
|
||||||
let mut out = Vec::new();
|
let mut out = Vec::new();
|
||||||
input_groups.into_iter().for_each(|g| {
|
input_groups.into_iter().for_each(|g| {
|
||||||
|
@ -564,13 +575,13 @@ fn test_flatten_group() {
|
||||||
Group {
|
Group {
|
||||||
notes: vec![Hit],
|
notes: vec![Hit],
|
||||||
length: *SIXTEENTH,
|
length: *SIXTEENTH,
|
||||||
times: Times(1)
|
times: Times(1),
|
||||||
},
|
},
|
||||||
Group {
|
Group {
|
||||||
notes: vec![Rest, Hit],
|
notes: vec![Rest, Hit],
|
||||||
length: *EIGHTH,
|
length: *EIGHTH,
|
||||||
times: Times(3)
|
times: Times(3),
|
||||||
}
|
},
|
||||||
]);
|
]);
|
||||||
assert_eq!(flatten_group(group("(2,16x(3,8-x))").unwrap().1), out);
|
assert_eq!(flatten_group(group("(2,16x(3,8-x))").unwrap().1), out);
|
||||||
}
|
}
|
||||||
|
@ -623,6 +634,19 @@ fn parse_groups() {
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn parse_group() {
|
fn parse_group() {
|
||||||
|
let expectation = Group {
|
||||||
|
times: *TWICE,
|
||||||
|
notes: vec![
|
||||||
|
SingleNote(Hit),
|
||||||
|
SingleGroup(Group {
|
||||||
|
times: *ONCE,
|
||||||
|
notes: vec![],
|
||||||
|
length: *EIGHTH
|
||||||
|
})
|
||||||
|
],
|
||||||
|
length: *SIXTEENTH
|
||||||
|
};
|
||||||
|
assert_eq!(group("(2,16x(8-x))"), Ok(("", expectation)));
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
group("16x--x-"),
|
group("16x--x-"),
|
||||||
Ok((
|
Ok((
|
||||||
|
|
Loading…
Reference in a new issue