-
Notifications
You must be signed in to change notification settings - Fork 134
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
Feature request: print current layer #1304
Comments
You can run Kanata with a TCP server and then connect to get the current layer. Example: |
That is certainly a workaround but tbh that is a very convoluted solution for printing the current layout, i do think that should be a basic command. |
It is the intended use case of the TCP server, not a workaround. How would you expect a command like |
I'd expect kanata to have, in ram, the current layout label, kanata --print would then check for a running daemon, and if it finds one, ask that running daemon (probably with dbus) for the layout, or it could just be stored in a file that can be read on demand rather than broadcasted by the daemon. Not sure of the security implications. Alternatively it could setup the tcp server for you, which would also be a lot less work and a lot less confusing. I'd like to know your thoughts on the matter, though, I don't know anything and i'm just talking out my ass to be clear. I'm actually struggling quite a bit to figure out how to do that tcp daemon thing, it's just very complex for what should be rather simple. I also think that since this would be handled completely in ram and not using a filesystem that it would be slightly more performant. |
Run kanata with the
Example bash command and output:
This doesn't feel very complex if you're already planning to do scripting with it. |
That's mostly acceptable, please leave the issue open, a simpler solution that just uses the layer listed in ram would still be a lot faster and have far fewer moving parts in my eyes (plus doesn't this implementation cause writes to the filesystem, meaning it wears down flash storage?) so it would still be preferred, and i'd update to using it if it existed, but that works, thanks! |
There are no filesystem writes, the path here is a "dummy" kernel path used for opening sockets. Like how /dev/input refers to input devices like keyboards. "Uses the layer listed in RAM” isn't a meaningful statement for designing an interprocess communication mechanism, which is what a kanata --print command needs to achieve. |
@jtroo is there even a simple guide of the json stuff I can send and receive for the tcp server also does kanata not support shortcuts |
There is no centralized doc. The best available today is scattered examples in issues/discussions and the source code as reference.
Please stay on topic in issue threads. |
Is your feature request related to a problem? Please describe.
I'd like to be able to, in the cli, print the current layer that is active in kanata, so that I can show the current layer on hyprlock.
Describe the solution you'd like.
kanata --print
(or something like that) should tell me the name of the currently active layer, this would also be helpful for scripting.
The text was updated successfully, but these errors were encountered: