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

admit prescribing a package version ... #847

Merged
merged 2 commits into from
Dec 2, 2022
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions CHANGES.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,9 @@

- Silence scary warning about missing compiler
- Prepare for an upcoming change to serialization in Julia 1.10
- `Packages.install` and thus also `Packages.load` with argument
`install = true` admit prescribing a version number of the package
to be loaded/installed

## Version 0.9.1 (released 2022-11-23)

Expand Down
86 changes: 52 additions & 34 deletions src/packages.jl
Original file line number Diff line number Diff line change
Expand Up @@ -61,16 +61,20 @@ end
"""
load(spec::String, version::String = ""; install::Bool = false, quiet::Bool = true)

Try to load the newest installed version of the GAP package with name `spec`.
Try to load the GAP package with name `spec`.
If `version` is specified then try to load a version of the package
that is compatible with `version`, in the sense of
[GAP's CompareVersionNumbers function](GAP_ref(ref:CompareVersionNumbers)),
otherwise try to load the newest installed version.
Return `true` if this is successful, and `false` otherwise.

The function calls [GAP's `LoadPackage` function](GAP_ref(ref:LoadPackage));
the package banner is not printed.

If `install` is set to `true` and the required GAP package is not yet
installed then [`install`](@ref) is called first, in order to install
the newest released version of the package.
If `install` is set to `true` and (the desired version of) the required
GAP package is not yet installed then [`install`](@ref) is called first,
in order to install the package;
if no version is prescribed then the newest released version of the package
will be installed.

The function calls [GAP's `LoadPackage` function](GAP_ref(ref:LoadPackage)).
If `quiet` is set to `false` then package banners are shown for all packages
being loaded. It is also passed on to [`install`](@ref).
"""
Expand All @@ -81,11 +85,21 @@ function load(spec::String, version::String = ""; install::Bool = false, quiet::
loaded = Globals.LoadPackage(gspec, gversion, !quiet)
if loaded == true
return true
elseif Globals.IsPackageLoaded(gspec)
# Another version is already loaded.
# Perhaps we could install the required version,
# but then we would not be able to load it into the current session
# and thus in any case `false` must be returned.
# It would be a strange side effect if the required version
# would afterwards be loadable in a fresh Julia session,
# thus we do not try to install the package here.
return false
elseif install == true
# Try to install the package, without showing messages.
if Packages.install(spec; interactive = false, quiet)
# Try to install the given version of the package,
# without showing messages.
if Packages.install(spec, version; interactive = false, quiet)
# Make sure that the installed version is admissible.
return Globals.LoadPackage(gspec, gversion, !quiet)
return Globals.LoadPackage(gspec, gversion, !quiet) == true
end
end

Expand All @@ -95,49 +109,53 @@ function load(spec::String, version::String = ""; install::Bool = false, quiet::
end

"""
install(spec::String; interactive::Bool = true, quiet::Bool = false,
install(spec::String, version::String = "";
interactive::Bool = true, quiet::Bool = false,
pkgdir::AbstractString = GAP.Packages.DEFAULT_PKGDIR[])

Download and install the newest released version of the GAP package
given by `spec` into the `pkgdir` directory.
Return `true` if the installation is successful or if the package
was already installed, and `false` otherwise.
Download and install the GAP package given by `spec` into the `pkgdir`
directory.

`spec` can be either the name of a package or the URL of an archive or repository
containing a package, or the URL of a `PackageInfo.g` file.

If `spec` is the name of a package then the package version can be
specified by `version`, in the format described for
[GAP's CompareVersionNumbers function](GAP_ref(ref:CompareVersionNumbers)).
In all other cases the newest released version of the package will get
installed.

Return `true` if the installation is successful or if
(a version compatible with `version`) of the package was already installed,
and `false` otherwise.

The function uses [the function `InstallPackage` from GAP's package
`PackageManager`](GAP_ref(PackageManager:InstallPackage)).
The info messages shown by this function can be suppressed by passing
`true` as the value of `quiet`. Specifying `interactive = false` will
prevent `PackageManager` from prompting the user for input interactively.
For details, please refer to its documentation.
"""
function install(spec::String; interactive::Bool = true, quiet::Bool = false,
function install(spec::String, version::String = "";
interactive::Bool = true, quiet::Bool = false,
pkgdir::AbstractString = DEFAULT_PKGDIR[])
# point PackageManager to the given pkg dir
Globals.PKGMAN_CustomPackageDir = GapObj(pkgdir)
mkpath(pkgdir)

try
#T When a new PackageManager version will be available,
#T this try/catch is no longer necessary,
#T because no GAP error is thrown when one is offline or so.
if quiet
oldlevel = Globals.InfoLevel(Globals.InfoPackageManager)
Globals.SetInfoLevel(Globals.InfoPackageManager, 0)
res = Globals.InstallPackage(GapObj(spec), interactive)
Globals.SetInfoLevel(Globals.InfoPackageManager, oldlevel)
return res
else
return Globals.InstallPackage(GapObj(spec), interactive)
end
catch e
if ! quiet
println( "cannot install $spec:\n$e")
end
return false
if quiet
oldlevel = Globals.InfoLevel(Globals.InfoPackageManager)
Globals.SetInfoLevel(Globals.InfoPackageManager, 0)
end
if version == ""
res = Globals.InstallPackage(GapObj(spec), interactive)
else
res = Globals.InstallPackage(GapObj(spec), GapObj(version), interactive)
end
if quiet
Globals.SetInfoLevel(Globals.InfoPackageManager, oldlevel)
end
return res
end

"""
Expand Down