Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Iltotore/iron
Strong type constraints for Scala
https://github.com/Iltotore/iron
assert functional-programming refinement-types scala types
Last synced: 12 days ago
JSON representation
Strong type constraints for Scala
- Host: GitHub
- URL: https://github.com/Iltotore/iron
- Owner: Iltotore
- License: apache-2.0
- Created: 2021-01-13T11:48:58.000Z (almost 4 years ago)
- Default Branch: main
- Last Pushed: 2024-09-15T20:24:56.000Z (about 2 months ago)
- Last Synced: 2024-09-16T04:26:41.452Z (about 2 months ago)
- Topics: assert, functional-programming, refinement-types, scala, types
- Language: Scala
- Homepage: https://iltotore.github.io/iron/docs/
- Size: 1.38 MB
- Stars: 448
- Watchers: 15
- Forks: 40
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
![logo](https://github.com/Iltotore/iron/blob/main/logo.png?raw=true)
[![Scala version support](https://index.scala-lang.org/iltotore/iron/iron/latest-by-scala-version.svg)](https://index.scala-lang.org/iltotore/iron/iron)
[![CI](https://github.com/Iltotore/iron/actions/workflows/ci.yml/badge.svg)](https://github.com/Iltotore/iron/actions/workflows/ci.yml)
___Iron is a lightweight library for refined types in Scala 3.
It enables attaching constraints/assertions to types, to enforce properties and forbid invalid values.
- **Catch bugs.** In the spirit of static typing, use more specific types to avoid invalid values.
- **Compile-time and runtime.** Evaluate constraints at compile time, or explicitly check them at runtime (e.g. for a
form).
- **Seamless.** Iron types are subtypes of their unrefined versions, meaning you can easily add or remove them.
- **No black magic.** Use Scala 3's powerful inline, types and restricted macros for consistent behaviour and rules. No
unexpected behaviour.
- **Extendable.** Easily create your own constraints or integrations using classic typeclasses.To learn more about Iron, see the [microsite](https://iltotore.github.io/iron/docs/index.html).
## Example
```scala
import io.github.iltotore.iron.*
import io.github.iltotore.iron.constraint.numeric.*def log(x: Double :| Positive): Double =
Math.log(x) //Used like a normal `Double`log(1.0) //Automatically verified at compile time.
log(-1.0) //Compile-time error: Should be strictly positiveval runtimeValue: Double = ???
log(runtimeValue.refineUnsafe) //Explicitly refine your external values at runtime.runtimeValue.refineEither.map(log) //Use monadic style for functional validation
runtimeValue.refineEither[Positive].map(log) //More explicitly
```## Helpful error messages
Iron provides useful errors when a constraint does not pass:
```scala
log(-1.0)
``````scala
-- Constraint Error --------------------------------------------------------
Could not satisfy a constraint for type scala.Double.Value: -1.0
Message: Should be strictly positive
----------------------------------------------------------------------------
```Or when it cannot be verified:
```scala
val runtimeValue: Double = ???
log(runtimeValue)
``````scala
-- Constraint Error --------------------------------------------------------
Cannot refine non full inlined input at compile-time.
To test a constraint at runtime, use the `refine` extension method.Note: Due to a Scala limitation, already-refined types cannot be tested at compile-time (unless proven by an `Implication`).
Inlined input: runtimeValue
----------------------------------------------------------------------------
```## Import in your project
SBT:
```scala
libraryDependencies += "io.github.iltotore" %% "iron" % "version"
```Mill:
```scala
ivy"io.github.iltotore::iron:version"
```**Note: replace `version` with the version of Iron.**
### Platform support
| Module | JVM | JS | Native |
|-----------------|-----|----|--------|
| iron | ✔️ | ✔️ | ✔️ |
| iron-borer | ✔️ | ✔️ | ❌ |
| iron-cats | ✔️ | ✔️ | ✔️ |
| iron-circe | ✔️ | ✔️ | ✔️ |
| iron-ciris | ✔️ | ✔️ | ✔️ |
| iron-decline | ✔️ | ✔️ | ✔️ |
| iron-doobie | ✔️ | ❌ | ❌ |
| iron-jsoniter | ✔️ | ✔️ | ✔️ |
| iron-pureconfig | ✔️ | ❌️ | ❌️ |
| iron-scalacheck | ✔️ | ✔️ | ❌ |
| iron-skunk | ✔️ | ✔️ | ✔️ |
| iron-upickle | ✔️ | ✔️ | ✔️ |
| iron-zio | ✔️ | ✔️ | ❌ |
| iron-zio-json | ✔️ | ✔️ | ❌ |## Adopters
Here is a non-exhaustive list of projects using Iron.
[Submit a PR](https://github.com/Iltotore/iron/pulls?q=is%3Apr+is%3Aopen+sort%3Aupdated-desc) to add your project or
company to the list.### Companies
- [Clever Cloud](https://www.clever-cloud.com)
- [Ledger](https://github.com/LedgerHQ)
- [Marss](https://github.com/marss)
- [Association familiale Mulliez](https://fr.wikipedia.org/wiki/Association_familiale_Mulliez)### Other projects
- [gvolpe/trading](https://github.com/gvolpe/trading) ([book](https://leanpub.com/feda))
- [cheleb/laminar-form-derivation](https://github.com/cheleb/laminar-form-derivation)
- [Lichess](https://lichess.org)
- [Tessella](https://github.com/scala-tessella/tessella)## Useful links
- [Website](https://iltotore.github.io/iron/docs/index.html)
- [Scaladoc](https://iltotore.github.io/iron/index.html)
- [Code of Conduct](https://iltotore.github.io/iron/docs/code-of-conduct.html)
- [Contributing to Iron](https://iltotore.github.io/iron/docs/contributing.html)