From 267f58b7be4c4399fd7a319baa9650a584fa3ed2 Mon Sep 17 00:00:00 2001 From: Alex McLean Date: Tue, 23 Apr 2024 14:14:30 +0100 Subject: [PATCH] Tactus tweaks - fixes for maintaining tactus and highlight locations (#1065) * outer bind/join should keep outer tactus * keep locations of outer pattern in stepJoin --- packages/core/pattern.mjs | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/packages/core/pattern.mjs b/packages/core/pattern.mjs index 8f2c4362e..439050d82 100644 --- a/packages/core/pattern.mjs +++ b/packages/core/pattern.mjs @@ -257,12 +257,12 @@ export class Pattern { } outerBind(func) { - return this.bindWhole((a) => a, func); + return this.bindWhole((a) => a, func).setTactus(this.tactus); } outerJoin() { // Flattens a pattern of patterns into a pattern, where wholes are - // taken from inner haps. + // taken from outer haps. return this.outerBind(id); } @@ -2429,7 +2429,10 @@ export function _slices(haps) { const breakpoints = flatten(haps.map((hap) => [hap.part.begin, hap.part.end])); const unique = uniqsortr([Fraction(0), Fraction(1), ...breakpoints]); const slicespans = pairs(unique); - return slicespans.map((s) => [s[1].sub(s[0]), stack(..._fitslice(new TimeSpan(...s), haps).map((x) => x.value))]); + return slicespans.map((s) => [ + s[1].sub(s[0]), + stack(..._fitslice(new TimeSpan(...s), haps).map((x) => x.value.withHap((h) => h.setContext(h.combineContext(x))))), + ]); } export function _fitslice(span, haps) {