This repository contains many frequently used small packages, it is designed to have reasonable trade-off between generic, performance and API friendliness. It helps to make life easier!
The master branch (v2) requires Go 1.18+, it uses the generics feature available in Go 1.18+. For version compatibility policy, please refer to the following docs.
The v1 branch contains the legacy code. there shall be no further changes to the v1 APIs.
Packages under exp directory are considered experimental and unreliable,
the API may change arbitrarily, or even disappear some day without any notice.
They do not follow the Go 1 compatibility promise.
When a package is tested enough, and the API is considered stable, it may be promoted
as "stable" and moved under the top directory.
Packages under the top directory are considered stable, they follow the
Go 1 compatibility promise and the Semantic Versioning spec.
Packages under the top directory may depend on exp packages but must keep
reasonable API compatibility and versioning.
-
collection/dagprovides a directed acyclic graph (DAG) data structure. -
collection/listxprovides generic list, queue and stack data structures. -
collection/heapxcontains a ready-to-use heap implementation based oncontainer/heap, and a generic priority queue based on heap data structure. -
collection/setprovides generic set data structures. -
confrprovides a simple yet powerful configuration loader. -
easycontains many handy utilities as a complementary to the standard library. -
easy/ezdbgprovides easy to use utilities which helps to do quick logging in development. -
easy/ezhttpcontains some utilities to work with HTTP requests. -
easy/ezkvcontains helpful utilities to work with key-value cache. -
easy/ezmapcontains some utilities to manipulate map data structure. -
easy/yamlxextends the YAML unmarshaler with extra features, such as "reading environment variables" and "file including", "reference using gjson JSON path expression", "reference using named variables", "function calling", etc. -
encrypt/cryptocontains some encryption utilities. -
exp/workflowprovides an experimental workflow engine to help to build complex business logic with a simple and declarative way. -
infra/acachecontains an async cache which can be used to fetch and update the latest data periodically and supports expiring a key if it's unused for a period. -
infra/errcodeprovides error code registry to manage error codes and messages. Standardized error codes greatly helps in large scale microservices. -
infra/logidprovides log ID generators to help service observability, such as tracing, metrics, etc. -
perf/bbpprovides efficient byte buffer pools with anti-memory-waste protection. -
perf/gopoolis a fork ofgithub.com/cloudwego/gopkg/concurrency/gopoolwith opinionated changes. It helps to reuse goroutines for better performance. -
perf/jsonprovides a drop-in replacement ofencoding/jsonand extended features. The underlying implementation is change-able and change-able on-the-fly.amd64users may switch to bytedance/sonic implementation for best performance in the cost of a little less maturity. Check README.md for detailed introduction. -
perf/lruis a high performance implementation of the LRU cache, it features pre-allocation, item expiration, friendly and type-safe APIs for commonly used key types. It also provides a sharded version for heavy lock contention use-case. -
unsafe/forceexportforce exports private types and functions of other packages. As you might expect, this package is unsafe and fragile and shouldn't be used in production, it is mainly for testing purpose. -
unsafe/reflectxcontains many utilities to work with reflection, providing convenient APIs or better performance. -
utils/compressprovides utilities to compress and decompress data. -
utils/ptrprovides small functions to work with pointer types, such as copying value as pointer, converting integer to string pointer, or dereference pointer which may be nil, etc. It helps to reduce duplicate code and makes code clearer and simpler. -
utils/retryimplements frequently used strategies and options to do retry when error occurs, with various hooks and circuit breaker to protect system overload. -
utils/sqlutilprovides utilities to work with relational database ORM libraries, it keeps simple and can work withdatabase/sqland many ORM libraries. -
utils/structtagcontains some handy utilities to work with struct tags. -
utils/strutilprovides utilities to work with string data as supplement to the standard librariesstringsandunicode/utf8. -
utils/timeutilprovides utilities to process time related things. -
utils/vdutilhelps to do data validation. -
zlogprovides utilities to use slog with context, and a better implementation to redirect package log's default logger.
See GoDoc for detailed online docs.
Also note that the following packages, which were originally located in this repository, have been moved to standalone repositories:
-
base62is a compact and high performance implementation of base62 algorithm for Go. It has been moved to https://github.com/jxskiss/base62. -
mcliis a minimal but very powerful and magic cli library for Go. It has been moved to https://github.com/jxskiss/mcli.