-
-
Notifications
You must be signed in to change notification settings - Fork 6
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
General questions regarding vs-overlay #17
Comments
Thanks for opening this, I wanted to say something about this, but never came around to actually do it. First, I’m sorry for not being able to maintain this and leaving this in the state it is in currently. I added many plugins when I used vapoursynth quite a bit but now I sadly don’t have much time for vapoursynth and maintaining this overlay. As I introduced quite a few of the packages in this overlay, it’s my “responsibility” (at least I feel like it is, because I wrote that code in the first place) to take care of them, so if you have any questions about a specific thing, don’t hesitate to reach out to me. However, as you can probably see from my low activity (not only) in this project, I don’t know if I’ll be able to help you quickly (because most things in here are quite complex, so I have to think about them for some time). I am definitely interested in making sure that vapoursynth in Nix has good infrastructure because its sheer amount of plugins with different variants makes it a prime candidate for packaging with Nix. I’ll quickly address your points, though that is by no means an exhaustive discussion, just what I think of it right now:
In general that is what we want, though many plugin updates have breaking changes, so a way to use older plugin versions would be great (though probably not that easy without evaluating multiple versions of the overlay).
I think addressing this requires cooperation from upstream (maybe some aren’t aware that not versioning causes problems?). Until upstream versions packages, the only thing we can do (AFAIK) is using the latest commit.
That’s right, ideally this could be done as a hook (like how
Yes, Hydra would be nice for ensuring compatibility with the latest nixpkgs version, though I don’t know that much about hydra and if the “legacy” (non-flakes) method will still be supported (or how to implement that with flakes, which normally pin the inputs).
I also though about this but because of the different ways the plugins can be built, I couldn’t figure out how to abstract this (some are plain python, some are python modules with native code, some are just native code (C/C++), some are written in Rust, …).
That’s a very complex problem indeed. Every possible way I could think of (as it is right now, multiple outputs, multiple packages, differentiation in the wrapper) has some downsides, especially because python plugins can depend on native plugins.
I think the withPlugins mechanism is a good way in principle (many packages in nixpkgs are doing it that way), though a separation is probably necessary. But if there is a way to avoid the problems by not using the withPlugins mechanism, I won’t be opposed to it.
That could be done by adding a derivation that runs the tests to
As already said, I probably won’t have the time to thoroughly review them, though it definitely would be great to have an alternative vapoursynth distribution to the de facto standard (AUR).
I also tried packaging that once, but gave up because I didn’t fully understand jupyter (and to an extent python) infrastructure in nixpkgs. |
Thanks for the quick response, I'm definitely gonna look into how the pythonImportsCheck works. Writing test with passthru.tests also seems like something that I'd be able to just make work, but I don't think that would that be useful at this stage. I will report back once I made meaningful progress on something. |
A few more things I wanted to add
To address a few things I mentioned in my original message:
|
Hi - I merged a few PRs recently since they seemed unlikely to break anything, and I couldn't find any issues just reading through the diff. Ideally, it'd be nice to build and test them before merging, but my thinking was that a more up-to-date but possibly more unstable repo would be more useful than a dead one, especially considering flake lockfiles. What do you think about that, @sbruder? Also, since I don't use vapoursynth much anymore, maybe this repository is a good candidate to try to transfer to the nix-community organization. I could look into that. |
Yes, I also think that because users of the overlay can always pin it to a certain revision and should do that anyway (because of breaking changes in vapoursynth plugins). |
@sshiroi since you have disabled issues on your fork I figured I would message you here. |
@compguy284 I only infrequently update nixos-unstable so thanks for pointing it out. I have removed the overriden version and tested rife and w2x and they seem to work. I have also enabled issues (github apparently disables them by default on forks?) so please feel free to report any future problems. I also noticed that vsgan broke and fixed that too, but I'm not sure becauase I don't know poetry. |
I have hit this breakage myself, but I have not yet had the time to properly investigate. |
Sure! |
Latest nixpkgs has checkInputs -> nativeCheckInputs. In this repo atleast acsuite and getnative is affected. |
@sshiroi That sounds significant enough to warrant its own issue. |
I just came across this when updating my fork. Fixing build is easally achieved by putting ffmpeg and imagemagick in nativeCheckInputs. I now also noticed that even if thats fixed this getnative version will still be broken here because latest vapoursynth r60 removed deprecated functions (which is already fixed in upstream getnative). You can create an issue if you want but, I didn't because I'm in a weird situation where I mainly use my fork which has drifted far from upstream that I can't event PR stuff back, so I just though I notify when stuff breaks for me that I know also breaks here.
|
Since I saw activity on this repo again I though I should write about a few things that in my are relevant for discussing.
: Whats the best course of action ignore release and always take a unstable commit?
: I have alread programmed this but I dont't like the implementation
: Maybe some hydra thing sbruder mentioned, or just someone that checks every few week if everything still builds on nixos-unstable
: In my opinion it would be best to transition to a model where all vapoursynth binaryPlugins are collected in some env variable (like PATH or PYTHONPATH) instead of having to build a extra withPlugins derivation with python and vapoursynth stuff combined.
I will continue working on these problems myself, but I think it would be best if someone with more nix/vapoursynth knowledge could comment.
The text was updated successfully, but these errors were encountered: