5
0
mirror of https://github.com/wailsapp/wails.git synced 2025-05-02 22:31:06 +08:00
wails/v2/internal/system/packagemanager/packagemanager.go
Ian M. Jones 82cc5498f1
Add nixpkgs support to doctor command. (#1551)
* Dependancy => Dependency typo fix.

* Add Nixpkgs support to doctor command.

* Add mention of nixpkgs to linux distro support doc.
2022-07-13 07:29:41 +10:00

163 lines
3.5 KiB
Go

//go:build linux
// +build linux
package packagemanager
import (
"sort"
"strings"
"github.com/wailsapp/wails/v2/internal/shell"
)
// A list of package manager commands
var pmcommands = []string{
"eopkg",
"apt",
"dnf",
"pacman",
"emerge",
"zypper",
"nix-env",
}
// Find will attempt to find the system package manager
func Find(osid string) PackageManager {
// Loop over pmcommands
for _, pmname := range pmcommands {
if shell.CommandExists(pmname) {
return newPackageManager(pmname, osid)
}
}
return nil
}
func newPackageManager(pmname string, osid string) PackageManager {
switch pmname {
case "eopkg":
return NewEopkg(osid)
case "apt":
return NewApt(osid)
case "dnf":
return NewDnf(osid)
case "pacman":
return NewPacman(osid)
case "emerge":
return NewEmerge(osid)
case "zypper":
return NewZypper(osid)
case "nix-env":
return NewNixpkgs(osid)
}
return nil
}
// Dependencies scans the system for required dependencies
// Returns a list of dependencies search for, whether they were found
// and whether they were installed
func Dependencies(p PackageManager) (DependencyList, error) {
var dependencies DependencyList
for name, packages := range p.Packages() {
dependency := &Dependency{Name: name}
for _, pkg := range packages {
dependency.Optional = pkg.Optional
dependency.External = !pkg.SystemPackage
dependency.InstallCommand = p.InstallCommand(pkg)
packageavailable, err := p.PackageAvailable(pkg)
if err != nil {
return nil, err
}
if packageavailable {
dependency.Version = pkg.Version
dependency.PackageName = pkg.Name
installed, err := p.PackageInstalled(pkg)
if err != nil {
return nil, err
}
if installed {
dependency.Installed = true
dependency.Version = pkg.Version
if !pkg.SystemPackage {
dependency.Version = AppVersion(name)
}
} else {
dependency.InstallCommand = p.InstallCommand(pkg)
}
break
}
}
dependencies = append(dependencies, dependency)
}
// Sort dependencies
sort.Slice(dependencies, func(i, j int) bool {
return dependencies[i].Name < dependencies[j].Name
})
return dependencies, nil
}
// AppVersion returns the version for application related to the given package
func AppVersion(name string) string {
if name == "gcc" {
return gccVersion()
}
if name == "pkg-config" {
return pkgConfigVersion()
}
if name == "npm" {
return npmVersion()
}
if name == "docker" {
return dockerVersion()
}
return ""
}
func gccVersion() string {
var version string
var err error
// Try "-dumpfullversion"
version, _, err = shell.RunCommand(".", "gcc", "-dumpfullversion")
if err != nil {
// Try -dumpversion
// We ignore the error as this function is not for testing whether the
// application exists, only that we can get the version number
dumpversion, _, err := shell.RunCommand(".", "gcc", "-dumpversion")
if err == nil {
version = dumpversion
}
}
return strings.TrimSpace(version)
}
func pkgConfigVersion() string {
version, _, _ := shell.RunCommand(".", "pkg-config", "--version")
return strings.TrimSpace(version)
}
func npmVersion() string {
version, _, _ := shell.RunCommand(".", "npm", "--version")
return strings.TrimSpace(version)
}
func dockerVersion() string {
version, _, _ := shell.RunCommand(".", "docker", "--version")
version = strings.TrimPrefix(version, "Docker version ")
version = strings.ReplaceAll(version, ", build ", " (")
version = strings.TrimSpace(version) + ")"
return version
}