Skip to content
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

command: add unload-input-conf command #15344

Closed
wants to merge 1 commit into from

Conversation

guidocella
Copy link
Contributor

Add a command to remove bindings previously loaded with load-input-conf. This lets you load and then remove an input.conf without relying on deprecated input sections - at least externally, internally it still uses input sections, but this can be changed later without changing the API. This is mainly useful to load different key bindings for images and then restore the regular key bindings when switching to a video.

First, we need to assign key bindings loaded with a load-input-conf to a new input section instead of the default one, because bind_keys() permanently deallocates bindings in the same input section with the same key. This way if you bind a key in input.conf and load and unload another config file which binds the same key, the input.conf binding is restored. enable_section() is split from mp_input_enable_section() to avoid recursive locking.

The input section name is the path of the config file. It is not normalized to not break ~ expansion in parse_config_file().

unload-input-conf then deletes the input section whose name is the path argument. It is basically like the disable-section command. In theory you can also disable other input sections with unload-input-conf, but they are unlikely to clash with filenames with slashes and dots in practice, and it is not worth implementing much validation if we plan to discard input section code later.

Add a command to remove bindings previously loaded with load-input-conf.
This lets you load and then remove an input.conf without relying on
deprecated input sections - at least externally, internally it still
uses input sections, but this can be changed later without changing the
API. This is mainly useful to load different key bindings for images and
then restore the regular key bindings when switching to a video.

First, we need to assign key bindings loaded with a load-input-conf to a
new input section instead of the default one, because bind_keys()
permanently deallocates bindings in the same input section with the same
key. This way if you bind a key in input.conf and load and unload
another config file which binds the same key, the input.conf binding is
restored. enable_section() is split from mp_input_enable_section() to
avoid recursive locking.

The input section name is the path of the config file. It is not
normalized to not break ~ expansion in parse_config_file().

unload-input-conf then deletes the input section whose name is the path
argument. It is basically like the disable-section command. In theory
you can also disable other input sections with unload-input-conf, but
they are unlikely to clash with filenames with slashes and dots in
practice, and it is not worth implementing much validation if we plan to
discard input section code later.
@kasper93
Copy link
Contributor

I'm conflicted about this. Whole unload-input-conf seems like a convoluted way for the simple goal of having multiple input bindings layers.

@guidocella
Copy link
Contributor Author

I would be fine with undeprecating input sections but it was rejected in #14050. So I wrote this as an alternative.

@kasper93
Copy link
Contributor

I would be fine with undeprecating input sections but it was rejected in #14050. So I wrote this as an alternative.

I feel like it is just dancing around this input sections depreciation, achieving the same goal, but with new, "non-deprecated" way.

cc @na-na-hi: Do you think this is better way than exposing input-bindings directly to scripts?

@na-na-hi
Copy link
Contributor

cc @na-na-hi: Do you think this is better way than exposing input-bindings directly to scripts?

I think this PR is exactly input sections in a different name, which certainly doesn't help reducing the complexity of input code.

The current keybind mechanism requiring libmpv clients to use define/enable/disable section commands just to enable and disable key bindings, and all the needed code in mpv to handle them, is cumbersome. It was designed to be used by the player and not the scripts.

Instead, in the future it's better to just forward all input events to clients and let clients handle them, so the key bindings can be controlled by the libmpv clients without needing to interact with mpv. This is how inputs of all window systems (Win32/X11/Wayland/...) work, and how mouse and touch positions work currently. This also makes handling text input much more sensible without depending on hacks like ANY_UNICODE.

@guidocella
Copy link
Contributor Author

How would clients and mpv itself know when not to react to key bindings when only another client should handle them, e.g. not to process key bindings while console is open?

@na-na-hi
Copy link
Contributor

How would clients and mpv itself know when not to react to key bindings when only another client should handle them, e.g. not to process key bindings while console is open?

A client can issue a command to make it the "current focused client" and capture all inputs. Once it's done it releases the capture. It would be simpler to implement than input section since mpv only needs to track which clients are requesting focus and not keybinds.

@guidocella
Copy link
Contributor Author

So e.g. stats which wants to capture only up and down arrows will disable all other key bindings instead?

@na-na-hi
Copy link
Contributor

If a client doesn't handle some keybinds it can forward them to mpv or other clients.

@kasper93
Copy link
Contributor

I don't disagree, but this would be big changes to input system.

@guidocella
Copy link
Contributor Author

Superseded by #15346.

@guidocella guidocella closed this Nov 24, 2024
@guidocella
Copy link
Contributor Author

It should be noted that when you search keybindings in stats there are 2 stacked focused clients; console processes most inputs, stats processes up and down, and mpv core processes the rest. And it is easy to imagine other clients using mp.input.get in this way. So it would not be so easy to replace input sections.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants