47 releases

Uses new Rust 2024

0.3.2 Sep 9, 2025
0.3.1 Jun 25, 2025
0.2.9 Jun 8, 2025
0.2.3 Sep 22, 2024
0.1.35 Nov 29, 2022

#6 in #scsys-ecosystem

Download history 412/week @ 2025-08-27 394/week @ 2025-09-03 282/week @ 2025-09-10 169/week @ 2025-09-17 205/week @ 2025-09-24 438/week @ 2025-10-01 173/week @ 2025-10-08 262/week @ 2025-10-15 246/week @ 2025-10-22 188/week @ 2025-10-29 125/week @ 2025-11-05 141/week @ 2025-11-12 141/week @ 2025-11-19 151/week @ 2025-11-26 90/week @ 2025-12-03 39/week @ 2025-12-10

454 downloads per month
Used in 28 crates (3 directly)

Apache-2.0

36KB
699 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.3.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

~150–550KB
~13K SLoC