Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/songmu/goxz
Just do cross building and archiving go tools conventionally
https://github.com/songmu/goxz
Last synced: about 22 hours ago
JSON representation
Just do cross building and archiving go tools conventionally
- Host: GitHub
- URL: https://github.com/songmu/goxz
- Owner: Songmu
- License: mit
- Created: 2017-12-24T13:42:20.000Z (about 7 years ago)
- Default Branch: main
- Last Pushed: 2024-08-30T16:35:10.000Z (4 months ago)
- Last Synced: 2024-12-28T16:13:44.738Z (8 days ago)
- Language: Go
- Homepage:
- Size: 1.9 MB
- Stars: 94
- Watchers: 6
- Forks: 12
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
goxz
=======[![Build Status](https://github.com/Songmu/goxz/workflows/test/badge.svg?branch=main)][actions]
[![Coverage Status](https://codecov.io/gh/Songmu/goxz/branch/main/graph/badge.svg)][codecov]
[![MIT License](http://img.shields.io/badge/license-MIT-blue.svg?style=flat-square)][license]
[![GoDev](https://pkg.go.dev/badge/github.com/Songmu/goxz)][godev][actions]: https://github.com//Songmu/goxz/actions?workflow=test
[codecov]: https://codecov.io/gh/Songmu/goxz
[license]: https://github.com/Songmu/goxz/blob/main/LICENSE
[godev]: https://pkg.go.dev/github.com/Songmu/goxzGO + X (crossbuild) + Z (zip)
## Description
Just do cross building and archiving go tools conventionally
## Installation
% go install github.com/Songmu/goxz/cmd/goxz@latest
Built binaries are available on gihub releases.
You can also install goxz with [aqua](https://aquaproj.github.io/).
% aqua g -i Songmu/goxz
## Concept
- Simple and Lightweight
- Provides `goxc` subset
- only provides cross building and archiving
- No older Go support
- No complicated configuration and behaivors
- convention over configuration## Synopsis
```console
# in your repository
% goxz -pv 0.0.1 -os=linux,darwin -arch=amd64 ./cmd/mytool [...]# archives are built into `./goxz` directory by default (configurable by `-d` option)
% tree ./goxz
goxz/
├── yourapp_0.0.1_darwin_amd64.zip
└── ...
```## Included resources
following files are included to archives automatically.
- `LICENSE*`
- `README*`
- `INSTALL*`
- `CREDIT*`
- `CHANGELOG*`You can specify additional resources by using `-include` option.
## Archive naming specification
`{{Package}}_{{Version}}_{{OS}}_{{Arch}}.{{Ext}}`
or
`{{Package}}_{{OS}}_{{Arch}}.{{Ext}}`- `{{Package}}`
- directory name of the project by default
- you can specify it with `-n` option
- `{{Version}}`
- When the version is specified by `-pv` option, that is contained in archive name
- `{{Ext}}`
- `.zip` is by default on "windows" and "darwin", `.tar.gz` is by default on other os.
- use `-z` option to use zip always to compress.
- No file naming notations are available yet
- ref. goxc: `{{.ExeName}}_{{.Version}}_{{.Os}}_{{.Arch}}{{.Ext}}`## Options
- `-d` destination directory (`./goxz` by default)
- `-n` application name. by default the directory name is used.
- `-os` linux,darwin and windows by default
- `-arch` amd64,arm64 by default
- `-pv` for speicifing version (optional)
- `-o` output filename
- not available with multiple package building
- `-z` to use zip always to compless
- by default, zip is used on "windows and "darwin", tar.gz is used on other OS
- `-include` Include additional resources in archives
- `-build-ldflags` / `-build-tags`## Author
[Songmu](https://github.com/Songmu)