dataDerivation

Opinionated Set of tool for functional programming in scala

License

License

Categories

Categories

Data
GroupId

GroupId

ru.tinkoff
ArtifactId

ArtifactId

tofu-data-derivation_2.13
Last Version

Last Version

0.4.0
Release Date

Release Date

Type

Type

jar
Description

Description

dataDerivation
Opinionated Set of tool for functional programming in scala
Project URL

Project URL

https://github.com/TinkoffCreditSystems/tofu
Project Organization

Project Organization

ru.tinkoff
Source Code Management

Source Code Management

https://github.com/TinkoffCreditSystems/tofu

Download tofu-data-derivation_2.13

How to add to project

<!-- https://jarcasting.com/artifacts/ru.tinkoff/tofu-data-derivation_2.13/ -->
<dependency>
    <groupId>ru.tinkoff</groupId>
    <artifactId>tofu-data-derivation_2.13</artifactId>
    <version>0.4.0</version>
</dependency>
// https://jarcasting.com/artifacts/ru.tinkoff/tofu-data-derivation_2.13/
implementation 'ru.tinkoff:tofu-data-derivation_2.13:0.4.0'
// https://jarcasting.com/artifacts/ru.tinkoff/tofu-data-derivation_2.13/
implementation ("ru.tinkoff:tofu-data-derivation_2.13:0.4.0")
'ru.tinkoff:tofu-data-derivation_2.13:jar:0.4.0'
<dependency org="ru.tinkoff" name="tofu-data-derivation_2.13" rev="0.4.0">
  <artifact name="tofu-data-derivation_2.13" type="jar" />
</dependency>
@Grapes(
@Grab(group='ru.tinkoff', module='tofu-data-derivation_2.13', version='0.4.0')
)
libraryDependencies += "ru.tinkoff" % "tofu-data-derivation_2.13" % "0.4.0"
[ru.tinkoff/tofu-data-derivation_2.13 "0.4.0"]

Dependencies

compile (5)

Group / Artifact Type Version
org.scala-lang : scala-library jar 2.13.0
ru.tinkoff : tofu-data_2.13 jar 0.4.0
com.propensive : magnolia_2.13 jar 0.11.0
org.manatki : derevo-core_2.13 jar 0.10.2
org.scala-lang : scala-reflect jar 2.13.0

provided (1)

Group / Artifact Type Version
com.github.ghik : silencer-lib_2.13.0 jar 1.4.3

test (1)

Group / Artifact Type Version
org.scalatest : scalatest_2.13 jar 3.0.8

Project Modules

There are no modules declared in this project.

ToFu

Build & Release Maven Central Discord Chat Scala Steward badge

Functional programming toolkit aimed at taming the complexity of Tagless Final approach.

Quick Start

see the docs on the microsite

To use the whole utils pack just add to your build.sbt:

libraryDependencies += "tf.tofu" %% "tofu" % "latest version in badge"

Of course, you can also specify an exact list of tofu modules that you want to add to your dependencies (used in place of "tofu"):

  • tofu-core for core utils
    • tofu-core-cats-mtl for interop between tofu-core and Cats MTL
  • tofu-core-higher-kind for higher kinded utils
  • tofu-concurrent for concurrent utils
  • tofu-config for config utils
  • tofu-data for data utils
  • tofu-derivation for derivation utils and derevo annotations
  • tofu-doobie for Doobie utils
  • tofu-enums for Enumeratum utils
  • tofu-env for Env (a variation of a Reader Monad based on Monix Task)
  • tofu-fs2-interop for interop with fs2
  • tofu-streams for streaming utils
  • tofu-logging for the whole set of logging utils (derivation, layout, structured, util, interop)
    • tofu-logging-derivation for logging derivation only
    • tofu-logging-layout for logging layout only
    • tofu-logging-structured for logging structured only
    • tofu-logging-util for logging util only
    • tofu-logging-refined for interop between tofu-logging and Refined
    • tofu-logging-shapeless for interop between tofu-logging and Shapeless tag
    • tofu-logging-log4cats for interop with Log4Cats
  • tofu-memo for caching utils
  • tofu-observable for monix.reactive.Observable utils
  • tofu-optics-core for optics core (Optics typeclasses)
  • tofu-optics-interop for optics interop with Monocle
  • tofu-optics-macro for macro optics generators
  • tofu-zio-interop for interop with ZIO (core, logging)
    • tofu-zio-core for ZIO instances only
    • tofu-zio-logging for ZIO logging only

Adopters

Proud user of ToFu? Feel free to add your company!

Raiffeisen Bank Russia

Risk Management Solutions

Contributing

Please note we use the following labels for automated release descriptions:

  • chore if your PR does not change any types and runtime semantics
  • fix if your PR merely fixes incorrect behavior

Formatting

We have an automated check for style conformance. You can run sbt checkfmt before PR. If you have any trouble during this check, just run sbt fmt and commit again.

Copyright

Copyright the maintainers, 2019-2021

Logos made with love by @impurepics

ru.tinkoff

Tinkoff.ru

Online financial ecosystem

Versions

Version
0.4.0