Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/Gelio/go-global-update

A command to update globally installed go executables
https://github.com/Gelio/go-global-update

cli go golang update-checker

Last synced: 3 months ago
JSON representation

A command to update globally installed go executables

Awesome Lists containing this project

README

        

# go-global-update

![go-global-update screenshot](https://user-images.githubusercontent.com/889383/161372879-8cf4bd33-ced2-45ad-a27d-888b15ae0dbc.png)

Update globally installed go binaries.

The missing go command similar to `npm -g update` or
[cargo install-update](https://github.com/nabijaczleweli/cargo-update).

## Table of contents

- [Requirements](#requirements)
- [Installation](#installation)
- [Usage](#usage)
- [Upgrading `go-global-update`](#upgrading-go-global-update)
- [Troubleshooting](#troubleshooting)
- [How it works](#how-it-works)
- [Alternative tools](#alternative-tools)
- [Contributing](#contributing)

## Requirements

- Go 1.16 or higher

## Installation

```sh
go install github.com/Gelio/go-global-update@latest
```

## Usage

Running

```sh
go-global-update
```

will print information about currently installed global binaries and attempt to
upgrade those that have newer versions.

You can also do a dry run without update the binaries:

```sh
go-global-update --dry-run
```

or update just a handful of binaries:

```sh
go-global-update gofumpt
```

For more information, see

```sh
go-global-update --help
```

## Upgrading `go-global-update`

`go-global-update` will take care of updating itself when it updates other
binaries.

## Troubleshooting

Do you have problems updating some binaries using `go-global-update`? Take a
look at [TROUBLESHOOTING.md](./TROUBLESHOOTING.md) for more information.

## How it works

`go-global-update` consists of the following steps:

1. Determine binaries to inspect.

Either use the list of provided arguments or all executables installed in
your `go env GOBIN` (or `$(go env GOPATH)/bin`).

1. Inspect where each executable came from (by running
`go version -m [executable name]` and checking the `path`),

1. Check the latest version for each binary using
`go list -m -f "{{.Version}}" [path]`

1. If the binary has a newer version, run `go install [package path]@latest` to
update it.

## Alternative tools

`go-global-update` is not the only tool trying to solve the problem of updating
globally-installed go binaries. The alternatives are:

- [gup](https://github.com/nao1215/gup)

Advantages:

- includes desktop notifications
- has a subcommand to remove a binary
- has a way to export/import a list of binaries

Disadvantages:

- does not offer troubleshooting information when an upgrade fails
- does not report error logs from failed updates
- updates binaries installed from source (potentially overwrites locally-made
changes)

- [binstale](https://github.com/shurcooL/binstale)

Disadvantages:

- seems not to detect globally-installed binaries using go modules

```sh
$ binstale
binstale
(no source package found)
go-global-update
stale: github.com/Gelio/go-global-update (stale dependency: github.com/Gelio/go-global-update/internal/colors)
gofumpt
(no source package found)
gotop
(no source package found)
misspell
(no source package found)
shfmt
```

## Contributing

Contributions are welcome! See [CONTRIBUTING.md](./CONTRIBUTING.md) for more
information.