Igo is a powerful cross-platform command-line interface tool designed for building and packaging Go projects. It provides seamless integration with Go's build system while adding advanced packaging capabilities for Windows, macOS, and Linux platforms.
- Cross-Platform Support: Build for Windows, macOS, and Linux from any platform
- Flexible Configuration: YAML-based configuration with variable substitution
- Multiple Output Formats: Generate binaries, ZIP, TAR, and TAR.GZ packages
- Go Command Integration: Extends Go's run, build, and other commands
- Customizable: Support for custom configuration variables and build rules
- Progress Tracking: Visual progress indicators for long-running operations
- Go 1.21 or later
- Git
# Clone the repository
git clone https://github.com/qwqxl/igo.git
cd igo
# Build the tool
go build -o igo main.go
# Install globally (optional)
go install
go install github.com/qwqxl/igo@latest
# Initialize with default configuration
igo init
# Initialize with custom config name
igo init my-config
This creates a igo.yaml
configuration file with default settings.
Edit the igo.yaml
file to customize your project settings:
project:
name: "my-app"
version: "1.0.0"
main: "main.go"
build:
platforms:
- "windows/amd64"
- "darwin/amd64"
- "linux/amd64"
# Build for all configured platforms
igo build
# Build for specific platforms
igo build --platforms "windows/amd64,linux/amd64"
# Build with custom output directory
igo build --output ./bin
# Create distribution packages
igo package
# Package with specific format
igo package --format tar.gz
# Include additional files
igo package --include "docs/,config/"
The configuration file (igo.yaml
) supports the following sections:
project:
name: "your-app-name"
version: "1.0.0"
description: "Your app description"
main: "main.go"
output: "app-name"
build:
platforms:
- "windows/amd64"
- "darwin/amd64"
- "linux/amd64"
tags:
- "release"
flags:
- "-ldflags=-s -w"
env:
CGO_ENABLED: "0"
output_dir: "dist"
type: "binary"
package:
include:
- "README.md"
- "LICENSE"
exclude:
- ".git"
- "*.tmp"
format: "zip"
output_dir: "packages"
compression_level: 6
environment:
APP_ENV: "production"
DEBUG: "false"
custom:
config_name: "igo"
command_keywords: "build,package,run"
company_name: "Your Company"
Initialize a new igo configuration file.
igo init # Creates igo.yaml
igo init my-config # Creates my-config.yaml
Run Go commands with igo configuration.
igo run # Runs main.go
igo run ./cmd/server # Runs specific file
igo run -tags debug # Runs with build tags
Build Go project with custom configuration.
igo build # Build for all platforms
igo build --platforms "windows/amd64"
igo build --output ./bin
igo build --type zip
Package Go project for distribution.
igo package # Create packages
igo package --format tar.gz
igo package --include "docs/"
igo package --exclude "*.tmp"
Validate configuration file.
igo validate
Show current configuration.
igo config
Igo supports the following platforms for cross-compilation:
- Windows: amd64, 386, arm64
- macOS: amd64, arm64
- Linux: amd64, 386, arm, arm64
- FreeBSD: amd64, 386, arm, arm64
- ZIP: Standard ZIP archive
- TAR: Uncompressed TAR archive
- TAR.GZ: Gzip compressed TAR archive
Igo supports variable substitution in configuration values:
custom:
company: "Acme Corp"
version: "1.0.0"
build:
output_dir: "dist/${custom_company}-${custom_version}"
Available variables:
${project_name}
: Project name${project_version}
: Project version${project_main}
: Main file${env_KEY}
: Environment variables${custom_key}
: Custom configuration values
# Initialize project
igo init
# Edit igo.yaml
# Build for multiple platforms
igo build
# Create distribution packages
igo package
package:
include:
- "static/"
- "templates/"
- "config.yaml"
exclude:
- "*.log"
- ".env"
package:
include:
- "README.md"
- "docs/"
- "examples/"
format: "tar.gz"
git clone https://github.com/qwqxl/igo.git
cd igo
go build -o igo main.go
go test ./...
- Fork the repository
- Create a feature branch
- Make your changes
- Add tests
- Submit a pull request
This project is licensed under the MIT License - see the LICENSE file for details.
- Issues: GitHub Issues
- Documentation: GitHub Wiki
- Discussions: GitHub Discussions
- Docker support
- CI/CD integration
- Plugin system
- GUI interface
- Cloud deployment integration