-
Notifications
You must be signed in to change notification settings - Fork 8
Description
Following from #24 (which we cannot rely upon packages following semver unfortunately) I have hit several other issues thinking about this. I think we need to clarify this before #24 and starting an uninstall feature.
How do we want to support multiple versions?
some points:
- There can only be one version linked in
/usr/local/binusing the packages name. Do we make it the highest version installed? how to run other versions? - make symbolic links for
/usr/local/bin/package-version/usr/local/pkgs/package folder/version/package-bin - 2 above this would have to be done with other binaries in a package if they are made available. (pkgx. ‘provides:’ ?)
- 1 and 2 would also have to be done with libraries on
/usr/local/lib - If we want to support multiple versions how would this work with upgrades, upgrade only x or x.x what about patch versions ?
- How to keep versions we want to keep? Add a pin feature to stop upgrading and pruning of certain installed versions?
- do we want to be able to switch default version e.g change the symbolic link on
/usr/local/bin/package - How to deal with packages and versions removed from the pantry
As you can see this starts to become very messy and increases complexity.
Perhaps we only should have one version for each package or perhaps only the major or major and minor?
or perhaps only allow multiple versions for certain packages?
With libraries I would hope that libraries would be on path in the env and /usr/local/lib is just a fallback.
But we would have to think about this because its probably more likely that we want multiple versions of libraries.
Will pkgx's pantry be keeping multiple versions of everything?
I doubt it, maybe libraries, compilers and interpreters for an extended period of time.