On Sat, Feb 19, 2011 at 07:49:09PM +0000, Pedro Lopes wrote:
> >yes, this is known.
> By known you mean.. Is it on the bug tracker already?

As Cyrille wrote, it's not a bug, but a feature: Usually when you use an
abstraction in your patch and you load that patch, everything inside of that
abstraction is loaded first, including its loadbangs, then the surrounding
patch goes through its own loadbangs. Normally you don't recognize this, but
the order becomes important, when the abstraction sends something to the
surrounding patch for example through its outlet. Then the rule is: First the
abstractions sends through the outlet, possibly influencing stuff in the main
patch, then the main patch loadbangs. See the attachement "main.pd" for an
illustration of this behaviour.

Now dynamic patching basically is the same as loading a patch: The messages are
almost the same, only now they get sent to a [pd something] subpatch-receiver
instead of to Pd's internal objectmaker. You can see this in the second
example, main-dynamic.pd, whic just patches the contents of main.pd into a
subpatch.

The important difference is the handling of loadbangs: If an abstraction like
[lb-abs] would execute its loadbang immediatly, then it would bang to an
outlet, that is not yet connected!  So in the end your result would be
different from the result you get when loading main.pd, although it's the same
construction. 

To overcome this ambiguity, loadbanging in dynamic patching is an explicit
action: You have to initiate the loadbangs at an appropriate time that you
decide on your own. Ususally it's fine to do that by sending a "loadbang"
message at the end of your dynamic patching cycle, to the same receiver. This
way also the execution order of the construct you've build will be preserved in
execution of the loadbangs and initialisation.

> When such things are discovered (and by things I mean issues), shouldn't
> they be documented inside the help patches?

There are no official help patches for dynamic patching, only the tutorial
floating around somewhere, which I can't find ATM. The loadbang explanation
should probably be inside of this, if it isn't already.

Ciao
-- 
 Frank Barknecht            Do You RjDj.me?          _ ______footils.org__

Attachment: dynamic-loadbang.tgz
Description: GNU Unix tar archive

_______________________________________________
Pd-list@iem.at mailing list
UNSUBSCRIBE and account-management -> 
http://lists.puredata.info/listinfo/pd-list

Reply via email to