GitXplorerGitXplorer
x

zeroapply

public
12 stars
2 forks
0 issues

Commits

List of commits on branch master.
Unverified
d9139b930c36a2f8bc77b326d1d1a6f546b57384

Update sbt-scalafmt to 2.5.4

sscala-steward-bot committed 2 days ago
Unverified
585a55b1a2e9ba594be3c3e1ae5f8fe9709f2eb2

Update scalafmt-core to 3.8.5

sscala-steward-bot committed 2 days ago
Unverified
4e68990b9518b4ec83a0ec2d40c59aa7c34350e8

Update scalafmt-core to 3.8.4

sscala-steward-bot committed 6 days ago
Unverified
6790c65a2ca63a82053fe1be6eee7141bb06bff6

Update scala-library, scala-reflect to 2.13.16

sscala-steward-bot committed 8 days ago
Verified
fa865a8560b654948b11e698c9d702f514eb984c

setup-sbt

xxuwei-k committed 8 days ago
Unverified
fa30112c5292406dc6ba6b4a2438c6d74cad4fff

Update sbt, scripted-plugin to 1.10.7

sscala-steward-bot committed a month ago

README

The README file for this repository.

zeroapply

Zero Cost Apply/Applicative Syntax

example

zeroapply.OptionApply.apply3(Option(1), Option(2), Option(3))(_ + _ + _)

{
  val x0: _root_.scala.Option[Int] = scala.Option.apply[Int](1);
  if (x0.isEmpty)
    _root_.scala.None
  else
    {
      val x1: _root_.scala.Option[Int] = scala.Option.apply[Int](2);
      if (x1.isEmpty)
        _root_.scala.None
      else
        {
          val x2: _root_.scala.Option[Int] = scala.Option.apply[Int](3);
          if (x2.isEmpty)
            _root_.scala.None
          else
            _root_.scala.Some(x0.get.+(x1.get).+(x2.get))
        }
    }
}
import scalaz._, std.AllInstances._

case class Foo[A, B](a: A, b: B, c: Int)

object Foo {
  implicit def instance[A: Order, B: Order]: Order[Foo[A, B]] =
    zeroapply.CaseClass.order[Foo[A, B]]
}

new Order[Foo[A, B]] {
  override def equalIsNatural =
    Equal[A].equalIsNatural && Equal[B].equalIsNatural && Equal[Int].equalIsNatural

  override def equal(x1: Foo[A, B], x2: Foo[A, B]) =
    Equal[A].equal(x1.a, x2.a) && Equal[B].equal(x1.b, x2.b) && Equal[Int].equal(x1.c, x2.c)

  override def order(x1: Foo[A, B], x2: Foo[A, B]) =
    Order[A].order(x1.a, x2.a) match {
      case Ordering.EQ =>
        Order[B].order(x1.b, x2.b) match {
          case Ordering.EQ => Order[Int].order(x1.c, x2.c)
          case z => z
        }
      case z =>
        z
    }
}

latest stable version

libraryDependencies += "com.github.xuwei-k" %% "zeroapply" % "0.5.0"
libraryDependencies += "com.github.xuwei-k" %% "zeroapply-scalaz" % "0.5.0"

for scalaz 7.2.x

https://github.com/xuwei-k/zeroapply/tree/0.2.x