This section tracks changes in Pd's current implementation.
------------------ 0.46-7 ------------------------------
Fixed non-working declare -stdpath on windows
Fixed bug in which [array min/max] ignored onset argument
Fixed jack audio back-ed not to auto-start the daemon
Various compilation and architecture fixes
------------------ 0.46-6 ------------------------------
fixed bug selecting and saving/restoring MIDI output devices.
new bob~ object (Moog filter emulation) in extra. (This was intended for 0.47 but it was easiest to leave it in place for this bug-fix release).
------------------ 0.46-5 ------------------------------
fixed crasher bug (cutting all text in an object then cutting again to delete the object sometimes crashed Pd)
added two checks to re-sort DSP when arrays are created or renamed
patched Makefile.am for correct list of objects (fixes broken make install)
fixed configure.ac to useS fftw3
------------------ 0.46-4 ------------------------------
fixed crasher bug in 0.364-3
------------------ 0.46-3 ------------------------------
changed priority settings to agree with new restrictions on linux -- apparently non-root processes can't set to any of the top 5 or so priority levels.
three minor fixes for array graphics
new "set" messages and wildcard '-' template names for "set", "get", "elem", "setsize", "getsize", and "append" objects
updated Makefile.am to reflect new and corrected help file names
took out bogus object in rev3~
------------------ 0.46-2 ------------------------------
fixed bug calculating widths of pre-version-0.39 GOPs
added a pd_getdspstate() function to replace dspstate external variable which was moved to the pd instance structure. Strictly speaking this doesn't restore binary compatibility but I beleive only one extern writer was using dspstate (and he's actively maintaining the externs) so I think this is OK.
The old standard-error "realtime priority" debug message under linux only appears if Pd is strted 'verbose'. OTOH, if realtime priority-setting fails, the user is notified in the Pd window.
fixed debian compile bug.
fixed "array" object to allow a size of 1.
------------------ 0.46-1 ------------------------------
Bug fix in oscparse (truncated some messages)
Fixed ALSA (on linux) to open devices with fewer channels than requested
Other small bug fixes.
------------------ 0.46-0 ------------------------------
The biggest change in 0.46 was to make possible loading multiple Pd instances into a single address space. The instances share symbols (there are no namespaces) but have different schedulers, DSP netwoerks, and MIDI I/O structures. In principle it should be possible to design Pd plug-ins that don't interact with each other using libpd.
New oscparse and oscformat objects to facilitate OSC I/O. No support for streaming; UDP only so far.
At long last, Pd vanilla compiled for Macintosh computers is distributed with Jack support.
Bug fixes to IEM GUIs: sliders and radio buttons pass floating-point numbers through without limiting them to the GUI's range or resolution. Also, the toggle no longer resets its "value" (the nonzero number it outputs) when receiving numbers in messages. Set compatibility to 0.45 or earlier to get the old behavior (using "pd compatibility" message or a startup flag).
Audio and MIDI settings are now saved by device name, not number, so that, hopefully, adding or reordering devices doesn't change the devices Pd opens as saved in preferences. You can also specify them by name on Pd's command line with new flags such as "-audioadddev".
New [text tosymbol] and [text fromsymbol] to allow string manipulation.
Netsend/netreceive can send messages bidirectinally if using TCP protocol.
Added some startup flags (mostly from Iohannes) - -nostderr, etc. Also added a flag (-noautopatch) to suppress autoconnect.
improved the sound of rev2~ and rev3~ reverberators
Made stdlib and stdpath flags and declarations follow standard search paths (Iohannes again).
Dozens of small bug fixes.
------------------ 0.45-3 ---------------------------
fixed a bug pasting text into Pd and an audio problem in Mac OSX (non-default sample rates with built-in hardware needed huge buffering)
------------------ 0.45-1,2 ---------------------------
fixed bug in which backspace to dialog windows got sent to the last edited patch
------------------ 0.45 ---------------------------
multi-purpose "array" and "text" objects. "Array" is a more general replacement for the "table", "tabread" and "tabwrite" obejcts. "text" is sort of like Max's "coll" but simpler and hopefully more powerful. "text"s are also avaioable as fields in data structures.
"tempo" messages for delay, metro, timer, and "test sequence". In particular you can specify or measure time in samples, but you can also use this for changing the speed of an ensemble of delay loops while keeping them in sync.
binary netsend/netreceive (so you should no longer need an extern for OSC).
pd~ (multiprocessing) works on windows and is less likely to deadlock although not yet perfect.
Objects/messages/comments have settable box widths. By default they're auto, but you can change that by draging on the right-hand-side border. You can set it back to the default just by dragging ot to whatever width the default would have been. If a box's width isn't "auto" and you open the patch back in Pd version 0.44 you'll see a warning; if you open it in earlier versions you'll get pages of error messages but no real harm. You can open and save a patch in 0.44 if you'd like to reset all box widths to auto.
The Pd window now tells you whether PD has an audio device open or not, and various error and status messages that used to go to standard error now appear on the Pd window (this improvement was way overdue!)
Fixed hangups exiting when using jack.
Got ASIO working again on PC (it was apparently broken; I don't know for how long.)
Various other small improvements in audio and midi handling: Notably, except when using Jack, Pd doesn't open audio on startup; sometimes you want to get to the dialog panel before audio ever starts (for instance, on Mac, to revent Pd from hanging when someone walks in the building with an apple TV -- gee, thanks, Apple!)
Took a patch from Iohannes Zmoelnig to make Pd source conform to strict aliasing rules. The vanilla release is still compiled with -fno-strict-aliasing but this will be dropped after more testing.
The vanilla release now includes a 64 bit binary for MacOS. This is a separate app and it won't load externs that haven't been compiled with -arch x86_64. (Externs can be future-proofed by including both i386 and i86_64 binaries by compiling with -arch i386 -arch x86_64).
The soundfiler now writes correct sample rate to AIFF files (was previously hard-coded to 44100). Still no way to detect the sample rate of a file when reading it.
------------------ 0.44-3 ---------------------------
Fix hip~ AC gain once more (still didn't have it right).
Small improvements in MIDI handling (midiin and sysexin device numbering; two linux-specific fixes).
"open recent" fixed for linux
------------------ 0.44-2 ---------------------------
Fix underflow problem fr Rasbperry Pi (no effect on other platforms)
------------------ 0.44-1 ---------------------------
Fixed default API settings to prefer MMIO over ASIO for MS Windows and anything over jack (so that first-time users are most likely to get audio out).
------------------ 0.44 ---------------------------
many, many changes (hopefully improvements) in audio and MIDI I/O and in scheduling.
got rid of the "old" (cd src; ./configure etc) build system. src now contains fallback makefiles for gnu/linux and mac as well as windows. But the "official" way to build Pd is now to invoke automake.
better handling of reading and writing files with non-ASCII filenames in Micrsoft Windows.
fixed a bug in hip~ (incorrect gain; noticeably different when the cutoff frequency is set about 5K or higher.) To get the old behavior you can set Pd to be 0.43 compatible; see the hip~ help window for details.
inlet~ and outlet~, if configured to do upsampling, now use sample/hold instead of zero padding by default; arguably this is a bug fix as the DC gain isn't one for zero padding. Also undoable by setting compatibility to 0.43.
------------------ 0.43.2-3 ---------------------------
bug fixes, notably allowing an increase in incoming MIDI bandwidth.
added an "f" message to canvases which might in the future be used to specify formatting info (width; font size) box by box.
------------------ 0.43.1 ---------------------------
bug fix: in "perf mode" (having sent pd the "perf" message to prevent undesired patch closure) Pd crashed (oops!) when one asked for the patch to close after all.
Improvements to Mac version of bonk~ -- "learn" parameter handled correctly and compilation fixes.
Default font size is the same on all platforms.
Bug fixes reading and writing AIFF files, particulatly 24 bit ones
"edit mode" menu checkbox should work now.
X Pasting text into boxes now works in linux.
fixed bug that hung Pd when closing more than one pd~ subpatch out of order.
fixed segfault if DSP loop found and main patch had signal inlets/outlets
miscellaneous cleanups.
STILL BUGGY: when you change the contents of a graph-on-parent subpatch the old stuff often doesn't get erased correctly.
------------------ 0.43 ---------------------------
Completely new TCL front end, thanks to Hans-Christophe Steiner, Iohannes Zmoelnig, and others.
------------------ 0.42-5 ---------------------------
broken abs~ and log~ fixed
pd~ -ninsig 0 hang fixed
testtone updated and 16ch version added
lrshift~ bug fix
32 channel limit removed for portaudio (ASIO/Windows and Mac)
------------------ 0.42-4 ---------------------------
added -noautopatch startup argument to defeat auto-connecting to new objects (some folks like it and others hate it)
gfxstub bug fix
fixed crash on deleting "s" objects with no args
re-fixed seteuid(0 problem
fixed crash on "find $1" (still not useful though)
------------------ 0.42.1-3 ---------------------------
Bug fix on Windows(cancelling window close deactivated window).
Bug fix running Pd from command line in MacOS.
"Select all" fixed to select none if everything already slected.
------------------ 0.42 ---------------------------
The 'struct' object can now be used to catch a small but growing variety of events (mouse clicks on data, selection/deselection).
The 'tabread4~' object was fixed to allow message-time onset into the table. This makes it possible (at last) to use tabread4~ effectively with large (> 1 second) samples. New help files 3.audio.examples/B15 and B16 show how to use it. It's not pretty but it's at least possible.
Took patches from Iohannes Zmoelnig to make Pd work when compiled to use 64-bit floating-point audio. I didn't test this; doubtless there will still be some problems. (This isn't the same thing as running in '64 bit mode' which already works fine and is the default when compiled on a 64-bit linux machine.)
New objects in extra, 'pd~', and 'stdout', allow running a separate Pd instance in a sub-process. Theoretically this should make it possible to use multiprocessors efficiently in {d. It's still somewhat experimental; it might not work well to pass large numbers of messages and/or signals back and forth.
A -batch flag allows Pd to be run efficiently from scripts. You should probably also specify -nosound. With these flags Pd runs as quickly as it can without waiting for real time. It's up to the patch to arrange to exit at the appropriate time via a 'pd quit' message.
Large and sweeping improvements have been made to bonk~ and sigmund~. The new bonk~ features are documented in its help window; sigmund~ works better but has the same old features.
Closing and quiting Pd now act more politely, querying the user only if there are edited windows. There's also a query if the user types into a box holding an edited abstraction to prevent the changes from getting lost accidentally. A new 'pd perf' message re-enables the old "really close this window" behavior, which is appropriate for performances where you don't want the wrong keyclick to stop Pd brusquely.
The process of reloading multiple copies of a modified abstraction was sped up.
The 'find' dialog permits searching for substrings. This is useful for strings containing "$" arguments, where it's unclear what 'find' does or should do.
New pow~, log~, exp~, abs~, and 'wrap' objects.
The 'print' object takes "-n" flag to supperss "print:" in output
"clear" button in Pd output window
".pdrc" loading suppressed if pd is started with "-noprefs".
Bug fix in pipe object: if sending a list to pipe, it didn't update the delay time when asked to.
Binbufs fixed to handle arbitrary length messages. (This fixed a problem reloading data structures with huge arrays).
various fixes to
------------------ 0.41-3,4 ---------------------------
2 fixes for PC: no bonk~, and the audio device selection dialogs didn't show all the devices.
------------------ 0.41-2 ----------------------------
More bug fixes: large netsends dropping messages, and crash bug when turning DSP on and off repeatedly in MS windows
------------------ 0.41-1 ----------------------------
Fixed a startup problem for Mac OSX 10.5.1 (other platforms should not be affected)
------------------ 0.41 ----------------------------
Pd may be compiled in 64 bit address spaces; this is well tested on linux and at least seems to work on Microsoft and MacOS. On linux, in fact, if you compile Pd in a 64-bit version of the OS it's automatically in the 64 bit address space.
In linux, a "-nosleep" flag causes Pd to poll instead of sleeping as it waits for dac and adc; this is useful on multiprocessors when you don't mind having Pd occupy 100% of one processor and want to get latency as low as possible. (If you don't use this, latency on multiprocessors - Intel Core 2 at least - is much worse for some reason than it is on uniprocessors.) It's "experimental" but I use it every day.
added an experimental callback scheduler. This might reduce latency in MacOS and/or Microsoft, although I haven't seen that actually happen yet.
removed limitation on huge messages from text files; this prevented long "data" arrays from reloading from disk correctly.
fixed crash bug closing patches with open GOPs.
changed selection strategy so that, right after duplicating a collection of objects, clicking tends to select an already-selected object.
the cursor changes slightly more apprpriately when switching between edit to run modes.
got really confused about the proper role of "declare 'path" in abstractions; for the moment they are ignored. I the future, it may be worthwhile to allow them but to have them act only locally to the abstraction; but this might mean a lot more computation overhead when opening files.
limited window sizes to that of the screen (otherwise, on Mac OS, it's impossible to resize them.)
fixed "startup" dialogs to allow unlimited "path" and "lib" entries
started, but didn't finish, the process of getting Pd to compile with t_float as 64 bits. This would slow Pd down but improve tabread4~'s accuracy.
made IEM Guis respect "-font" flag and friends. New startup flags: "-font-face" (badly named); "-font-size" sysnonym of "-font". (Large patch from HC).
String overflow protection here and there.
migrated to ".net" compiler ("VC 2005", a free download).
------------------ 0.40-1 --------------------------
Fixed "declare" which wasn't working properly yet in 0.40-0, and made more objects (notably "soundfiler") respect "declared" paths. Path entries are relative to the parent patch. Declares inside abstractions are ignored.
"drawnumbers" are draggable now, even if they're in arrays.
Bug fix opening "html" help from windows.
Changed MACOSX to __APPLE__ in 4 places.
------------------ 0.40 -----------------------------
A new object, "declare", allows patches to control where Pd looks for resources such as abstractions and libraries.
Sybmols can now be built using multiple dollar sign variables, as in "$1-$2.$3". Meanwhile, naming subpatches as in "pd $1-foo" now seems to work correctly.
The switch~ object takes a "bang" message to compute one block of DSP on demand. Also, block sizes are no longer required to be powers of two (although reblocking only works between powers of two.)
Externs may have characters in their names that aren't part of valid C variable names (i.e., outsize the range a-z,A-Z,0-9, _).
Openpanel and savepanel take an argument to set the initial directory to search.
Support for large (>2G) soundfiles, in operating systems that offer it.
Text copy/paste fixed (I hope) for Macintosh
Intel Mac binaries. New naming scheme for externs to allow disambiguation (although Pd falls back to the old names for compatibility.)
Templates can get notified when data are selected/deselected. I want to provide this for mouse actions on locked canvases too, but haven't yet.
Characters like "\", "[", etc., typed into dialogs for labelling number boxes or other GUI objects, get filtered out so that they at least don't hang Pd up.
Drawcurve (and the others, filledcurve, drawpolygon, filledpolygon) have a new "-x" flag that inhibits a scalar getting selected when the curve is clicked on. This is useful for drawing stuff in the background (grids, clefs, etc).
6 or so patches adopted from sourceforge.
A "list length" object
IEM Gui labels (except for the VU meter) default to 10 point fonts (typically 8 before).
"send" without an argument gets an inlet to set the destination
A -noprefs flag defeats loading startup preferences. This gives you a way to rescue things if Pd's settings somehow crash Pd on startup.
tabwrite~ takes a "start" message to allow writing into the middle of the table.
------------------ 0.39.2 --------------------------
Bug fixes: memory leak in OSX version; problem printing numbers as symbols.
------------------ 0.39.1 --------------------------
Bug fixes: compatibility problems with older version of TK
------------------ 0.39.0 --------------------------
At the source level, "regular" arrays and arrays within data structures are now the same thing. This will mean that, in the future, features introduced to one array type will become available on the other one too. Array elements are "scalars" (i.e., data structures) and if they have drawing instructions, each point of the array is drawn according to them; they can be clicked on, etc., just like any other scalars. "Regular" arrays have points which are of a special, built-in template, "float".
Drawing instructions now can use variable ranges for screen coordinates; for instance, specifying an offset of "a(0:10)(100:200)(0.2)" specifies that the member "a", which shoudl range from 0 to 10, should be graphed at locations ranging from 100 to 200 (relative to the scalar's base location) and should have a "grain" of 0.2, i.e., steps of 2 pixels each.
Drawing instructions can be turned on and off, either globally (for all data of the given structure) or by a data field.
The "struct" object has an outlet to notify you when a datum is selected or deselected.
Graph-on-parent subpatches and abstractions no longer scale the GUI objects to fit the parent rectangle; instead you get a sub-rectangle in the subpatch, of the same size as the parent object, to place GUI objects in. GUI objects that don't fit inside aren't shown on the parent, and the parent objects no longer stretches itself to show things that wouldn't otherwise fit. Older patches work as before until you try to edit them - at which point you have no choice but to use the new functionality.
The font size of a Graph-on-parent abstraction is that of the abstraction itself, not the calling patch.
Message boxes now take "addcomma" and similar messages.
A "list" object is provided for joining and splitting lists, and converting between lists and non-list messages.
Pd extension is now added automatically to files on Macintish when you do a "save as". The tcl/tk version is updated to 8.4.5. This should run on OSX version 10.2 and later. Also on Mac, drag-and-drop startups read "libraries" (specified in "startup" dialog) before opening the file.
The "pointer" object has a method to rewind to the beginning of a list. A "sendwindow" message forwards any message to the window contining the scalar currently pointed to.
Abstractions don't produce visible windows, even if subwindows of the abstraction were visible when the abstraction was saved.
MIDI sysex messages should now work on all platforms.
Bug fixes:
sending lists to arrays now correctly interprets the first number of the list as the starting index (following values are then stored seuentially in the array.)
The rfft~ object's imaginary part had the wrong sign. Also, the Nyquist bin is now supplied correctly.
Fixed problems writing aiff files using the writesf~ and soundfiler objects. Writesf, if sent an "open" while a file was previously being written, closes the previous file first.
Bug fix in number2 which sometimes crashed Pd.
Stale-pointer protection made more robust.
Some of Pd's tcl/tk error messages have been tracked down, but probably not all of them yet.
"Find" crashed Pd when the found object was in a GOP.
Mouse motion over arrays no longer is quite so CPU-consuming (but is still somewhat so.)
samplerate~ now reflects up/downsampling.
Tilde objects in blocked, overlapped subpatches no longer adjust their internal sample rate to reflect the overlap.
Fixed a thread-safety problem in sys_microsleep().
------------------ 0.38.1 -------------------------- Fixed two bugs that crashed Pd when deleting number boxes in certain situations.
------------------ 0.38.0 --------------------------
The big change is queued graphics updates, which apply (so far) to tables and number/symbol boxes. The IEM GUIS aren't enqueued yet. This along with a better graphics update buffering scheme makes Pd's graphics run much better.
Support for cutting/copying/pasting text between boxes and between Pd and other applications.
Dialogs for setting and saving path, libs-to-load-on-startup, and some other things. This and the audio settings can be saved automatically to the appropriate repository (.pdsettings on linux; registry on MS windows; "Preferences" on Mac.)
"Print" printout goes to the Pd window by default. You can revert to the old (standard error) behavior with the "-stderr" startup flag.
The "gui" TK script can now start Pd up (previously Pd had to be started first.) This is needed for Pd to work as an "App" on Mac.
new filter objects: cpole~, fpole~, etc... these will get used in the upcoming Techniques chapter 8.
Objects whose creation failed get a distinctive outline; if they are already inside a patch they sprout inlets and outlets as necessary to preserve connections.
Filenames in the "search path", etc., now may contain spaces, commas, and semicolons.
bug fix: click on minaturized subpatch failed to "vis" it
bug fix: font size change crash reported by CK
Key bindings like control-Q now work even from within most dialogs.
The audio settings dialog now permits turning audio input and/or output off without forgetting how many channels it should be when on.
RME Hammerfall ALSA support from Winfried -- but specify the number of channels correctly or else Pd crashes.
portaudio (e.g., Mac) audio support fixed for inchans != outchans, so the emi emagic can now be used 2-in. 6-out, for example.
(linux) The configure script can set the setuid flag on "make install". The "-enable" flags to ./configure should now work correctly too.
atan2 had its inlets switched to conform to standard usage
------------------ 0.37.3 --------------------------
Oops- added __i386__ macro to windows makefile so it would test for underflows correctly. This affects only Microsoft Windows; the other two platformas are fine as 0.37.2. Thanks to Thomas Musil...
------------------ 0.37.2 --------------------------
fixed a bug in soundfile reading (soundfiles now default to wav better.)
fixed gfx update problem in hradio and vradio
minor changes to built-in Max import feature (but you should still use cyclone's instead.)
colors for scalars fixed (probably never worked before!)
added a "set" message to the line object
aliased spaces to underscores in GUI labels so that at least they won't destroy the object.
------------------ 0.37.1 --------------------------
fixed the apple key on OSX so it does key accelerators
fixed bug in -inchannels/-outchannels arg parsing
major editions to the IEM GUIs to fix bugs in how "$" variables are handled. The code still isn't pretty but hopefully at least works now.
bug fix in vd~ for very small delays
fixed MSW version not to make windows grow by 2 pixels on save/restore
added an "nrt" flag for OSX to defeat real-time priritization (useful when runnig Gem.)
on some platforms, audio open failures are handled more gracefully.
added a "changelog" file in the source directory to document source-level changes.
------------------ 0.37 --------------------------
Pd is finally fixed so that it can open and close audio and MIDI devices on-the-fly (previously it opened them once at startup and hogged them until Pd quit). Starting DSP causes audio devices to be opened, and stopping it closes them. There are dialog panels in the "Media" menu (which used to be called "Audio") for choosing audio and MIDI settings. The "path" also can be changed on the fly via a dialog in the "File" menu.
 A "vline" object acts like "line" but to sub-sample accuracy.  See
the audio example, C04.control.to.signal.pd (and/or chapter 3 of
 Theory and Techniques of Electronic Music  ).
 
  The block~/switch~ object now takes a "set" message to dynamically change
block size, etc.
  The makefilename object takes a "set" message to set the "pattern".  You
can use this to kludge multiple substitutions (as shown in the help file).
  The writesf~ object got an update and a better help window.  It now should
be able to write 32bit floating-point WAV soundfiles.  The file's sample rate
is now set "correctly".
   Various improvements were made in audio I/O to improve stability and
reduce latency.
   Jack support should work for Mac OSX (it appears as a separate API).
Linux is offering experimental portaudio V19 support (but Mac and Window/ASIO
are still based on PA V18.)
   The fiddle~ object (in extra) has an "npoints" method to set the analysis
window size dynamically.
  (windows) Pd is now distributed as a self-extracting archive.
  (windows) url files in the help directories are opened correctly.
  (Mac) the arrow keys should now be fixed.
  (linux) The "configure" script should be better at finding TK in various
distributions (debian users previously had to use a special configure script.)
  (developers) Pd now exits cleanly from its main loop instead of bailing
out.  A mutex protects Pd's data so it can be accessed from other threads. 
(Thomas Grill's improvements.)
  (developers) The "savefunction" and "dialog" widget behaviors
were replaced by a better mechanism (class_setsavefn() and
class_setpropertiesfn()).  THey're declared in m_pd.h so you don't have to
include the (unstable) g_canvas.h to get them.
  (developers) Better flag handling in the IEM GUIs (g_toggle.c, etc) should
compile with fewer warnings and be more portable.
  ------------------ 0.37-test 1 --------------------------
  The MacOSX version now prioritizes itself effectively (thanks to
gert@test.at (v93r)) via Adam Lindsay).  Adam also made a proper MacOSX
"package" for Pd.
  A bug was fixed in readsf~/writesf~ (things were coming out in the wrong
number of channels.)
  A problem compiling Pd with TK8.4 (the latest version) was fixed.
  Large numbers of GUI improvements by Adam Lindsay, especially relevant
to Mac OSX.
  For externs, the binary may now be included in a subdirectory of the
same name (e.g., "choice/choice.pd_linux" and "choice\choice.dll").  So
now you can pack multiple binaries for the same extern, along with the
source, in one convenient place.  (Note that
"expr~" is an exception, since it goes by three different names, so this
trick fails for that example.)
   "Help" files renamed "help-xxx.pd", so that help files are now possible
for abstractions.  The "help path" feature from CVS (I forgot who contributed
that) is also included but should now not be needed: Pd remembers where it got
externs and abstractions and looks back in the same directory for a help file. 
See the way "extras" is organized.
   Pd refuses to connect signal outlets to non-signal inlets.
   When you save any patch, Pd looks for all invocations of that patch
as an abstraction and reloads them.  This unfortunately has the side effect of
making all the containing windows visible, but it's better than nothing.
  ------------------ 0.36-1 -------------------------------
  "print" now queries you for a file to save the postscript to.
  "expr" brought up to date (0.4) -- a bug was fixed involving expresions
like "max($f1, 100)" which had erroneously output an integer.
  a bug fix in the 4-point interpolation formula, which affects tabosc4~,
tabread4~, tabread4, and vd~.  These should have significantly lower
distortion than before.
  bug fix: vradio, hradio "send symbol" feature didn't work
  ------------------ 0.36 -------------------------------
  There's now an "undo" for most editing operations.  Undoing is only
available in the window that was most recently edited.  (One gotcha remains,
that "stretching" (in the font menu) affects all windows and you can't undo any
but the last one it touched.)  Also, there's no "undo" for run-time operations,
only editing ones.  That might be worth thinking about.
  Some bugs were fixed that affected "flipped" canvases (ones whose
"properties show a positive "y" increment per pixel.)  Also, the coordinates
are now saved and restored correctly.  "text" objects (comments) now stick to
the bottom of the window for flipped canvases.
  Signal lines now show up fatter than control lines.  (Now I have to go
through the figures in the HTML doc again... drat)
  "Classic" number boxes now can have labels and send/receive signals, which
work in the same way as the IEMGUI controls do.  I think "$1" style
label/send/receive names work too.  I fixed a related bug
in the IEM code (typing at boxes sometimes crashed Pd).  
  "vdial" and "hdial" were renamed "vradio" and "hradio", and fixed to
output numbers, not lists, like the other GUIs.  The old ones are still around
for compatibility with old patches.
  "Make install" should now actually make Pd before trying to install it.
  "expr" is updated to Shahrokh's 0.4test3 version (which I modified somewhat
to get it to compile.)  
  The problem of CPU usage skyrocketing on underflows in P4s should
be fixed.
  Compiled "pdsend" and "pdreceive" for Windows.
  "PD_VERSION" macro added to m_pd.h
  ------------------ 0.35 -------------------------------
  An experimental new feature called graph-on-parent allows subpatches and abstractions to show
GUI features; so, for instance, you can make an oscillator with a number box to
control the frequency.  This is described in section 2.7.2 of the HTML
documentation and an example is shown in 7.stuff/synth1/.
  Spaces are allowed in pathnames to Pd and to patches; however, the "path"
variable still can't have spaces.  (You can address path directories using
relative pathnames as in "../sound" (or ..\sound on Windows), even if there
are spaces further "up" the path to the patch.  See 3.7, "dealing with files."
  The soundfile reading routine (used in readsf~ and soundfiler) is much
better at opening wav files with different header sizes and odd chunks.
You can now read floating-point "wav" files -- although you can't write them 
yet.
  Templates and data structures are extensively reworked.  A "struct"
object replaces "template", so that you specify the name of the structure as
the first argument to "struct" (previously it was derived from the
window name.)  You can now have multiple "structs" of the same name; the
oldest one is the "real" one, but if you delete that, the structures are
all conformed to the next-oldest one, and so on.  You can alter the contents of
a "struct" and all the associated data will be modified to fit the new
structure definition.  Data are persistent, i.e., saved with the containing
patch.  You can copy and paste data between patches.  If you save data to a file
explicitly, you can read it into another patch and the data are conformed
automatically to the new data structures.
  A new version of Thomas Musil's GUI objects was merged in.
  The testtone patch works for up to 6 channels of audio input and output.
  Lots of improvements got made to audio I/O in general.  In NT you may
specify "-asio" to use ASIO drivers; see HTML documentation section 3.2.
You may specify lists of audio input and output devices.  In Linux, Pd
will now attempt to open each /dev/dsp* only once, even if it's requested
for reading and writing.
  The "extra" directory is now searched after the directories in the
search path, not before (so now you can override objects like "fiddle~").
  A bug in paf~ is fixed.
  In Linux, the ".pdrc" is now read before the command line arguments, so
that command line arguments override the .pdrc (it was backwards before.)
  In Linux, "help" now can invoke either mozilla or netscape to start
up the HTML documentation.  This doesn't work in Windows or Mac land yet.
  In Linux, the "-32bit" flag was added, which you must now use if 
running Guenter's OSS RME Hammerfall driver.  (This was necessary because
OSS went and used the same "bit" for a different purpose, so that Pd tried
to open some other cards in 32bit mode inappropriately.)
  In Linux, MIDI is now opened "-NODELAY" ... this makes the OSS Creative
driver take MIDI input correctly which it didn't before.
  In MS windows, you can now use "readsf~/writesf~" for spooling sounds to
and from disk.
  MS Windows bug fixes: -nosound was ignored, and now works.  Also, clicking
to open abstractions, when they were already open anyway, used to lose the
keyboard; this should be fixed now.  Finally, "netreceive" didn't work when
running "-nogui". This is fixed, and moreover, you should definitely include
a netreceive object in any -nogui patch in MSW, otherwise it eats up all
available CPU time gratuitously.
  The outlet is removed from the "table" object.
  In MS Windows, Pd now has "-resync" and "-noresync" flags so that you
can specify how to deal with audio input and output blocksize nonsense in
MMIO.  If "resync" is on, whenever the audio input and output seem out
of whack the audio driver resynchronizes all input and output devices;
otherwise the situation is simply ignored.  "Noresync" is probably best for
consumer stereo cards (and is the default if you're running only 2 channels in
and out).  If you're running more than 2 channels in either direction, the
default is "resync".
  In soundfiler's read method, if you specify "-maxsize", that implies
"-resize" (as it ought to.)
  You can use $1-style names for arrays and tables.
  Pd will now refuse to make duplicate connections between objects.
  Pd is (somewhat shakily) running on Macintosh OS/X.  See section 3.4 of
the HTML doc.  For Macs with one-button mice, you can double-click in edit
mode to simulate a right click.  Unfortunately, the "alt" key doesn't work
yet.
  In Linux, ALSA audio is now fixed to clip, not wrap around, on output
overflows.
  Various problems were fixed with objects changing size.  Number boxes never
wrap to two lines (as they used to), and lines are reconnected appropriately
when objects are resized.
  A function call is added to retrieve a unique event-dependent number,
so that objects like "buddy" can be written.
  All the "sound" command-line flags now have "audio" equivalents.
  The "-listdev" flag now works on Mac and MSW/ASIO.
  Help file updates for env~, route, and pointer
  ------------------ 0.34.3 -------------------------------
  fixed a bug in "udp" netreceive that crashed pd
  fixed a bug in tabosc4~ that caused gritty sound
  changed "specfile" for RPM releases (thanks Fernando)
  adopted Krzysztof's glob_setfilename bug fix
  bug fixes from "the joy of global variables" thread in Pd list
  made a help window for "table".
  ------------------ 0.34.2 -------------------------------
  fixed ".pdrc" bug
  added an experimental "pd restart-audio" feature for (new) Alsa
  ------------------ 0.34.1 -------------------------------
  Bug fixes:
  1.  Closing a window with objects selected crashed Pd.
  2.  "find" when it opened a window to show the found object crashed Pd.
  3.  (Linux only) Oversized .pdrc files crashed pd...
  Also, I updated Thomas Musil's IEM GUI objects and their help files.
  ------------------ 0.34 -------------------------------
  NEW FEATURES:
  I incorporated Thomas Musil's GUI objects (slider, button, etc.) into
the Pd release so Thomas won't have to publish patches to Pd anymore.  I
didn't take the graphical inlets and outlets for reasons explained elsewhere,
but Thomas might decide to continue supplying them on a patch basis.
  Many new examples were added to the "2.control" and especially
"3.audio" example patches.  A list of differences between Max/MSP and Pd
now appears at the end of this section.
  Finally, I fixed Pd to notice window iconification and suspend graphical
updates for iconified windows.
  Numbering of versions of Pd will now be as in "0.34.2" instead of
"0.34PATCH2" which was confusing.
  BUGS FIXED:
  I incorporated Krzysztof Czaja's menuclose bug fix in g_canvas.c.
  (Linux) the configure script is more rational.
  the qlist and pack objects were fixed to handle reentrancy correctly.
  Pd now complains about running out of memory (before it dies.)  I intend
to provide advance warning and automatically back out of loading patches that
would run out of memory, but that's not in place yet.
  Typing into a message box sometimes left you with lines from the output
pointing to the wrong location.  Fixed.
  Reading of "wav" and nextstep soundfiles now handles the headers better.
  ------------------ 0.33 -------------------------------
  AUDIO AND MIDI:
  MIDI time jitter is reduced.  Theoretically, it could now be
as low as the audio blocksize (and so if you care about MIDI timing, keep your
audio blocksize low.)  If you run Pd with audio in stream mode or without
audio at all, and perhaps in some cases in block more too (?),
the controlling parameter for MIDI jitter is "-sleepgrain", which specifies
the interval of time Pd sleeps when it believes it's idle.
  You can now specify multiple MIDI input and output devices.  For example,
"pd -midiindev 3 -midioutdev 4,2" asks for the third MIDI input device and the
fourth and second MIDI output device.  The "channel message" midi objects in Pd
such as notein or pgmout will take channels 1-16 to mean the first open MIDI
port, 17-32 the second one, and so on.  The midiin, sysexin, midiout objects
give you a separate inlet to specify which of the open MIDI port numbers
you want.
  (Linux only) By default, Pd now reads and write audio in "block mode."
Previously you have to specify "-frags" and/or "-fragsize" to get this.
As of this version you have to specify "-streammode" to get the opposite,
streaming mode.  This mode seems only to work with a small number of sound
cards, notably Ensoniq ens1370 and ens1371.
  (Linux only) Also, "-fragsize" is replaced with a more convenient
"-blocksize" which you specify in sample frames.  It defaults to 64 which is
Pd's audio computation block size but may be larger or smaller.  Typically you
would specify "-audiobuf" and "-blocksize" and Pd will  compute "-frags" for
you; but you can also specify "-frags" explicitly.
  (Linux only) OSS and ALSA audio support are improved.  You can now talk to
RME9652 using Guenter's OSS driver; this is different from the "-RME" support
which uses Winfried's older driver.  Other multichannel OSS drivers might now
work as well.  Pd also seems to work with ALSA 0.9 Beta 4; I've tested this
with Midiman Delta 66 and Soundblaster live.  I plan to update the linux audio
setup documentation accordingly.
  NEW FEATURES:
  I've put in Shahrokh's new expr, expr~, and fexpr~ objects.  The latter
allows you to make expressions referring to prior input and output samples in
case you're interested in writing your own recursive filters, oscillators,
or chaotic sound generators...
   In support of expr, you can now use commas in "object" boxes; they just
become symbols.
   sqrt~ is fixed so that it apparently has 24-bit accurate mantissas.
It turned out to be easier to just make it accurate than to confront the
question of how a reduced-accuracy version should be named.
  The bizarre framp~ object which does phase vocoder analysis got a help
window.  The phase vocoder example doesn't use framp~ and I had forgotten
what it did until Guenter dug it back up.
  (Linux only) I finally got around to incorporating Guenter's autoconf
stuff, and learned about RPM.  Major new Linux releases will probably be
in .tar.gz and .rpm formats; "test" releases will probably just be in .tar.gz.
I also fixed it so that the installation prefix is overridden if you invoke
pd by its full pathname, so that you can still use compilations with
installation prefixes before you actually install them.
  (NT only) I added support for directX using the portaudio package
by Ross Bencina and Phil Burk.  I couldn't discover any way this would ever
outperform the old "multimedia" API Pd uses.  So the release contains the sources,
but you have to recompile Pd to use directX.  Use "makefile.nt.portaudio".  Only
1 or 2 channels of audio are supported.  The interesting thing is that the same
code will run on Macintosh.  There are a couple of other obstacles to a
MacOS port of Pd though; it's hard to predict when this will be feasible.
  BUG FIXES:
  "drawnumber" was broken in 0.32 -- fixed.
  new arrays in 0.32p6 got ill-fitting graphs -- fixed.
  ------------------ 0.32 PATCH 6 -------------------
  Got array and graph dialogs to behave better when there are more
than one.
  put in mtof~, etc.
  made Pd search the "extra" directory without having to specify it in "path."
  bug fix in exporting patches to Max
  ------------------ 0.32 PATCH 5 -------------------
  Reversed the order of these release notes so that the newest appear first.
  Arrays can save their content with containing patch; the properties
dialog selects this.  The dialog shows up when you create a new array from
the menu, and allows you to set the name and size.  Only floating point arrays
can be created and edited this way.
  Bug fix: the figures in the NT web doc were garbage.
  Bug fix: large tables (> 800 pixels and points) no longer crash the GUI.
A related problem remains; large arrays are truncated to either 1000 points
or 1000 pixels.
  Bug fix: doing "save as" on an instantiated abstraction no longer sets
the window title.
  in linux, a couple of status messages on opening /dev/dsp only appear now
if Pd is run "-verbose".
  ------------------ 0.32 PATCH 2, 3, 4 -------------------
  Hassled more with font size differences between NT and Linux, and updated
many help files.  Minor bug fixes here and there.
  the table object now takes a second argument to set size in points.
  Improved underflow protection in some DSP objects.
  pointer now has a "vnext" traversal method which goes forward to the
next SELECTED object.
  improvements to throw~ (it now sums) and receive~ fixed to be settable.
  bug fix in which RME driver always thought sample rate was 44100.
  ------------------ 0.32 PATCH 1 -------------------
  bug fixes (bugs flagged by mik): vcf~ help window crashed; writesf~
only wrote 1 channel soundfiles; "table" object didn't open when clicked
on;
  new object: tabosc4~ -- finally, a real wavetable oscillator for Pd.
  much work on "data" editing; go to 7.stuff/data-structures, open patches
5 and 7, and try clicking on things.  Alt clicks delete or add points; regular
clicks drag values around.  The cursor changes to show you what will happen
if you click.
   New objects:  
  midiin, sysexin, midiout.  (I don't think MIDI sysex is working
in Windows yet though.)
  threshold~ as in Jmax, triggers from audio level.
  value as in Max and Jmax.
  writesf as in Jmax.
   New startup flags:  
  -sleepgrain: if you aren't using audio I/O, this can reduce time jitter in
MIDI I/O.  Otherwise, MIDI I/O jitter is limited by the audio buffer size.
  -noloadbang: cancels loadbangs.
  -nogui: suppress starting the GUI.  You can then still talk to Pd using,
perhaps among other possibilities, the new network connection programs now
included in the release.
  -guicmd: lets you specify the command string Pd calls to start the GUI,
in case you've written your own GUI to replace the TK one Pd comes with.
  -send: after loading all the patches specified in the command line,
you can specify "startup" messages to send.  For example, if you want to use
Pd just to play 50-channel soundfiles from a shell, this is how you can specify
the soundfile name on the command line.
   bug fixes. 
  A readsf~ problem got fixed.
  hitting the tab key used to cause Pd windows to relinquish the keyboard.
  The $0 feature apperas now to work.
  Inlets and outlets of subpatches sometimes got out of left-to-right order.
  Scrollbars are less out of whack than they were before.
  Pd now knows to de-iconify windows if you "vis" them from the parent.
    in general:  
  In Linux the treatment of MIDI input is now much more efficient.  Also,
bugs were fixed in notein and (for SGI) bendin.
  You can "select all" from the Edit menu.
  standalone programs "pd-send" and "pd-receive" are provided that can send
mesages to Pd or receive messages from Pd via the netsend~ and netreceive~
objects.  This should allow you to interface a wide variety of other programs
with Pd either on the same machine or over the network.  Also you should be
able to hack the code into your own programs to make them interoperate with
Pd and/or each other.  The underlying protocol is called FUDI.
  "Properties" for scalars, graphs, and number boxes: left click on them.
In particular, number boxes can have fixed widths and finite ranges; if you
make them one character wide they act as toggles.  Later you'll be able to
configure them as sliders.
  As to scalars, the properties dialog lets you edit the data in the raw.
Don't try to edit the template though; you can't.
  You can now type into a "pd" object to change its name without losing the
contents.
  An experimental "scalar" _text_ object now allows abstractions to draw
primitive control panels on their parents when you invoke them, as if they were
Moog or Buchla modules.  See the "7.stuff/data" examples.
  New help windows for the "data" classes (pointer, append, template, etc.)
and for send/receive which somehow I had neglected.
  When you hit "copy" with nothing selected, the copy buffer used to be
cleared.  This is fixed to do nothing.
  ALSA support in Linux has been completely overhauled.  It now works with
Midiman (up to 10 in/12 out!) and es1370.  There are problems with SBLive under
ALSA but it works in OSS emulation with a "-frags" setting. See the "getting
started" documentation.
  In NT, the default is now "noresync" if you're running stereo.  You can
override this with the "-resync" flag.  If you're running more than 2 channels
it's the opposite (as it was before.)
  "symbol" boxes now display symbols and let you type them in.
  There was a bug when you renamed a patch from outside Pd; the old filename
still showed in the title bar (and there were other bad side effects.)   FIxed.
  Protection was added against patches opening themselves as abstractions.
  The "route" object's handling of leading symbols was improved.  I'm not
sure whether it's Max compatible or not.
  You can draw into arrays with the mouse, at least in the case where there's
at least one pixel per point.  (I'm not sure if the other case even makes
sense.)
  Abstractions display their "$1", etc., arguments in the window title bar.
  A "sort" method was added for lists to make them easier to use as
sequencers.
  The "save as" dialog makes a more reasonable choice of start-up directory.
  "Trigger i" is now disallowed (it used to crash Pd.)
  Getbytes and resizebytes now zero out new memory.
  A memory leak reported by Hannes has been partly, hopefully mostly, fixed.
  The "signal_free 2" bug reported by Fogar is fixed.
  New graphs now reliably avoid using already-taken "graph%d" names.
  The old bug which showed up as ".xxxxxxxxx: no such object" is fixed.
  The FFT examples have been reworked and the "pique" and "shift" objects
are moved to "extra".
  in Linux, you can get Pd to promote itself to "real time" priority.
A "watchdog" process protects you from having Pd lock your machine up.  You
must request real time by running "pd -rt" or "pd -realtime".  You must  either
be superuser or make Pd a root-owned SETUID program (chown root .../pd/bin/pd;
chmod 4755 .../pd/bin/pd).  For security reasons, Pd relinquishes root
privelige immediately after setting its priority, before loading
any patches or externs.
  Protection was added against message loops.
  loadbang was fixed so that loadbangs in abstractions go off before loadbangs
in the owner patch.  Within each patch, loadbangs go off forst in subpatches.
  new object: tabplay~, a non-imterpolating sample reader.
  new objects (in "extra" library): loop~; rev1~.
  The "toys" library was renamed "extra" and incorporated in the Pd release.
  In Linux, timeouts were added to the driver opening and closing code
(which used to hang under some conditions.)
  the "field" object was replaced by "template"; see "data.structures"
examples in 7.stuff.  Data lists can be read from and written to files now.
  You can invoke an external object by pathname, as in "../../extra/loop~".
  hip~, etc. should no longer get stuck when they get a NAN on input.
  a bug was fixed in expanding symbols such as "$1-foo".
  readsf~ - a MAX/FTS style soundfile player, which reads multichannel
soundfiles in wave, aiff, or next formats.  The files must be 16 or 24 bit
fixed point or 32 bit floating point (only nextstep headers understand the
latter.) You can also override the header.  A "skip" flag lets you read
starting anywhere in the file.  (Sorry: linux only for now; I can't find
Posix threads packages for the other platforms.)
  soundfiler - support for reading and writing soundfiles (wave, aiff,
nextstep) to and from arrays.  Multichannel soundfiles can be read into or
written from several arrays at once.  When reading you can ask that the tables
be automatically resized; in any event the object obligingly outputs the number
of samples actually read.  When writing you can specify a sub-segment of the
arrays, and/or request that the soundfile's maximum amplitude be normalized to
one.
  tabplay~ - a non-interpolating sample player
  Garry Kling reports having compiled Pd for "yellowdog" linux on Macintosh
computers.  One "fix" has been made to s_linux.c to facilitate this.  I don't
have access to a Mac running linux at the moment so I can't verify whether
any particular repease of mine actually works there.
  Signal objects now automatically convert scalars to vectors, so that you
can just run a number box into a signal input.  One caveat is that the binops
"+~", "-~", "*~", "/~", "max~", "min~" run slightly faster if you give them
an argument to tell them that their right inlet will be scalar; so the 
construction "+~ 0" is still meaningful.  This will get fixed at some later
date...
  Font sizes work in what I hope will be a more machine-portable way.  On
any machine, the point sizes 8, 10, 12, 14, 16, 24 are DEFINED to be the
largest fonts Pd can find that don't exceed their size on my linux machine.
This way I can write patches that everyone else can read, and others will
at least have fewer portability problems than before.  The downside is that
your old patches may appear with a different type size than you want; use the
"font" menu item to fix them.
  The OSS support no longer asks the audio driver whether full duplex
is needed; it just tries to open it.  Apparently some drivers (such as
ALSA's OSS emulation) might do full duplex but not implement the call Pd
used to query for it.
  You can give "-nomidi" as a flag (previously you had to type "-nomidiin
-nomidiout".)
  A GUI bug reported by Iain Mott was fixed.
  You can now type symbols such as "$3-poodle" and the "$3" portion gets
expanded properly.  Someone was also asking about the FTS-style #0 feature,
but I couldn't figure out how to reconcile it with Pd's usage of "$" for "#"
in abstractions.  So I'm still searching for a good way to provide local
symbols.
  the GUI now protects itself from "\", "{" and "}" characters by dropping
them.  I wonder how many NT users have crashed Pd trying to type in filenames
with backslashes...
  samphold_set and tabwrite_stop methods added.  There turned out to be
no help window for samphold~ so one was supplied.
  Version 0.28 has a primitive in-box text editor... about time!
  the "front panel" now gives you information on audio levels and
sync errors.
  Message boxes flash, sort of, when you click them.
 
Support has been added for RME 9652 soundcards; see the Linux soundcard section of
the documentation.  Support files for RME and PCI128 (Ensoniq es1370) cards
are released separately from Pd.
  The delete and backspace keys clear the current selection.  There is
unfortunately no "undo" though; I'm not sure this is a good thing to have
put in.
  The "until" object has a "float" method which limits the number of bangs
it will output.
  The audio setup is better documented for NT and Linux.
  The externs in 4.fft and 6.externs got recompiled and tested.
  BUG FIX: the "read16" message to tables was broken on NT and is now fixed.
  BUG FIX: In Linux, starting Pd up sometimes changed the audio mixer 
setting.
  BUG FIX: sending "floats" to inlets expecting lists now works correctly.
  BUG FIX: "route" on symbols now deals better with symbols, floats and lists.
 
The main new feature is the "find" menu stuff.  You can search for boxes
containing specified atoms, including semicolons or commas.  Most errors are
now trackable, allowing you to "find last error".  Look in the "Find" menu.
 
New objects written: change, max, max~, min, min~, and swap.
 
I looked in 0.INTRO.txt in 5.reference, and found that the objects 
bag, cputime, realtime, pipe, symbol, poly, and bang were missing.
 
Five or six bug fixes.
 
Some audio problems in 0.25 were addresses.  In Linux, audio drivers that
don't support the GETISPACE/GETOSPACE ioctl calls can be called using the
(inferior) "-frags/-fragsize" mechanism.  If you specify either a "-frags"
or a "-fragsize" option, the GETIOSPACE calls are cancelled.
 
Under NT, for some audio drivers the 0.26 release gave a constant stream of
"resync" events.  I don't know what causes this but I added a "-noresync"
option which simply never resyncs at all.
 
phasor~ and osc~ can be configured to take floating point messages to set
their frequencies,  as an alternative to having an input signal to do the
same.  Also, +~, etc, can take floating point arguments (and messages) to
add or multiply scalars.  THe +~, etc, loops were unrolled to make them
run faster.
 
A switch~ object is provided to let you switch sub-patches on and off.  The
inlet~ and outlet~ objects were re-written to avoid adding any overhead when
moving signals in or out of sub patches.
 
In Linux at least, the audio latency is much reduced.  It's possible to poll
for audio I/O lateness errors by sending "pd audiostatus".
 
When reading a sample using tabread4~, you can switch between sample tables
using the "set" message.
 
A new "textfile" object is like qlist but more flexible.
 
Many help windows got updated (but at least a dozen more need work urgently).
 
A dsp_addv function was added to allow variable-length DSP calls (for writers
of tilde externs.)
 
It's possible for a tilde extern to have a name ending in "tilde" now.  Name
the setup routine "foo_tilde" for "foo~", etc.
 
The dac~ object was fixed to clip its output when out of    range (before it
wrapped around.)
 
A first line of protection was added against getting numerical underflow
in delay feedback loops.  Before, when a reverberator taled out there was
a sudden jump in CPU usage because the numerical underflows would trap to the
kernel.  Now, if any delwrite~ is given a value less than 1e-20 or so, it
records a true zero to avoid this.
 
Signal division checks for divide by zero.
 
A "Font bomb" feature is provided for resizing fonts and stretching and
contracting patches to fit.
 
Pds now bind themselves to the symbol pd-<window-name).
 
IN Linux, if Pd is called as root it tries to promote its run-time
priority.  You can make pd a setuid root owned program if you want this
behavior for non-root users who start pd.
(Don't make pd-gui setuid though.  That would make a security
hole in your system.)
 
The Pd commend line can take multiple "open" arguments.
 
The file search path feature was fixed amd generalized.
 
Alt-clicking a table gives you a dialog to set its x and y range and pixel
size.
 
Lots of minor, under-the-hood improvements and bug fixes...
 
The Netsend/netreceive objects were improved; you can now choose between UDP
and TCP and there's an outlet to tell you whether they're connected.
 
You can now alt click on an object to get its help window (and the help
windows got a fair amount of work.)
 
multichannel audio I/O -- you can get up to 8 audio cnahhelsin and out.
On SGI this is sdone correctly; on NT it's done using sequential "stereo"
devices.  I'm not sure of the status of multichannel in linux...
 
The "text" window got new accelerators and a bigger font size
 
there are 3 "tool" patches in 7.stuff: filtering, pvoc, ring mod.
 
In NT, command-line backslashes are converted to forward slashes.
 
There's a load measurement tool in the "help" menu.
 
The SGI version contains an n32 binary (look at the "bin" directory).
 
new objects:
 
Bug fixes:
 
Arrays can be written to and read from text files or from 16-bit
binary files.  See ../2.starter/2G for an overview.
 
Guenter Geiger has contributed a Max-style "table" object which 
creates an "array" object in a subwindow.
 
Guenter has also put in a "search path" feature for externs, abstractions,
etc.
 
The Help menu got reworked.
 
Select and Route were extended to work Zack-style with symbols.
 
"random" takes seeds now (see the "help" window)
 
Some more work on graphical lists; you can see the current state in
../7.stuff/data-structures.  It's still nascent.
------------------- 0.23 -------------------
 
A first cut at the "pure data" feature is now included.  See section 6
of the documentation for a quick introduction to it; see also patches 12 and
14 in the FFT examples.
 
The documentation has been reorganized.  The most interesting new features are:
 
more bug fixes:
 
The phasor~ object's "float" method has been REMOVED -- use the right-hand
inlet to set the internal phase.  This is so that I can later fix all tilde
objects to convert messages to signals automatically at all signal inputs.
 
bug fixes:
 
table size change with DSP on:  It used to crash Pd to resize an array
when DSP was turned on.  This is now fixed.
 
deselect all when locking.  When you lock a patch the selection is cleared.
 
unlock when pasting.  .. and if you paste into a petch, it's unlocked.
 
lost keyboard events.  Version 0.20 lost keyboard events and
forgot window size changes.  This should now be fixed.
 
new features:
 
In NT, the 0.19 release turned out not to contain all the files needed to make
TCL run.  This problem should now be fixed.
 
Also, the array_write routine was fixed.
 
- an experimental facility for array of floats is included. You can make a new
array (from the "put" menu) which will be given a name such as "array1".  You
can then send it "read <file>", "write <file>", "resize <N>", and "print"
messages.  File reading and writing is in ascii.  "resize" changes the size of
the array, and "print" prints its vital signs.  You can then use "tabread4~"
to do a 4-point interpolating table lookup, and tabwrite~ to write audio
samples into the table.
 
Numbers now default to floating point, although certain objects like "spigot"
and "metro" still convert their boolean inputs to integers so that 0.5 is
"false." This behavior will probably change later.  The "div" and "mod"
objects are introduced for explicit integer division and remainder.
 
Number boxes drag in integer increments, or in hundredths if you hold the
"shift" key down when you click.
 
Pd documents now save their font sizes.  The font size is global to an entire
document.  New documents come up in the font size Pd was started in (using
the "-font" flag.)  If you want to change the font size of an existing
document, use a text editor; the font size is the last argument on the first
line. 8, 10, 12, 14, 16, 18, and 24 are supported.
 
The abbreviations "t," "f," and "i" stand for "trigger,", "float", and "int."
 
Inlets and outlets of subpatches are now sorted correctly; although there is
still a problem deleting inlets/outlets which have connections.
 
The size and screen location of Pd documents is saved correctly.
 
Tilde objects now work in "subpages" although there is no way to send
signals through their inlets and outlets; use throw~/catch~ or send~/receive~.
 
On NT, the default is to open both audio output and input (this used not
to work.)  The situation is still shaky; audio seems to hang up sporadically
on my machine; but I seem to have installed my audio driver wrong anyway.
I had to set a huge output FIFO (1/3 sec or so!) to get it to work at all.
You can type "pd -dac", "pd -adc", or "pd -nosound" to get output only,
input only, or no audio at all.
NT's MIDI input and output are supported, but on my machine MIDI output is
flaky.  I'm curious how all this will work on other machines...
 
The list of classes is now:
 
GENERAL:
field inlet outlet print int float send receive select route pack unpack
trigger spigot moses delay metro line timer makenote stripnote random loadbang
serial get netsend netreceive
 
MATH:
+ - * / == != > < >= <= & && | || %
mod div sin cos tan atan atan2 sqrt log exp abs
mtof ftom powtodb rmstodb dbtopow dbtorms 
 
MIDI:
notein ctlin pgmin bendin touchin polytouchin noteout ctlout pgmout bendout
touchout polytouchout
 
SIGNAL:
dac~ adc~ sig~ line~ snapshot~ +~ -~ *~ /~ phasor~ cos~ vcf~ noise~ env~ hip~
lop~ bp~ biquad~ samphold~ clip~ rsqrt~ sqrt~ wrap~ print~ scope~ tabwrite~
tabread4~ send~ receive~ catch~ throw~ delwrite~ delread~ vd~
 
menu "close" on a dirty document now checks if you really want to close
without saving (although "quit" will still exit Pd without verification.)
 
Got rid of "dll" error printout when loading abstractions
 
- added scope~, which is just a stopgap until real sound editing comes up.
 
fixed "cut" which crashed 0.03 if DSP was running.
added clip~, print~, line~, snapshot~.
 
"pd dsp 1", "pd dsp 0" messages added.  If you edit a patch with DSP on,
PD resorts the DSP network as needed.  Unconnected and multiple signal inlets
are allowed.
 
A DSP network mechanism has been added.  DSP objects are:
sig~, +~, *~, phasor~, cos~.
 
Loading of externs is provided (although there is no search path mechanism
so the extern has to be in the patch's current directory.)  Look in
pd/externs for an example.
 
This first release serves mostly to test the "release" mechanism.  A Pd
"canvas" object is provided which does both graphing and patch editing.
The editing features apply only to the Max-like part; the graphs have
to be edited into a Pd file via text editor.
 
Four menu items (in the "put" menu) create the four kinds of "patchable"
objects; they can be dragged and connected as in Max; to break a connection,
just click on it (the cursor becomes a turkey to indicate this.)  Cut,
paste, and duplicate seem to work, and a "Pd" class offers subwindows.
 
The following max-like objects are included:
    print;
    +, *, -, /, ==, !=, >, <, >=, <=, &, |, &&, ||, %;
    int, float, pack, unpack, trigger;
    delay, metro, timer;
    send, receive.
  -----------------------------------------
  These are now tracked on the
Pd Sourceforge project page.
  It wasn't anyone's intention to make Pd a Max/MSP clone, but on the
other hand, if there's no reason for a feature to appear differently in
Pd than in Max/MSP, the choices in Pd tend to hew to those in Max/MSP.
Moreover, some effort has been undertaken (but more is needed) to make the
two interoperable.
  You can use Pd to import and export patches to Max/MSP; just save as text to
a file with extension ".pat", and then open in the other program.  You'll at
least get something.  If you stick to common or commonizable features you can
actually develop patches for both platforms.  Pd importing of Max patches works
best if you use the Pd Extended package; there are many more compatible objects.
  When specific objects exist on one platform and not on the other, it's
often possible to make abstractions to imitate the missing objects, in a
kind of personalized compatibility library.
  There are, however, differences in semantics you'll want to know about;
a partial list follows.
   abstraction arguments. 
In Pd you can edit instantiations of abstractions and save the result back
to the file of the abstraction.  This isn't possible in Max, because the
instantiations are different from the abstraction itself in that "#1", etc.,
are replaced by the instantiation arguments.  In Pd, these arguments appear
as "$1", etc, and are translated at a slightly later stage of the instantiation
process so that you still see them as "$" variables in the instantiation.
 (see Section 2.7. abstractions) 
  In Pd, to make current all instantiations of the
abstraction, either delete and recreate them or close and open the patch; 
this is done automatically in Max/MSP.
   In Pd, if you select "save" while in a subpatch, the parent is saved. In
Max/MSP, if you do this a dialogue box comes up asking if you want to save the
subpatch as a separate file.  (if you want to save a subpatch to a file in Pd,
you have to copy and paste the contents to a new document.
  In Pd, inlets and outlets are ordinary text objects; in Max/MSP they're
"gui" objects from the palette.
  In Max/MSP, if an object's outlet is connected to several destinations,
corresponding messages are always sent in right-to-left screen order.  In
Pd, the messages are sent in the order you made the connections in.  In either
case, in situations where you care about the order it's appropriate to use
a "trigger" object to specify.
  In Pd, there's no "gate"; instead it's "spigot" with the inlets in the
opposite, more natural order.
  Switching subsets of the DSP patch on and off is done in completely
different ways in Pd and Max/MSP, and block sizes are handled differently as
well.
   Max offers many "GUI" objects such as sliders, dials, VU meters, piano
keyboards, even "bpatchers." Until version 0.34, the only two in Pd were the
number box and graphical arrays.  Starting in version 0.34, Pd incorporates
Thomas Musil's GUI objects: sliders, switches, and so on.  (Thanks Thomas!)
Beyond this essential collection of GUI objects, it's unlikely you'll ever find
any commonality between the two.  Also, as of 0.34, importing and exporting to
Max doesn't know about the Musil objects; I'll try to get that fixed for 0.35.
   In Pd there's no "preset" object (I now think it's basically a bad idea)
and you have to use explicit sends and receives to restore values to number
boxes. Then just make a "message" box to re-send the values you want. 
  In Macintosh land, instead of getting tabosc4~ and arrays, you get cycle~
and buffer~. The only gotcha is that you probably can't draw in buffer~ with
the mouse as you can with arrays, but at least it's possible to 
make a patch that copies a "table" into a "buffer~".
  The "bpatcher" feature in Max has a correlate, "graph on parent" subpatches,
in Pd; however, Pd's version is quite different from Max's.
 
 
 
 
 
 
------------------- 0.32 -----------------
 
 
------------------- 0.31 -----------------
 
 
------------------- 0.30 -----------------
 
 
------------------- 0.29 -----------------
 
 
------------------- 0.28 -----------------
 
 
------------------- 0.27 -----------------
 
 
------------------- 0.26 -----------------
 
 
------------------- 0.25 -----------------
 
 
------------------- 0.24 ---------------
 - bang - convert any message to a "bang"
 - qlist -      message sequencer
 - textfile -   file to message converter
 - makefilename - format a name with a variable field
 - openpanel - "Open" dialog
 - savepanel - "Save as" dialog
 - Fixed a bug in "const" message to arrays
 - "exp" was broken on NT, now fixed
 - phase vocoder example improved
 - "read" message to arrays now zero out unread samples
 - bug fix in "key" object
 - bug fix in ifft~ (thanks to Peter Lunden)
 - "print" object fixed to distinguish between lists starting with symbols and
    other messages 
 - polygon, curve, fpolygon, fcurve renamed to fix name clash with Gem
 - improved "new object" placement on screen
 - fixed help dialog to remember previous directory (thanks to Harry Castle)
 - heterogeneous lists
 - some new "tutorial" patches
 - 15 "fft" examples
 - improved help navigation
 - titles on abstractions no longer saved inside file
 - left-to-right sorting of inlets/outlets now seems to work
 - nt audio setup got confused when driver couldn't do full duplex
 - opening window with audio on is now fixed
 - deleting inlets/outlets deletes connections first (used to crash)
 - 1e20 parsed correctly now
 - osc1~ fixed and optimized
 - resizing arrays with DSP on used to crash; now fixed
 - pasting now adds to the end of the list (used to add to beginning)
 - clicking now selects the most recent object when two or more overlap
 - Pd's "open" and "help" dialogs now maintain separate paths
 
 
------------------- 0.22 -------------------
 
bug fixes
 - parsing 1e+006 gave symbol (now float)
 - "." parsed as number, should be symbol
 - change GUI polling loop to TK event dispatch (unix only)
 - improved "tidy up" feature
 - size check added to text boxes (used to crash; still not correct.)
 - occasional bug sending text with CRs to tk
 - binop startup bug
 - key accelerators for creators wrong
 - ftom range to 1500
 - bug in pack, unpack
 - windows restore bigger than saved
 
 
Nt-specific bug fixes:
 - getsockopt for netreceive fails.  Just omitted it for NT.
 - put tcl dlls in tcl bin, not pd bin
 --- archive tcl subsystem for easier version updates
 --- fix README accordingly
 - deal with bell sound
 - turn on optimization
 - looked for audio timeout bug but couldn't find it.
 
 
------------------- 0.21 -------------------
 subpatches came up in wrong font size
 dirty flag on window title bar fixed
 improvement to netreceive suggested by Mark Danks
 style notes fleshed out as suggested by Larry Troxler
 fixed Bill Kleinsasser's bug (short and long array in same graph)
 phase setting for phasor~
 fft objects.  Also, block~, for specifying block sizes and overlaps for FFTs.
 canvas_makefilename() (used, e.g.,  by array_read and write)
 "stuff" directory with examples of real Pd applications.
 
 
------------------- 0.20 -------------------
 
 
------------------- 0.19 -------------------
notable new objects:
- vcf~, a bandpass filter with a signal input for center frequency.
- delread, delwrite, vd, as in ISPW Max.
- various math and midi stuff
- catch~, throw~, send~, receive~ for nonlocal signal connections
 
 
------------------- 0.18 -------------------
Release notes now descrie the three platforms Pd runs on: IRIX and
NT (maintained at UCSD) and LINUX, maintained by Guenter Geiger.
 
 
------------------- 0.12 - 0.17 -------------------
got Pd running under NT, although driver problems remain.  Gem is also
distributed for both platforms.
 
 
------------------- 0.11  -------------------
Here's a list of all the objects in this release:
general: print int float send receive select pack unpack trigger spigot
time handling: delay metro line timer
arithmetic: + + - - * * / / == == != != > > < < >= >= <= <= & && | || %
midi: notein noteout makenote stripnote
other: random get
signals: dac~ adc~ sig~ line~ snapshot~ +~ *~
signal oscillators: phasor~ cos~
signal filters: env~ hip~
signal debugging : print~ scope~
"spigot" replaces "gate" but has the inputs reversed.
 
 
------------------- 0.10  -------------------
Many bug fixes.  This was the first pre-release to be put on the FTP site.
 
 
------------------- 0.09  -------------------
 set up the "Help" menu
 Bug in DSP sorting fixed
 "Notein" and "noteout" objects
 Comments from the Put menu say "comment" (they were invisible before)
 The scheduler deals better when sound I/O malfunctions
 
 
------------------- 0.08  -------------------
 metro bug
 scrollbars
 scheduler bug
 text box wraparound at 80 chars.
 fixed boxes to reconnect on retype
 
 
------------------- 0.07  -------------------
- made an adc~ object
 
 
------------------- 0.06 -------------------
- fixed two bugs in DSP sorting
- added DSP on/off gui
- added lock/unlock and changed the cursor behavior
- fixed -font flag to set font pointsize
 
------------------- 0.05 -------------------
- improved the open panel slightly.
- added atoms (int only).
- reworked text editing to reside in Pd, not Pd-gui.
- included a dbx-debuggable Pd in the distribution.  I haven't yet figured
    out how to get dbx to work with externs though.
 
------------------- 0.04 -------------------
 
------------------- 0.03 -------------------
 
------------------- 0.02 -------------------
 
------------------- 0.01. -------------------
  5.2. known bugs  
  5.3. differences from Max/MSP