#scsys #primitive #utilities #toolkit

no-std scsys-util

scsys is a collection of primitives and utilities for use throughout the ecosystem

8 releases

Uses new Rust 2024

0.3.1 Jun 25, 2025
0.3.0 Jun 12, 2025
0.2.9 Jun 8, 2025
0.2.8 May 30, 2025
0.2.4 Apr 29, 2025

#1114 in Text processing

Download history 80/week @ 2025-04-23 73/week @ 2025-04-30 126/week @ 2025-05-07 19/week @ 2025-05-14 455/week @ 2025-05-21 466/week @ 2025-05-28 364/week @ 2025-06-04 520/week @ 2025-06-11 249/week @ 2025-06-18 448/week @ 2025-06-25

1,601 downloads per month
Used in 36 crates (via scsys)

Apache-2.0

16KB
211 lines

scsys

crates.io docs.rs GitHub License


Welcome to scsys, a collection of useful utilities, types, and other primitives that are used in various projects developed by Scattered Systems. The library is designed to be a general-purpose utility library that can be used in any Rust project, aiming to provide a standardized set of tools that can be used to build robust and reliable software.

Usage

Before you start using scsys, make sure to add it as a dependency in your Cargo.toml file. You can do this by adding the following lines:

[dependencies.scsys]
default-features = true
features = [
    "derive",
]
version = "0.2.x"

Examples

For more detailed examples, please visit the examples directory in the repository. Below are some brief examples highlighting certain features of the library.

Example 1: Using the VariantConstructors derive macro

The VariantConstructors derive macro can be used to automatically generate functional accessors for named fields within a given structure. For example, given the following structure:

#[derive(
    Clone, 
    Copy, 
    Debug, 
    Default, 
    Eq, 
    Hash, 
    Ord, 
    PartialEq, 
    PartialOrd, 
    scsys::VariantConstructors
)
pub enum Sample {
    A,
    B(usize),
    C { x: f32, y: f32 },
}

we can automatically generate a functional constructors for each of the Sample variants:

let a = Sample::a();
let b = Sample::b(42);
let c = Sample::c(1.0, 2.0);
assert_eq!(a, Sample::A);
assert_eq!(b, Sample::B(42));
assert_eq!(c, Sample::C { x: 1.0, y: 2.0 });

Getting Started

To get started with scsys, you can check out the QUICKSTART.md file, which provides a step-by-step guide on how to set up your development environment and start using the library.

License

Licensed under the Apache License, Version 2.0, (LICENSE-APACHE)

Contribution

Contributions are welcome, however, ensure that you have read the CONTRIBUTING.md file before submitting a pull request.

Dependencies

~0.3–1.6MB
~31K SLoC