File: Quant.sc

package info (click to toggle)
supercollider 1%3A3.10.0%2Brepack-1
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 45,496 kB
  • sloc: cpp: 283,513; lisp: 74,040; ansic: 72,252; sh: 23,016; python: 7,175; makefile: 1,087; perl: 766; java: 677; yacc: 314; lex: 175; ruby: 136; objc: 65; xml: 15
file content (34 lines) | stat: -rw-r--r-- 1,016 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
// This class is used to encapsulate quantization issues associated with EventStreamPlayer and TempoClock
// quant and phase determine the starting time of something scheduled by a TempoClock
// timingOffset is an additional timing factor that allows an EventStream to compute "ahead of time" enough to allow
// negative lags for strumming a chord, etc
Quant {
	classvar	default;
	var <>quant, <>phase, <>timingOffset;

	*default { ^default ?? { Quant.new } }
	*default_ { |quant| default = quant.asQuant }

	*new { |quant = 0, phase, timingOffset| ^super.newCopyArgs(quant, phase, timingOffset) }

	nextTimeOnGrid { | clock |
		^clock.nextTimeOnGrid(quant, (phase ? 0) - (timingOffset ? 0));
	}

	asQuant { ^this.copy }

	printOn { |stream|
		stream << "Quant(" << quant;
		if(phase.notNil) { stream << ", " << phase };
		if(timingOffset.notNil) {
			stream << ", ";
			if(phase.isNil) {
				stream << "nil, ";
			};
			stream << timingOffset
		};
		stream << ")"
	}

	storeArgs { ^[quant, phase, timingOffset] }
}