rsc3/doc-schelp/HelpSource/Reference/Scope.scrbl

59 lines
1.9 KiB
Text
Raw Permalink Normal View History

2022-08-24 13:53:18 +00:00
#lang scribble/manual
@(require (for-label racket))
@title{Scoping and Closure}
scoping of variables@section{categories}
Language
SuperCollider has nested scoping of variables. A function can refer not only to its own arguments and variables, but also to those declared in any enclosing (defining) contexts.
For example, the function defined below within makeCounter can access all of the arguments and variables declared in
@racketblock[makeCounter::.
Other code can call the returned function at some later time and it can access and update the values contained in ]
@racketblock[makeCounter:: at the time when the inner function was instantiated.
]
@racketblock[
(
var makeCounter;
makeCounter = { arg curVal=0, stepVal=1;
// return a function :
{
var temp;
// temp is local to this function, curVal & stepVal in the
// enclosing function are referred to here within.
temp = curVal;
curVal = curVal + stepVal;
temp // return result
}
};
// Each invocation of makeCounter creates a new set of variables curVal and stepVal:
x = makeCounter.value(10, 1);
z = makeCounter.value(99, 100);
)
::
x and z are functions which refer to different instances of the variables curVal and stepVal
]
@racketblock[
x.value.postln; // posts 10
x.value.postln; // posts 11
z.value.postln; // posts 99
z.value.postln; // posts 199
x.value.postln; // posts 12
x.value.postln; // posts 13
z.value.postln; // posts 299
z.value.postln; // posts 399
::
Note that even though the function which defines curVal and stepVal has completed execution, its variables are still accessible to those functions that were defined within its context.
This is known as lexical closure, the capturing and availability of variables defined in outer contexts by inner contexts even when the outer contexts may have completed execution.
]