Greetings! I attempted to see if there was any work or discussion on this, but brought up nothing, I hope I am not duplicating some effort/thought here.I recently developed a small script allowing me to assign ports to groups, using aliases, so that I may autoconnect these groups to ardour buses. However, I quickly discovered there is a limit of two aliases per port, which is admittedly workable, but not pleasantly so. perhaps there is a better method of achieving this functionality? but I wanted to continue using jack-matchmaker.
So I've patched a local copy of jack2 to allocate an array for aliases per port, and allow its size to be specified via the compile time flag --aliases-per-port. However, the implementation is not the best, I needed to introduce a seperate version of jack_port_get_aliases, suffixed with _b, which can be used in conjunction a new function, jack_port_max_aliases, to safely retrieve aliases beyond the first two. applications using the old jack_port_get_aliases will still be shown only the first two aliases in the list. however the matching functions will match against all aliases.
Additionally there is what looks like serialization&matching code in JackDriver, which i have not yet attempted to patch.
I've also patched copys of jack-matchmaker and luajack to make use of this.
I dont imagine such functionality would be accepted into jack in its current state? it seems there is sort of a bind here regarding external api design. I would love to contribute this to jack, so i'm emailing to see what the possibility of that is, and if anyone has any ideas about how to go about it. I am willing to patch jack1 as well for it, the relevant code looks near identical. I would also like to dynamically manage the array size or string memory allocation, perhaps within the limit, as statically allocating even port_num*(alias_limit=8)*name_size to store mostly unused aliases seems rather heavy, but it looked like everything regarding ports is statically allocated for a reason?