Skip to content

A Go library for safe type conversions, ensuring type safety and preventing panics.

License

Notifications You must be signed in to change notification settings

bsv-blockchain/go-safe-conversion

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

164 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

🛡  go-safe-conversion

Lightweight Go library for safe type conversions, ensuring type safety and preventing panics.


Release Go Version License


CI / CD    Build Last Commit      Quality    Go Report Coverage
Security    Scorecard Security      Community    Contributors Sponsor


Project Navigation

📦 Installation 🧪 Examples & Tests 📚 Documentation
🤝 Contributing 🛠️ Code Standards ⚡ Benchmarks
🤖 AI Usage 📝 License 👥 Maintainers

📦 Installation

go-safe-conversion requires a supported release of Go.

go get -u github.com/bsv-blockchain/go-safe-conversion

📚 Documentation

Good to know: go-safe-conversion ships with zero runtime dependencies. The only external package we use is testify—and that's strictly for tests.


Development Build Commands

Get the MAGE-X build tool for development:

go install github.com/mrz1836/mage-x/cmd/magex@latest

View all build commands

magex help
Repository Features

This repository includes 25+ built-in features covering CI/CD, security, code quality, developer experience, and community tooling.

View the full Repository Features list →

Library Deployment

This project uses goreleaser for streamlined binary and library deployment to GitHub. To get started, install it via:

brew install goreleaser

The release process is defined in the .goreleaser.yml configuration file.

Then create and push a new Git tag using:

magex version:bump push=true bump=patch branch=master

This process ensures consistent, repeatable releases with properly versioned artifacts and citation metadata.

Pre-commit Hooks

Set up the Go-Pre-commit System to run the same formatting, linting, and tests defined in AGENTS.md before every commit:

go install github.com/mrz1836/go-pre-commit/cmd/go-pre-commit@latest
go-pre-commit install

The system is configured via modular env files in .github/env/ and provides 17x faster execution than traditional Python-based pre-commit hooks. See the complete documentation for details.

GitHub Workflows

All workflows are driven by modular configuration in .github/env/ — no YAML editing required.

View all workflows and the control center →

Updating Dependencies

To update all dependencies (Go modules, linters, and related tools), run:

magex deps:update

This command ensures all dependencies are brought up to date in a single step, including Go modules and any tools managed by MAGE-X. It is the recommended way to keep your development environment and CI in sync with the latest versions.


🧪 Examples & Tests

All unit tests and examples run via GitHub Actions and use Go version 1.24.x. View the configuration file.

Run all tests (fast):

magex test

Run all tests with race detector (slower):

magex test:race

⚡ Benchmarks

Run the Go benchmarks:

magex bench

Benchmark Results

Benchmark Iterations ns/op B/op allocs/op
BigWordToUint32 554149441 2.052 0 0
Int32ToUint32 1000000000 0.3149 0 0
Int64ToInt32 1000000000 0.3136 0 0
Int64ToUint32 573749866 2.078 0 0
Int64ToUint64 1000000000 0.3125 0 0
IntToInt16 1000000000 0.3113 0 0
IntToInt32 1000000000 0.3112 0 0
IntToUint16 575023266 2.080 0 0
IntToUint32 1000000000 0.3112 0 0
IntToUint64 1000000000 0.3113 0 0
TimeToUint32 580299204 2.068 0 0
Uint32ToInt32 1000000000 0.3113 0 0
Uint32ToInt64 1000000000 0.3111 0 0
Uint32ToUint64 1000000000 0.3112 0 0
Uint32ToUint8 1000000000 0.3113 0 0
Uint64ToInt 1000000000 0.3114 0 0
Uint64ToInt32 1000000000 0.3112 0 0
Uint64ToInt64 1000000000 0.3113 0 0
Uint64ToUint16 1000000000 0.3113 0 0
Uint64ToUint32 1000000000 0.3114 0 0
UintptrToInt 1000000000 0.3114 0 0
UintToUint32 1000000000 0.3191 0 0

These benchmarks reflect fast, allocation-free lookups for most retrieval functions, ensuring optimal performance in production environments. Performance benchmarks for the core functions in this library, executed on an Apple M1 Max (ARM64).


🛠️ Code Standards

Read more about this Go project's code standards.


🤖 AI Usage & Assistant Guidelines

Read the AI Usage & Assistant Guidelines for details on how AI is used in this project and how to interact with AI assistants.


👥 Maintainers

Siggi Galt MrZ
Siggi Dylan MrZ

🤝 Contributing

View the contributing guidelines and please follow the code of conduct.

How can I help?

All kinds of contributions are welcome 🙌! The most basic way to show your support is to star 🌟 the project, or to raise issues 💬.

Stars


📝 License

License

About

A Go library for safe type conversions, ensuring type safety and preventing panics.

Topics

Resources

License

Code of conduct

Contributing

Security policy

Stars

Watchers

Forks

Sponsor this project

Packages

 
 
 

Contributors

Languages