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

major changes #9

Open
wants to merge 17 commits into
base: main
Choose a base branch
from

Conversation

calestyo
Copy link
Contributor

@calestyo calestyo commented Oct 7, 2023

Hey.

Sorry for not splitting this up in more branches (was lazy), but at least the changes are all split up nicely in small commits.

Please check them and merge :-)

Thanks,
Chris.

Signed-off-by: Christoph Anton Mitterer <mail@christoph.anton.mitterer.name>
Signed-off-by: Christoph Anton Mitterer <mail@christoph.anton.mitterer.name>
Signed-off-by: Christoph Anton Mitterer <mail@christoph.anton.mitterer.name>
Signed-off-by: Christoph Anton Mitterer <mail@christoph.anton.mitterer.name>
Previously, a fallback would have only happened, when either `hash` was disabled
or the `hash()`-function failed, but not when only the (hash) file didn’t exist.

Signed-off-by: Christoph Anton Mitterer <mail@christoph.anton.mitterer.name>
Clarify that no parameter or tilde expansion happens and that absolute pathnames
are required.

Also do that actually in the example value (which users may just uncomment) by
no longer using `$HOME` but rather a value where typically no write permissions
should exist.

Signed-off-by: Christoph Anton Mitterer <mail@christoph.anton.mitterer.name>
Signed-off-by: Christoph Anton Mitterer <mail@christoph.anton.mitterer.name>
This commit adds another option `global_chapters_by_xattr`, which, if enabled,
causes an XATTR of the media files to be used for determining the name of the
global chapters file.

The idea is, that all media files have an XATTR set that contains some kind of
ID (like a hash value of the file or some MusicBrainz ID) that is unique for
each media file.

In contrast to the current `hash`-option this has some advantages:
- The hash value doesn’t need to be recalculated every time.
- With the `hash`-option, the hash value is calculated from the media file’s
  pathname.
  If this changes (for example, when the file is moved), the chapters file can’t
  be found anymore. If another file is moved to the pathname from a previously
  moved/deleted file, a wrong chapters file would be used for it.
  The XATTRs aren’t affected by this.

Because the XATTR method seems less fragile then the method that hashes the
pathname, it was given higher priority.
But a user can simply not enable it and only use the latter.

Future enhancements could allow to select multiple XATTRs (either one after one
or combining their values into one ID).

Fixes: 6
Signed-off-by: Christoph Anton Mitterer <mail@christoph.anton.mitterer.name>
Unfortunately `getfattr` doesn’t use proper exit statuses (see attr bug #33417
(https://savannah.nongnu.org/bugs/index.php?33417)) so one needs to match the
error message.
For that reason, `LC_ALL` is set to `C` (for the `getfattr` process only) in
order to get the same error message, regardless of the user’s locale.

Signed-off-by: Christoph Anton Mitterer <mail@christoph.anton.mitterer.name>
Previously, the trailing newline of strings read from other processes’ standard
output was stripped off by searching for *all* newlines in the string and
removing them.

While command names should typically not contain newlines, media fails may do
and so their “corrected” pathnames would have not pointed to the actual file.

This commit fixes this by properly stripping of the final character from
standard output (assuming it to be a newline).

Fixes: 8
Signed-off-by: Christoph Anton Mitterer <mail@christoph.anton.mitterer.name>
This is in order to align it to the previously added `global_chapters_by_xattr`-
option and to make it more clear that it will only affect global chapters.

Signed-off-by: Christoph Anton Mitterer <mail@christoph.anton.mitterer.name>
Signed-off-by: Christoph Anton Mitterer <mail@christoph.anton.mitterer.name>
Currently this option disables both, reading and writing, at once. Future
changes could allow to configure this separately.

Signed-off-by: Christoph Anton Mitterer <mail@christoph.anton.mitterer.name>
Signed-off-by: Christoph Anton Mitterer <mail@christoph.anton.mitterer.name>
Signed-off-by: Christoph Anton Mitterer <mail@christoph.anton.mitterer.name>
Signed-off-by: Christoph Anton Mitterer <mail@christoph.anton.mitterer.name>
Previously, this script was a single file `chapters.lua`, to be placed in the
mpv script directory `~/.config/mpv/scripts`.

This commit changes this to use the mode, where a subdirectory of the mpv script
directory “belongs” to the whole script.

In that mode, the script’s name is determined by the subdirectory’s name.
And the script’s main file must be named `main.lua`.

The reason for this change is the 2nd part of this commit, which changes the
default location for the global directory to be the (dynamically determined)
script directory (i.e. the one that also contains `main.lua`).

This has the benefit, that we can write chapter files in that directory, without
fearing to clash with other scripts.
Since all chapter files get the extension `.ffmetadata`, there should be no
danger of accidentally having them interpreted by mvp or clash with our own
script file.

Signed-off-by: Christoph Anton Mitterer <mail@christoph.anton.mitterer.name>
@calestyo
Copy link
Contributor Author

calestyo commented Oct 7, 2023

Oh, this PR would fix #6 and #8.

mar04
mar04 previously approved these changes Oct 9, 2023
@mar04
Copy link
Owner

mar04 commented Oct 9, 2023

Could you split those into cosmetic fixes, that xattr thing and bug fixes? I would merge some of those commits right away, others I would like to test first when I have some more time.

@calestyo
Copy link
Contributor Author

calestyo commented Oct 9, 2023

Could you split those into cosmetic fixes, that xattr thing and bug fixes? I would merge some of those commits right away, others I would like to test first when I have some more time.

Uhm... well if it really really really needs to be, cause otherwise you wouldn't consider for merging it.

The problem is that disentangling this will not be quite a mess as at least some commits touch the same places, IIRC.

That's partially the reason why I hadn't made proper branches for each bigger topic, cause they'd get just merge conflicts if they were first made all on master.

Can't you just go through one by one from the earliest commit and merge one after another as soon as you find time for testing each?

I think every commit should leave master in a consistent state and not depend on subsequent ones, so one-by-one-should be doable.

@mar04
Copy link
Owner

mar04 commented Oct 14, 2023

Ok, I went through the commits:
1, 2, 4 - 7 - OK
8, 9 - separate pull request
10 - separate pull request

3, 12 - drop, I don't like the changes
15, 16 - drop, I like how it works right now
11, 17 - drop, we are not changing option names or anything that would break existing users' setups

@mar04 mar04 dismissed their stale review October 14, 2023 18:01

change

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.

2 participants