/usr/share/SuperCollider/HelpSource/Classes/Rest.schelp is in supercollider-common 1:3.6.3~repack-5.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 | CLASS:: Rest
summary:: Represents a rest in event patterns
categories:: Streams-Patterns-Events
related:: Classes/Pbind, Classes/Event
DESCRIPTION::
Rest may be used in event patterns to indicate that the resulting event should be a rest (i.e., silent). It should be used in one of the child patterns belonging to a Pbind, for instance.
subsection:: Expressing rests in event patterns
In addition to the Rest class, rests can be specified in two other ways (legacy usages).
list::
## A link::Classes/Symbol:: may be specified in any frequency stream (under the keys degree, note, midinote or freq). The exception to this rule is control bus mapping symbols, beginning with 'c' followed by a number. Typical symbols that have been used include strong::\rest::, strong::\r:: and the empty symbol strong:: \ ::.
code::
p = Pbind(
\degree, Pseq([
0, 1, 2, 0, 0, 1, 2, 0,
2, 3, 4, \rest, 2, 3, 4, \rest
]),
\dur, 0.25
).play;
::
## The event's strong::\type:: may be set to strong::\rest::.
code::
p = Pbind(
\degree, Pseries(0, 1, inf).fold(-7, 7),
\dur, 0.125,
\type, Pwrand([\note, \rest], [0.9, 0.1], inf)
).play;
p.stop;
::
::
The Rest class allows rests to be indicated in any stream, not only frequency or event type. Also, using the duration argument (see the *new method below), rests may be embedded into a duration stream. That is, rests may be treated as part of the rhythmic specification, rather than the pitch specification.
subsection:: Usage
list::
## The class Rest may be embedded directly in a child pattern. This sets the isRest flag and puts the number 1 into the event.
## Or, a Rest instance may be embedded. Rest.new's argument specifies the value that will be placed into the event. This allows rests to be given in a duration stream -- the argument is the rest's rhythmic value.
::
section:: How it works
When a Pbind child pattern returns a Rest, the Rest object sets a flag 'isRest' in the resulting event to be true. The child pattern's value in the event is a number. This is to prevent math errors if Rest is used in a pitch or duration stream (degree, note, midiNote, freq, dur, delta, stretch).
When a Rest is returned from a child stream, the rest object itself will not appear in the event. You can tell that the event is a rest by the presence of code::'isRest': true::.
code::
p = Pbind(\degree, Pseq([4, Rest], 1)).asStream;
p.next(());
// prints: ( 'degree': 4 )
p.next(());
// prints: ( 'isRest': true, 'degree': 1 )
::
That is, the importance of the Rest object is not that it appears in the event. The importance is the side effect that this object has on the resulting event.
CLASSMETHODS::
All methods of Rest except *new are private, and should not be used directly.
private:: processRest
private:: embedInStream
private:: asStream
METHOD:: new
Create an instance of Rest, with a value to be used in the resulting rest event.
argument:: dur
Typically, Rest instances will be used in duration streams, so the argument should be the rest's rhythmic value, or duration. Rest instances may also be used in any other stream, but the value will be ignored (since the event will do nothing except take time).
INSTANCEMETHODS::
private:: dur
private:: processRest
private:: embedInStream
private:: asStream
EXAMPLES::
Using the Rest class in a pitch stream
code::
p = Pbind(
\degree, Pif(
0.1.loop.coin,
Rest,
Pseries(0, 1, inf).fold(-7, 7)
),
\dur, 0.125
).play;
p.stop;
::
Using a Rest instance in a duration stream
code::
p = Pbind(
\degree, Pseries(0, 1, inf).fold(-7, 7),
\dur, Pseq([Pn(0.125, { rrand(3, 6) }), Rest(0.25)], inf)
).play;
p.stop;
::
|