2019-07-06 20:00:37 +02:00
|
|
|
# stew - status e-something w-something
|
|
|
|
|
2019-07-06 20:07:41 +02:00
|
|
|
[data:image/s3,"s3://crabby-images/17683/1768380119c0c89a3a7922cc565ecc789708079d" alt="License: Apache"](https://opensource.org/licenses/Apache-2.0)
|
|
|
|
[data:image/s3,"s3://crabby-images/fd432/fd43213bb59a161ac6c4afe58ccd16987c6acfd9" alt="License: MIT"](https://opensource.org/licenses/MIT)
|
|
|
|
data:image/s3,"s3://crabby-images/0b711/0b711680a4a39ab794fb1b7a0e4b33d1b7df9604" alt="Stability: experimental"
|
2023-04-14 21:51:50 +07:00
|
|
|
data:image/s3,"s3://crabby-images/5a0a3/5a0a3d797425ef0c0d643753be40b953cd7f8b71" alt="Github action"
|
2019-07-06 20:07:41 +02:00
|
|
|
|
2019-07-06 20:00:37 +02:00
|
|
|
`stew` is collection of utilities, std library extensions and budding libraries
|
|
|
|
that are frequently used at Status, but are too small to deserve their own
|
|
|
|
git repository.
|
|
|
|
|
2019-07-06 20:07:41 +02:00
|
|
|
We also use `stew` as a staging ground for code that has yet to be
|
|
|
|
battle-tested.
|
2019-07-06 20:00:37 +02:00
|
|
|
|
|
|
|
Some of these libraries may eventually be proposed for inclusion in Nim or
|
|
|
|
broken out into separate repositories.
|
|
|
|
|
2019-07-25 08:00:17 +02:00
|
|
|
## Notable libraries
|
|
|
|
|
|
|
|
Libraries are documented either in-module or on a separate README in their
|
|
|
|
respective folders
|
|
|
|
|
2024-12-04 10:35:57 +01:00
|
|
|
- `arraybuf` - `array`-based fixed-capacity dynamic-length buffer
|
2020-12-10 12:05:22 +01:00
|
|
|
- `arrayops` - small helpers and operations on `array`/`openArray`
|
|
|
|
- `assign2` - fast assignments (unlike the `=` operator in nim which is very slow)
|
2019-07-25 08:00:17 +02:00
|
|
|
- `bitops2` - an updated version of `bitops.nim`, filling in gaps in original code
|
|
|
|
- `byteutils` - utilities that make working with the Nim `byte` type convenient
|
|
|
|
- `endians2` - utilities for converting to and from little / big endian integers
|
2024-12-04 10:35:57 +01:00
|
|
|
- `io2` - I/O without exceptions
|
2023-06-12 11:42:27 +02:00
|
|
|
- `leb128` - utilities for working with LEB128-based formats (such as the varint style found in protobuf)
|
2020-03-29 17:34:45 +02:00
|
|
|
- `objects` - get an object's base type at runtime, as a string
|
2019-09-20 16:01:32 +02:00
|
|
|
- `ptrops` - pointer arithmetic utilities
|
2023-07-05 12:50:21 +02:00
|
|
|
- `result` - moved to [nim-results](https://github.com/arnetheduck/nim-results/)
|
2019-07-25 08:00:17 +02:00
|
|
|
- `shims` - backports of nim `devel` code to the stable version that Status is using
|
2020-12-10 12:05:22 +01:00
|
|
|
- `sequtils2` - extensions to the `sequtils` module for working conveniently with `seq`
|
2024-12-04 10:35:57 +01:00
|
|
|
- `staticfor` - compile-time loop unrolling
|
2019-07-25 08:00:17 +02:00
|
|
|
|
2019-07-06 20:00:37 +02:00
|
|
|
## Layout
|
|
|
|
|
|
|
|
`stew` modules are made to be fairly independent of each other, but generally
|
|
|
|
follow the following layout - if you've used C++'s `boost`, you'll feel right at
|
|
|
|
home:
|
|
|
|
|
2019-07-06 20:45:27 +02:00
|
|
|
```bash
|
2019-07-06 20:00:37 +02:00
|
|
|
# Single-module libraries
|
|
|
|
stew/small.nim # small libraries that fits in one module
|
|
|
|
|
|
|
|
# Multi-module libraries
|
|
|
|
stew/libname.nim # Main import file
|
|
|
|
stew/libname/stuff.nim # Detail import file
|
|
|
|
|
|
|
|
# Nim standard library shims that contain forwards-compatibility code to manage
|
|
|
|
# support for multiple nim versions - code in here typically has been taken
|
|
|
|
# from nim `devel` branch and `name` will reexport the corresponding std lib
|
|
|
|
# module
|
2019-07-06 20:45:27 +02:00
|
|
|
stew/shims/macros.nim # module that reexports `macros.nim` adding code from newer nim versions
|
2019-07-06 20:00:37 +02:00
|
|
|
|
|
|
|
# Tests are in the tests folder (duh!)
|
|
|
|
# To execute, run either `all_tests.nim` or specific `test_xxx.nim` files:
|
|
|
|
nim c -r tests/all_tests
|
|
|
|
```
|
|
|
|
|
|
|
|
## Compatibility
|
|
|
|
|
|
|
|
One of the goals of `stew` is to provide backwards and forwards compatibility
|
|
|
|
for different Nim versions, such that code using `stew` works well with multiple
|
|
|
|
versions of Nim. If `stew` is not working with the Nim version you're using, we
|
|
|
|
welcome patches.
|
|
|
|
|
2019-07-06 20:45:27 +02:00
|
|
|
You can create multiple versions of your code using the following pattern:
|
|
|
|
|
|
|
|
```nim
|
|
|
|
when (NimMajor,NimMinor,NimPatch) >= (0,19,9):
|
|
|
|
discard
|
|
|
|
elif (NimMajor,NimMinor,NimPatch) >= (0,19,0):
|
|
|
|
discard
|
|
|
|
else
|
|
|
|
{.fatal: "unsupported nim version"}
|
|
|
|
```
|
|
|
|
|
2019-07-06 20:00:37 +02:00
|
|
|
## Using stew in your project
|
|
|
|
|
2024-12-04 10:35:57 +01:00
|
|
|
`stew`, due to its experimental nature, does **not** have a stable API/ABI and
|
|
|
|
features may be changed or removed. Releases are done on a case-by-case basis
|
|
|
|
for when some specific project needs them - open an issue if you need one!
|
|
|
|
|
|
|
|
When making a release, we will strive to update the `minor` version whenever a
|
|
|
|
major component is removed or changed and the `patch` version if changes are
|
|
|
|
mostly additive, but due to the nature of the library being a collection of
|
|
|
|
smaller libraries, these guidelines may be streched at times.
|
|
|
|
|
|
|
|
It is not expected that the library will reach a `1.0` release. Instead, mature
|
|
|
|
code will be [graduated](https://github.com/status-im/nim-stew/commit/2cf408b9609fc3e6c238ddbd90ab31802e650212)
|
|
|
|
into independent libraries that can follow a regular release schedule.
|
|
|
|
|
|
|
|
* libraries that depend on `stew` should specify the lowest possible required
|
|
|
|
version (`stew >= 0.2`) that contain the necessary features that they use -
|
|
|
|
this may be lower than latest released version. An upper bound
|
|
|
|
(`stew >= 0.2 & <0.3`) or caret versions (`stew ^0.2`) may be used but it is
|
|
|
|
not recommended since this will make your library harder to compose with other
|
|
|
|
libraries that depend on `stew`.
|
|
|
|
* applications that depend on stew directly or indirectly should specify a
|
|
|
|
commit ( `stew#abc...`) or a specific version (`stew == 0.2.3`) - this ensures
|
|
|
|
the application will continue to work irrespective of stew updates
|
|
|
|
* alternatively, you can just copy the relevant files of stew into your project
|
|
|
|
or use a submodule - this approach maximises composability since each consumer
|
|
|
|
of stew no longer has to restrict the specific version for other consumers
|
2019-07-06 20:00:37 +02:00
|
|
|
|
2019-07-06 20:45:27 +02:00
|
|
|
Typically, you will import either a top-level library or drill down into its
|
|
|
|
submodules:
|
|
|
|
```nim
|
|
|
|
import stew/bitops2
|
2019-09-20 16:01:32 +02:00
|
|
|
import stew/ranges/bitranges
|
2019-07-06 20:45:27 +02:00
|
|
|
```
|
|
|
|
|
2024-12-04 10:35:57 +01:00
|
|
|
:warning: No API/ABI stability - in applications, pick a commit and stick with it :warning:
|
2019-07-06 20:00:37 +02:00
|
|
|
|
|
|
|
## Contributing to stew
|
|
|
|
|
|
|
|
We welcome contributions to stew - in particular:
|
|
|
|
* if you feel that some part of `stew` should be part of Nim, we welcome your help in taking it through the Nim PR process.
|
|
|
|
* if you're using `stew` with a particular Nim version, we welcome compatibility patches gated with `when NimMajor .. and NimMinor ..`
|
|
|
|
|
|
|
|
## License
|
|
|
|
|
|
|
|
Licensed and distributed under either of
|
|
|
|
|
|
|
|
* MIT license: [LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT
|
|
|
|
|
|
|
|
or
|
|
|
|
|
|
|
|
* Apache License, Version 2.0, ([LICENSE-APACHEv2](LICENSE-APACHEv2) or http://www.apache.org/licenses/LICENSE-2.0)
|
|
|
|
|
|
|
|
at your option. These files may not be copied, modified, or distributed except according to those terms.
|