It seems to me that a particular git “state” is indicated (the git-tree-sha1). If that is correct, and this requests one particular state of the repo on the master, how do I always get the latest version from that git repo instead?
As far as I understand, the Manifest.toml file does not specify the project requirements, but rather states the exact versions of packages in the project as you have it instantiated. Package requirements are instead listed in the Project.toml.
If nothing is mentioned about that package in the [compat] section of Project.toml then I guess any version is admissible. In any case, if you simply invoke
] up
from the REPL when the environment is active, you’ll get the latest compatible (as prescribed by Project.toml) version of all packages.
That was really my point: The Manifest file instructs Julia to install one particular commit of the H2Libjl package. When I run ]up I do get an update from the H2Libjl library in the form of the latest commit. I would like to get that latest commit by default by specifying THAT in the Manifest file. Does it make sense?
I would just like to get the latest commit of H2Libjl by specifying that it is the latest commit in the Manifest file. Obviously I will not know the sha. I would like to say “get me the latest”, so that I don’t have to do “update” on that package.
I think the Manifest is not to be touched directly, it just lists what is there. When you update a package in the environment, the corresponding lines in the Manifest will be updated.
When instantiating an environment, the package versions are taken from the Manifest (with their exact version) if present, and from the Project (latest compatible version) otherwise.
So I would say, just keep the Manifest local to your environment and don’t share it, so whoever fetches your project and instantiates it (which may be yourself too) will get the latest versions of packages.
My motivation really was to share the Manifest file so that everyone who collaborated on the project would get precisely the same versions of the packages as everyone else.
Except that for the library H2Libjl I would like everybody to get the latest commit, not just some particular fixed commit in the past.
I see. Then my guess is that you should be fixing the versions in the Project files using the compat section, and leaving that particular one unbounded.