Hi Peter,

>I remember that I looked at nam a while ago, but I must admit that I
>didn't get very far with it. When I looked at your page again just now,
>I noticed that the tar ball nam*.tgz has disappeared.

Sorry, my fault. It's up now FWIW.

>In the meantime, I've put together a little MIDI routing module for
>Python and ALSA. I'm tentatively calling it pyseq, and you can find
>it at
>    http://www.math.tu-berlin.de/~brinkman/software/pyseq.tgz
>if you're interested. I'm using ctypes to expose the snd_seq_event
>struct and ALSA functions to Python.

Ah, an interesting little piece of code. There seems to be a memory
leak in startMidiLoop() -- the pfds are never free()'d.

I've been busy too in the meantime and added snd_seq_* support to the
nam successor. Announcement following sometime soon.

>[...] The solution I have in mind is to have Python map MIDI
>control events to X events, which would, in theory anyway, let me
>add MIDI controls to almost any GUI. I have a hunch that this idea
>may not fly in practice, but I'm having fun thinking about it.

Python won't fly supersonic anyway; so as long as you're not expecting
sub-millisecond latency from your MIDI -> X signal path I don't see
why it shouldn't work. However, binding to certain widgets might prove
hard if they don't come with their own X Window ID. In that case,
you'd probably need to build in cross-process support for specific X
toolkits, which may prove more fun to think about than to actually
implement ...

I would like to suggest patching the applications you want to control
to support OSC; it might turn out to be the same amount of work, but
with more public benefit and less dependency on particular widget and
keybinding organisation (which can be a volatile thing). Unless, of
course, you want to control non-music applications, whose authors will
likely show little favour for OSC-enabling patches.

Cheers, Tim

Reply via email to