18 releases

0.7.6 Nov 1, 2022
0.6.4 Feb 3, 2022
0.6.2 Dec 27, 2021
0.4.1 Nov 13, 2021

#1012 in Rust patterns

Download history 8/week @ 2023-12-11 7/week @ 2024-01-01 9/week @ 2024-01-08 46/week @ 2024-01-15 230/week @ 2024-01-22 141/week @ 2024-01-29 126/week @ 2024-02-05 160/week @ 2024-02-12 190/week @ 2024-02-19 47/week @ 2024-02-26 9/week @ 2024-03-04 8/week @ 2024-03-11 4/week @ 2024-03-18 66/week @ 2024-03-25

89 downloads per month
Used in bangumi

MIT license

18KB
121 lines

microtype

Boilerplate-free microtypes

What/Why/How?

Microtypes (also known as "newtypes") are thin wrappers around primitive types, that differentiate between 2 otherwise identical types, based on their usage/meaning. Since they are distinct types, they can't be substituted for one another. This helps to reduce logic bugs, by catching incorrect use of data at compile time.

For example, consider the following:

fn handle_order(user_id: String, order_id: String) {
  // ...
} 

fn main() {
  let user_id = ...;
  let order_id = ...;
  handle_order(order_id, user_id);
}

In this small example, it's fairly easy to see that there's a bug here: order_id and user_id are in the wrong order. However, as projects grow it becomes harder to spot. More generally, human beings aren't very good at detecting errors like this, so we should try to offload this work onto the compiler.

Let's take a look at that but with microtypes instead:

// microtype definitions
microtype! {
  String {
    UserId
  }

  String {
    OrderId
  }
}

// or use the shorthand for declaring multiple microtypes
// microtype! {
//   String {
//     UserId
//     OrderId
//   }
// }

fn handle_order(user_id: UserId, order_id: OrderId) {
  // ...
} 

fn main() {
  let user_id: UserId = ...;
  let order_id: OrderId = ...;
  handle_order(order_id, user_id);  // Error, mismatched types
}

Great! It doesn't compile. By introducing microtypes, we've moved this run-time error into a compile-time error.

For more details and examples, check out the docs

Contributing

Any and all contributions are always welcome! Feel free to raise an issue/submit a PR, etc.

Dependencies

~1–1.4MB
~34K SLoC