-
Notifications
You must be signed in to change notification settings - Fork 1.5k
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
Support for "or" dependencies. #1789
Comments
In the Linux world (at least in Gentoo) I've seen "virtual packages" that don't actually install anything but rather have something similar to this kind of "or" dependencies and are considered installed if any of the referenced packages is installed. For example, a virtual "editor" package that is considered installed if vim, emacs or any other editor is installed. Maybe we could do something similar to that. In your example, we could have a virtual VisualStudio package that is seen as installed if any version of Visual Studio is installed, and then have ReSharper and any other tool depend on that single package. The part of checking for any of multiple installed packages could probably use some of the work for multiple ARP entries. |
We've also looked at the "provides" / "consumes" model implemented in some package managers. I think it gets a bit messy though. Virtual Packages also could be problematic. with the PackageDependencies, we could have a - OneOfTheFollowing key that contains an array. Without knowing full compatibility for a Virtual Package, the array could at least help ensure the dependent package works for those cases where one of the providers isn't compatible. I tend to think of Java Runtime Environments as one of the best examples for this scenario. |
Just going through all the feature requests and re-reading them; I think one way to ease the complexity here could be to take advantage of the package identifier split character, where This doesn't solve the need / desire for |
Wildcard dependencies would be interesting, but I'm afraid that if someone added something that fit the wildcard but didn't fit the dependency we could introduce regressions, like if |
I think the "or" case is probably still better due to the nature of the nested structure of packages. What if Visual Studio reorganizes themselves like: Microsoft.VisualStudio.Community.2019 Taking the Dependency on "Microsoft.VisualStudio" might not work if 2022 was needed. Virtual packages might work for something like Python where we could say: Python.Python - take the latest version of all child packages. It would depend on the logical structure. Since we don't have good logic for channels yet when things can be installed side by side, or the user and machine versions can both be installed, I'd be cautious. |
Description of the new feature / enhancement
I would like to be able to express that multiple different packages could be used to fufill a dependency. If an application relies on the OpenJDK, it is unlikely that it would rely on a specific vendor's implementation, and we shouldn't install a different version if the user already has one. Similarly, ReSharper (and other developer tools) rely on any version of Visual Studio being installed, but under the current system we could only express a single version and edition combination.
Proposed technical implementation details
One implementation could be that the dependencies key in the manifest could accept arrays of package id/version combinations in addition to single dependencies, where any value in the array would satisfy the dependency. For example:
The YAML "array of arrays" syntax isn't awesome, so maybe this isn't the best method.
The text was updated successfully, but these errors were encountered: