Files
snack/pacman/capabilities.go
2026-02-28 06:54:28 +00:00

87 lines
2.6 KiB
Go

package pacman
import (
"context"
"github.com/gogrlx/snack"
)
// Compile-time interface checks.
var (
_ snack.VersionQuerier = (*Pacman)(nil)
_ snack.Cleaner = (*Pacman)(nil)
_ snack.FileOwner = (*Pacman)(nil)
_ snack.Grouper = (*Pacman)(nil)
_ snack.GroupQuerier = (*Pacman)(nil)
)
// NOTE: snack.Holder is not implemented for pacman. While pacman supports
// IgnorePkg in /etc/pacman.conf, there is no clean CLI command to hold/unhold
// packages. pacman-contrib provides some tooling but it's not standard.
// LatestVersion returns the latest available version from configured repositories.
func (p *Pacman) LatestVersion(ctx context.Context, pkg string) (string, error) {
return latestVersion(ctx, pkg)
}
// ListUpgrades returns packages that have newer versions available.
func (p *Pacman) ListUpgrades(ctx context.Context) ([]snack.Package, error) {
return listUpgrades(ctx)
}
// UpgradeAvailable reports whether a newer version is available.
func (p *Pacman) UpgradeAvailable(ctx context.Context, pkg string) (bool, error) {
return upgradeAvailable(ctx, pkg)
}
// VersionCmp compares two version strings using pacman's vercmp.
func (p *Pacman) VersionCmp(ctx context.Context, ver1, ver2 string) (int, error) {
return versionCmp(ctx, ver1, ver2)
}
// Autoremove removes orphaned packages.
func (p *Pacman) Autoremove(ctx context.Context, opts ...snack.Option) error {
p.Lock()
defer p.Unlock()
return autoremove(ctx, opts...)
}
// Clean removes cached package files.
func (p *Pacman) Clean(ctx context.Context) error {
p.Lock()
defer p.Unlock()
return clean(ctx)
}
// FileList returns all files installed by a package.
func (p *Pacman) FileList(ctx context.Context, pkg string) ([]string, error) {
return fileList(ctx, pkg)
}
// Owner returns the package that owns a given file path.
func (p *Pacman) Owner(ctx context.Context, path string) (string, error) {
return owner(ctx, path)
}
// GroupList returns all available package groups.
func (p *Pacman) GroupList(ctx context.Context) ([]string, error) {
return groupList(ctx)
}
// GroupInfo returns the packages in a group.
func (p *Pacman) GroupInfo(ctx context.Context, group string) ([]snack.Package, error) {
return groupInfo(ctx, group)
}
// GroupInstall installs all packages in a group.
func (p *Pacman) GroupInstall(ctx context.Context, group string, opts ...snack.Option) error {
p.Lock()
defer p.Unlock()
return groupInstall(ctx, group, opts...)
}
// GroupIsInstalled reports whether all packages in the group are installed.
func (p *Pacman) GroupIsInstalled(ctx context.Context, group string) (bool, error) {
return groupIsInstalled(ctx, group)
}