On Mon, Apr 9, 2012 at 9:03 AM, Fons Adriaensen <fons@linuxaudio.org> wrote:
On Mon, Apr 09, 2012 at 05:27:54PM +0200, rosea.grammostola wrote:

> Personally I saw it as an advantage of JackSession, that it has JACK
> involved and that it only needs the JACK dependency. After the comments
> by Fons and by trying NSM myself, I think that it is an advantage of NSM
> instead, that it is independent of JACK. It's more easy to add apps
> without JACK support to the session and to keep apps with JACK support
> outside the session (by purpose). It gives you as a user more freedom
> and flexibility overall and so I think it's a better design choice.
> These advantages out weights the disadvantage of having one extra
> dependency to support NSM (liblo).

Liblo is *not* a dependency of any app using NSM. Since the NSM protocol
specifies the actual messages, an app can send an receive them whatever
code or library the developer prefers. In fact NSM does not add any
dependencies at all.


To ensure things stay like that, I'd like to see the following
added to the NSM specs:

* All communication is done using simple OSC messages,
* i.e. without using bundles or wildcards.

That way even the most basic OSC support would be enough to
use NSM. And with the protocol as it stands, nothing is lost.


This is true. Liblo is not a hard dependency. Anything that can send/receive OSC messages should work. It definitely doesn't use wildcards and I haven't actually found a use for OSC wildcards yet period, so I don't have a problem with officially avoiding them. Bundles are useful for some things (especially when delivering a list like response, because OSC has no more obvious way to indicate 'end of list'), and aren't very complicated at the stream level (just ordinary messages preceded by something that says, 'hey, this is a bundle of such and such length'), but, yeah, I don't have any idea how many of the OSC implementations out there support them. With liblo, it's only *generating* the bundle that is complicated. Receiving it is easy.The lowest common denominator here (that people are likely to actually use) is probably the Python OSC implementation. And, anyway, the current implementation doesn't use them for anything (if it did, it would probably use them for the session list response [not something most clients will even use] and the announce response/open pair [all clients use this one]).