-
Notifications
You must be signed in to change notification settings - Fork 3
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Linux support #5
Comments
Happy to provide it! All for Linux support, and the only reason it's not currently supported is because I haven't gotten to it yet.
Changing label to enhancement as Linux isn't official supported |
I have the same client number on two different machines (other is Ubuntu), so it's relatively stable, but I think option to select the driver should be more comprehensive. For improved UX, some default suggestions could be done by pattern matching.
|
And I think I have a fix for 2. However, one thing that doesn't seem to fully work is loading configurations. I'm missing at which point the device initialization is called? Or how it's supposed to work? My expectation is:
What I have to do is:
Is it expected behavior? |
Your expectation is how it works on my end (on OSX). If by device initialization, you mean running the control sequence and updating light states, that happens PortService.updatePorts. Each time updatePorts() is called, it reconciles devices which are configured in the current project (either by adding a device or loading a .controller file) against what ports are available. If a port is available and not yet connected, it will open the connection and run the control sequence and load initial light config. Update ports is called when SC detects a change in the available midi ports (disconnect or new connection), and also twice in background.ts. Keeping track of available MIDI devices is... a fun challenge. Especially with > 1 devices connect of the same model. My best bet as to why you need to add the device first is because loading the configuration file isn't opening the connection to the hardware ports, but by first adding to project, you're able to open them prior to loading the config. Lots of entropy here though, so this is a shot in the dark. |
Some googling seems to confirm that My main question then would be - how does multiple midi devices affect this? Multiple devices of same model? |
I believe the client numbers are just incremented for the consequent devices. I have some vague memory, that I was disconnecting midi-keyboard when it was still used, so that the port wasn't properly closed, and on reattaching there were port numbers like 21 and 22. But I don't think it matters much, the part with the client number can be just stripped away, keeping the name and the subport number. |
I found the problem why it wasn't initialized -- there was a null pointer exception in my code which wasn't reported anywhere for some reason. I'll clean the changes and make a pull request a bit later. |
There is an interesting thread on midi port names in Linux, in particular this message is informative: https://linuxmusicians.com/viewtopic.php?p=147380#p147380 In short, I wouldn't rely on any particular naming scheme, as apparently it can be changed with kernel updates. |
I created a pull request with working version, but for a full support there is still need and option to select driver manually. Could you implement it? I hope it shouldn't be hard but it would require a bit more global changes: configuration would need to include the driver name, not just a device name. |
And another thing: does "Save As" dialog on macOS adds file extension automatically? For me I have to manually append ".controller". |
Thanks for your work! Looking forward to checking it out. should be easy to implement, will try to hit it this week on osx, .controller is prepopulated in the dialog |
Added the bits you'll need in 8eb2585
Can you confirm that everything looks right on your os? I had everything inverted so I could test UI elements on osx. Should have reinverted everything correctly though. Also, would you confirm that message propagation work correctly for both named drivers and anonymous drivers (using the translator function)? Thanks |
Thanks for the quick work! I had a major problem though: my mk3 is not initialized for some reason. The control sequence seem to be sent, but there is no response from the device. It should both change light stats physically, as well as to respond with some messages, neither of which happens. Do you have any ideas what could happen? Also one relatively minor thing appeared: the port names don't fit into the left panel, so I can't see which of the ports is |
@aolsenjazz I've figured out what was the problem. The https://github.com/aolsenjazz/super-controller/blob/dev/src/main/port-service/port-manager.ts#L44 -- here the driver is looked up by the port name, which does not work on linux. I was able to make it work by setting the proper driver just before
I guess this can be the way to go, and actually the driver can be set to null first in |
Thanks for looking into this! Given the decoupling of drivers and config, it doesn't seem like good design to have ports and drivers coupled anymore imo; it makes more sense to me to look up drivers via the Also, opened #8 to make sure that doesn't slip thru cracks |
Hi, nice piece of software!
However, I had troubles running it on my Linux machine (Debian 12). What are you thoughts on Linux support?
More precisely, here are my issues:
On Linux I have different names for the ports, for example my Novation Launchkey Mini MK3 has the following two ports:
Launchkey Mini MK3:Launchkey Mini MK3 Launchkey Mi 20:0
andLaunchkey Mini MK3:Launchkey Mini MK3 Launchkey Mi 20:1
, as opposed toLaunchkey Mini MK3 MIDI Port
andLaunchkey Mini MK3 DAW Port
in the driver names. I had to adjust the names in the sources of the drivers to make it work. I guess some way to select the driver manually for the port should be useful.There is a resource leakage, as Node rtMidi can't properly close unused connections: Creating midi.input() instances can cause ALSA to run out of resources justinlatimer/node-midi#118 As a woraround I had to change polling interval to 1000 seconds. I guess the proper fix would be to create new
midi.Input()
/midi.Output()
only when needed, not on everyupdatePorts()
.I couldn't figure out how to save/restore configuration properly. Should be there some menu? I have none. I only have a suggestion to save session when I close the application, and don't see any way to restore it.
The text was updated successfully, but these errors were encountered: