File: News-3_9.schelp

package info (click to toggle)
supercollider 1%3A3.13.0%2Brepack-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 80,292 kB
  • sloc: cpp: 476,363; lisp: 84,680; ansic: 77,685; sh: 25,509; python: 7,909; makefile: 3,440; perl: 1,964; javascript: 974; xml: 826; java: 677; yacc: 314; lex: 175; objc: 152; ruby: 136
file content (372 lines) | stat: -rw-r--r-- 20,519 bytes parent folder | download | duplicates (5)
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
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
title:: News in 3.9
summary:: A summary of news in SC 3.9
categories:: News
related::Guides/News-3_8, Guides/News-3_7

We are proud to announce the arrival of SuperCollider 3.9.0! Apologies
for being so far behind schedule; we hope the improvements you'll find here
will more than make up for it. In 3.9.0, determined contributors have fixed
some of SuperCollider's major cross-platform compatibility demons, addressed
longstanding issues in the IDE and language, and added new features and bugfixes
across the board.

Many thanks to all who contributed to this release: adcxyz, awson, bagong,
brianlheim, cappelnord, carlocapocasa, crucialfelix, danstowell, defaultxr,
dyfer, elifieldsteel, gagnonlg, ghost, gusano, jamshark70, jd-m, jleben,
jmckernon, joshpar, jreus, LFSaw, llloret, LucaDanieli, Magicking,
miguel-negrao, muellmusik, patrickdupuis, porres, privong, redFrik, samaaron,
scztt, simdax, smoge, smrg-lm, snappizz, telephon, thormagnusson,
tiagomoraismorgado88, timsutton, vivid-synth, vividsnow, yurivict, and many
more in the SC community who helped in ways other than participation on GitHub.

section:: Known Issues

The IDE server status display turns yellow after a few seconds when opening code:: s.makeGui ::.  This does not cause any usability issues.

Only the first pages of the HTML files produced by SCDoc are printed in web browsers.

The help browser does not remember the last position open in a document when navigating through history, and just jumps to the top of the file.

Supernova loads plugins from "Extensions/plugins" rather than "Extensions".

code:: LevelIndicator.style() :: is broken, which leads to confusing warning messages.

code:: File.copy :: crashes the interpreter if the destination file exists.

On Windows, SerialPort is not available.

On Windows, Supernova is not available.

On Windows, the command-line sclang interpreter is not available.

section:: General: Added

scvim has seen numerous enhancements now that an actively maintained fork has been merged in.

SuperCollider can now be built on Windows using the MSYS2 toolchain, thanks in particular to @awson and @bagong.

SuperCollider can now be built on FreeBSD, thanks to @shamazmazum and @yurivict.

Detailed documentation on creating macOS standalone applications with SuperCollider has been added, thanks to @adcxyz.

Support for multiple sclang clients connecting to the same server is greatly improved, thanks to @adcxyz.

A CODE_OF_CONDUCT.md and CONTRIBUTING.md have been added to the repository.

Higher-resolution raster versions of the SC cube logo have been added to the top-level code:: icons/ :: directory, and a retina-friendly code:: .icns :: file.

section:: General: Changed

strong:: Breaking change: :: code:: sc_gcd :: in the plugin interface now conforms to code:: gcd(n, 0) == n :: instead of code:: gcd(n, 0) == abs(n) ::. This also affects the method code:: SimpleNumber:gcd ::.

The macOS plist file now shows the full version number for both the Version String and Shortened Version String.

section:: General: Fixed

A typo in the build system prevented the code:: -msse :: compiler flag from being properly set for gcc and clang. This *may* fix subnormal number issues in scsynth that some users have been experiencing.

Fixed a fontification break in scel when too many classes are defined.

Fixed build failures on FreeBSD, GCC 7, and newer versions of Boost.


section:: scsynth and supernova: Added

scsynth and supernova now support a code:: /version :: command, which responds with a message of the form code:: /version.reply program major minor patch branch commit ::. See the Server Command Reference for full details.

section:: scsynth and supernova: Changed

On macOS, if scsynth's input and output devices have mismatched sample rates, an error is thrown and the server does not boot. Setting the number of input channels to 0 (code:: -i 0 :: on the command line and code:: s.options.numInputBusChannels = 0 :: in sclang) now bypasses this error.

Disabled Nagle's algorithm for TCP communication in scsynth. Nagle's algorithm increases bandwidth at the cost of delay, which is undesirable in the context of SuperCollider. Both supernova and sclang have it turned off.

section:: scsynth and supernova: Fixed

The code:: /b_read :: and code:: /b_readChannel :: messages experienced intermittent failures to read sound files, most notably affecting code:: Buffer.cueSoundFile ::. This has been fixed.


section:: UGens: Added

A new UGen, code:: Sanitize ::, replaces infinities, NaNs, and subnormals with another signal, zero by default.

The code:: doneAction :: argument to DetectSilence can now be modulated.

UnaryOpUGen now supports the bitwise not operator code:: bitNot ::. It used to simply fail silently.

section:: UGens: Changed

strong:: Breaking change: :: The application binary interface (ABI) for server plugins has changed. This has an important impact: strong:: plugin binaries compiled for SuperCollider 3.8 will not work with SuperCollider 3.9 :: and vice versa. Please recompile your plugins.

strong:: Breaking change: :: code:: FOS.ar :: with control-rate coefficient inputs incorrectly initialized its coefficients at 0 and ramped to the correct values over the first control period. This has been fixed. To restore old behavior, multiply each coefficient by code:: Line.ar(0, 1, ControlDur.ir) ::.

section:: UGens: Deprecated

code:: Donce ::, a demand-rate UGen with no identifiable purpose, is deprecated. It was most likely used in the production of electronic donce music.

section:: UGens: Fixed

A number of UGens were discovered to have serious initialization bugs where the UGen would output an initial sample of garbage memory. This can create audio explosions if the buggy UGen's output is fed into certain filter UGens like LPF or Delay1. These bugs have been fixed, affecting BeatTrack, BeatTrack2, CoinGate, Convolution, Convolution2, Convolution2L, Convolution3, DetectSilence, DiskIn, DiskOut, IFFT, KeyTrack, LFGauss, PartConv, PV_JensenAndersen, PV_HainsworthFoote, RunningSum, StereoConvolution2L, and Unpack1FFT.

Fixed a bug with code:: TGrains :: ignoring the code:: amp :: parameter.

code:: Dibrown :: no longer ignores the code:: length :: argument.

code:: Pitch :: no longer ignores the code:: median :: argument.

Fixed a build error in DiskIOUGens on Windows.

Fixed code:: AudioControl :: outputting garbage data if a bus is mapped to it but nothing is playing to the bus.

Fixed incorrect math in code:: PanAz.ar :: with audio-rate input signal and position.


section:: sclang: Added

Regression tests for the sclang lexer, parser, and compiler have been added. This will make it easier to make fixes to these components in the future.

section:: sclang: Changed

strong:: Breaking change: :: sclang's nestable multiline comments had some mistakes. In particular, sometimes sclang's lexer would incorrectly process overlapping combinations of code:: /* :: and code:: */ ::, so e.g. code:: */*/ :: would be interpreted like code:: */ /* */ ::. This has been fixed.

The maximum number of MIDI ports has been increased from 16 to 128.

The startup post "NumPrimitives = #" is reworded to "Found # primitives".

section:: sclang: Removed

Removed some unhelpful memory addresses from call stack output in error printing.

Removed some accidentally retained debug posts when the language starts up.

section:: sclang: Fixed

Fixed help files failing to open on Windows if the user's name contains a non-ASCII character.

Fixed non-ASCII characters breaking the Visual Studio debugger.

Fixed a crash in code:: Object:perform :: when the selector is an Array whose first element is not a Symbol, e.g. code:: 0.perform([0]) ::.

code:: thisProcess.nowExecutingPath :: is no longer corrupted by code:: Routine:stop ::.

code:: TextView:selectedString_ :: now works when the selection size is zero.

Fixed a crash when a method or class/instance variable is named "code:: none ::".

Exceptions occurring in primitives no longer print unavoidable error messages even when wrapped in try-catch.

Fixed a crash when code:: Dictionary:keysValuesArrayDo :: is called with code:: nil :: as an argument.

Fixed code:: WebView:onLinkActivated :: handler failing to fire.

Fixed GUI objects failing to display when launched from the code:: action :: of code:: unixCmd ::. You will still need code:: { }.defer ::, however.

Fixed code:: QImage:getColor :: always returning zero for the green channel.


section:: Class library: Added

The UnitTest quark has been incorporated into the main repository.

Added a code:: rewind :: method to code:: CollStream ::.

Added four new class methods to code:: File :: for convenience: code:: readAllString ::, code:: readAllSignal ::, code:: readAllStringHTML ::, code:: readAllStringRTF ::.

code:: Pstep :: accepts an array as a duration argument.

Help files originating from extensions now display a plaque for visibility.

For consistency with other code:: Platform :: class methods, code:: Platform.recordingsDir :: may be used instead of code:: thisProcess.platform.recordingsDir ::.

code:: SequenceableCollection :: has two new instance methods: code:: flatten2 :: and code:: flatBelow ::. Additionally, code:: flatten :: is faster now.

The code:: ~callback :: function is now available for all code:: Event :: types instead of just "on" events.

Event types now include a code:: parentEvent ::, which provides default values..

New aliases for done actions, e.g. code:: Done.freeSelf == 2 ::, are introduced for better readability. See the code:: Done :: helpfile for details.

A new class, code:: Recorder ::, allows recording independently of the code:: Server :: object.

code:: SequenceableCollection:reduce :: supports an adverb argument.

A code:: recordingsDir :: method has been added directly to code:: Platform ::, which transparently calls code:: thisProcess.platform.recordingsDir ::.

code:: View:-resizeToBounds ::, code:: View:-resizeToHint ::, and code:: Window:-resizeToHint :: were added to make it easier to force Views and Windows to automatically resize.

code:: Maybe :: now supports collection methods code:: at ::, code:: atAll ::, code:: put ::, code:: putAll ::, code:: add ::, code:: addAll ::.

code:: BusPlug:-play :: can now accept a code:: Bus :: object.

Breadcrumb links in helpfiles now have separate links for each node in the hierarchy, and pages with multiple categories have separators between the categories.

code:: SoundFile:*openWrite :: now takes additional parameters.

Two new instance methods were added to Symbol: code:: isBinaryOp :: and code:: isIdentifier ::.

Added three convenience methods: code:: View:resizeToBounds ::, code:: View:resizeToHint ::, and code:: Window:resizeToHint ::.

Added code:: Collection:asEvent :: for easy conversion to an code:: Event ::.

code:: DeprecatedError :: now shows you the file path of the deprecated method.

Added two new methods to code:: SimpleNumber ::: code:: snap :: and code:: softRound ::.

code:: ReadableNodeIDAllocator :: offers a new optional replacement for code:: PowerOfTwoAllocator :: that assigns node IDs in a way more readable to humans when working with multiclient setups.

A new "booted" stage has been added to Server objects that have been booted but
may not be running yet, accessible via code:: Server:hasBooted :: and
code:: Server.allBootedServers ::.

section:: Class library: Changed

strong:: Breaking change: :: Rests in the patterns system have been restructured. Instead of using the code:: isRest :: event property, events are considered rests if one of their properties is a code:: Rest :: object. You must use instances of code:: Rest :: rather than the rest class itself -- use of code:: Rest :: instead of code:: Rest() :: is now deprecated.

strong:: Breaking change: :: Fixed code:: Dictionary:== :: only comparing the values of the two dictionaries, not the keys.

strong:: Breaking change: :: Fixed a mistake where code:: Pen.quadCurveTo :: used the primitive for a cubic Bézier instead of quadratic. To restore the old behavior, change code:: Pen.quadCurveTo :: to code:: Pen.curveTo ::.

strong:: Breaking change: :: The convenience instance methods code:: Env:kr :: and code:: Env:ar :: had the arguments code:: mul :: and code:: add :: renamed to code:: levelScale :: and code:: levelBias ::, since they don't behave like typical code:: mul :: and code:: add :: arguments.

code:: Collection:processRest :: returns the processed collection rather than the original.

The maximum number of MIDI ports has been increased.

Attempting to use a control-rate signal as an input to code:: Hasher.ar :: now results in an error.

The "Cleaning up temp synthdefs..." post message is suppressed if there is nothing to clean up.

To match code:: Out :: and code:: ReplaceOut ::, code:: LocalOut :: and code:: XOut :: now correctly validate their input, checking for a non-zero number of channels.

The argument to code:: Pattern:fin :: has a default of 1 for consistency with code:: Object:fin ::.

code:: Complex:reciprocal :: is faster now.

code:: Buffer:write :: takes floating point arguments, truncating them to integers.

Conversion methods among collection types has been improved and documented.

code:: clientID :: is now protected from being changed while the server is running.

section:: Class library: Deprecated

code:: OSCresponder ::, code:: OSCresponderNode ::, and code:: OSCpathResponder :: now emit deprecation messages, and will be removed after at least a year. Use code:: OSCFunc :: or code:: OSCdef :: instead.

code:: Speech :: is deprecated, and will be removed in 3.10. The rationale is that its audio output is independent of the server (severely limiting use in compositions), it depends on a proprietary macOS API with no prospect of cross-platform compatibility, and it is too niche to justify inclusion in the core library.

The WiiMote classes (code:: WiiMote ::, code:: WiiMoteIRObject ::, code:: WiiCalibrationInfo ::, code:: WiiMoteGUI ::, code:: WiiRemoteGUI ::, code:: WiiNunchukGUI ::) are deprecated. They never reached a stable state and have gone unmaintained and unused for years.

code:: AudioIn :: is deprecated and will be removed in some future version. It was provided only for backward compatibility with SC2, so its deprecation is long overdue. Use code:: SoundIn :: instead.

code:: SplayZ :: has been deprecated for a long time, but it's finally on the "official" deprecation track and will be removed in 3.10. Use code:: SplayAz :: instead.

code:: TDuty_old :: has been deprecated for a long time, but it now emits a warning and will be removed in 3.10. Use code:: TDuty :: instead.

code:: Watcher :: is an old alias for code:: SkipJack :: provided for backward compatibility. It is officially deprecated and will be removed in 3.10.

code:: Server:recordNode :: is deprecated. Use code:: Recorder:recordNode :: instead (e.g. code:: s.recorder.recordNode ::).

The code:: Server.set :: class variable is deprecated. Use code:: Server.all :: instead.

code:: SimpleNumber:quantize :: is deprecated. Use code:: SimpleNumber:snap :: instead.

code:: Server:userSpecifiedClientID :: is deprecated. Use code:: Server:clientID :: instead.

section:: Class library: Removed

Removed non-functional stub methods and classes related to Image: the classes ImageFilter and ImageKernel, and the Image instance methods lockFocus, unlockFocus, applyFilters, filters, filteredWith, addFilter, removeFilter, flatten, invert, crop, applyKernel.

code:: Module ::, an unmaintained and unused class for serialization of Synths, has been moved to a quark.

Removed the code:: openHelpFile :: instance methods of code:: Object ::, code:: String ::, code:: Method ::, and code:: Quark ::. These methods have been deprecated since 3.8.

Removed code:: String:openTextFile :: and code:: Symbol:openTextFile ::. Use code:: String:openDocument :: and code:: Symbol:openTextFile :: instead. These methods have been deprecated since 3.8.

section:: Class library: Fixed

A number of instance methods in code:: Buffer :: and code:: Bus :: did not properly check to see if the object has already been freed, and would act on buffer #0 or bus #0 (which is especially dangerous for the code:: free :: instance method). They now safeguard against this case and throw errors.

The code:: useRanger :: option in code:: EnvirGui :: broke in 3.7. This has been fixed.

code:: IdentityDictionary :: methods code:: collect ::, code:: select ::, and code:: reject :: retain references to the code:: parent :: and code:: proto :: objects.

On Linux, some MIDI methods created method override warnings. These have been silenced.

The "key" argument to code:: Pn :: was not properly set on the first repeat. This has been fixed.

Fixed errors when using a DragSource inside a CompositeView object.

Fixed an interpreter crash when defining a SynthDef whose name is too long. More specifically, the inputs to code:: UnixFILE:putPascalString :: and code:: CollStream:putPascalString :: are now validated.

Server crashes are better handled by the interpreter.

The time display and the "start recording", "pause recording", and "stop recording" menu items now cooperate better with running code:: Server:record ::, code:: Server:pauseRecording ::, and code:: Server:stopRecording ::.

code:: Server:makeGui :: and code:: Server:makeWindow :: broke in 3.8 — the fields in the windows went blank. They are working again.

A timing error with code:: NodeProxy:-clear :: was fixed.

code:: SoundFileView :: correctly displays its grid and does not draw the grid on top of the selection box.

The macOS plist file now shows the full version number for both the Version String and Shortened Version String.

Fixed instances of accidentally silencing error messages caused by neglecting to call code:: Object:primitiveFailed ::.

Patched the possibility of inconsistent code:: TempoClock :: state when the tempo is set via code:: setTempoAtSec ::.

Fixed memory spikes when using code:: MIDIFunc.sysex :: with a large code:: srcID ::.

Fixed spaces sometimes being rendered as code:: %20 :: in links in SCDoc.

Fixed code:: Function:plot :: showing an empty graph if the server wasn't booted when the method was invoked.

Fixed blatant errors in code:: Collection:asAssociations :: and code:: Collection:asPairs :: where elements were dropped.

Fixed bugs in code:: NodeProxy :: when using external servers.

code:: History :: now outputs a correct timestamp on Windows.

Fixed Volume control failing to be persistent when rebooting the server.

Fixed code:: SimpleNumber:asTimeString :: producing nonsensical results with the "precision" argument.

code:: Server:clientID :: can now be changed, allowing multiple clients connect to the same server.

History and HistoryGui have been cleaned up.

Fixed duplicate node IDs involving code:: Server.initTree ::.

Fixed supernova crashing when too many controls are used.

code:: Volume :: now respects lag time when it is instantiated or destroyed.

section:: IDE & SCDoc: Added

Entries in the Documents docklet can be reordered, and document tabs will automatically reorder to reflect this.

"Edit > Preferences > Editor > Display" has a new option that allows replacing tabs with a dropdown whose items are alphabetically ordered. This makes navigation easier in some performance contexts.

section:: IDE & SCDoc: Changed

Server actions, which were previously in the "Language" menu, have been moved out to their own "Server" menu.

Changed "occurrences" to "matches" in the status bar in the Find and Replace features.

Many minor improvements were made to the look and feel of the documentation.

section:: IDE & SCDoc: Fixed

Fixed SCDoc refusing to index any further documents if one document has a malformed code:: copymethod :: command.

Some Linux systems had unreadable font colors in the autocomplete tooltips. This has been (finally) fixed.

Fixed a bug where code:: Document:selectedString_ :: had no effect.

New tabs are now inserted to the right of the current tab instead of all the way at the end.

The help browser now has keyboard shortcuts for navigating back and forward. These shortcuts are OS-dependent and given to us by Qt.

Fixed the "Find in page..." feature in the help viewer skipping every other occurrence.

Fixed HTML checkboxes appearing in the upper left of the help viewer.

Fixed the right-click menu for the tabs appearing in the wrong place in macOS.