Object

doobie.free

sqldata

Related Doc: package free

Permalink

object sqldata extends SQLDataIOInstances

Algebra and free monad for primitive operations over a java.sql.SQLData. This is a low-level API that exposes lifecycle-managed JDBC objects directly and is intended mainly for library developers. End users will prefer a safer, higher-level API such as that provided in the doobie.hi package.

SQLDataIO is a free monad that must be run via an interpreter, most commonly via natural transformation of its underlying algebra SQLDataOp to another monad via Free#foldMap.

The library provides a natural transformation to Kleisli[M, SQLData, A] for any exception-trapping (Catchable) and effect-capturing (Capture) monad M. Such evidence is provided for Task, IO, and stdlib Future; and transK[M] is provided as syntax.

// An action to run
val a: SQLDataIO[Foo] = ...

// A JDBC object
val s: SQLData = ...

// Unfolding into a Task
val ta: Task[A] = a.transK[Task].run(s)
Source
sqldata.scala
Linear Supertypes
SQLDataIOInstances, AnyRef, Any
Ordering
  1. Grouped
  2. Alphabetic
  3. By Inheritance
Inherited
  1. sqldata
  2. SQLDataIOInstances
  3. AnyRef
  4. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Type Members

  1. type SQLDataIO[A] = Free[SQLDataOp, A]

    Permalink

    Free monad over a free functor of SQLDataOp; abstractly, a computation that consumes a java.sql.SQLData and produces a value of type A.

  2. implicit class SQLDataIOOps[A] extends AnyRef

    Permalink

    Syntax for SQLDataIO.

  3. sealed trait SQLDataOp[A] extends AnyRef

    Permalink

    Sum type of primitive operations over a java.sql.SQLData.

Value Members

  1. final def !=(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  2. final def ##(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  4. implicit val CatchableSQLDataIO: Catchable[SQLDataIO]

    Permalink

    Catchable instance for SQLDataIO.

  5. object SQLDataOp

    Permalink

    Module of constructors for SQLDataOp.

    Module of constructors for SQLDataOp. These are rarely useful outside of the implementation; prefer the smart constructors provided by the sqldata module.

  6. implicit val SuspendableSQLDataIO: Suspendable[SQLDataIO]

    Permalink

    Suspendable instance for SQLDataIO.

    Suspendable instance for SQLDataIO.

    Definition Classes
    SQLDataIOInstances
  7. final def asInstanceOf[T0]: T0

    Permalink
    Definition Classes
    Any
  8. def attempt[A](a: SQLDataIO[A]): SQLDataIO[Either[Throwable, A]]

    Permalink

    Lift a SQLDataIO[A] into an exception-capturing SQLDataIO[Throwable \/ A].

  9. def clone(): AnyRef

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  10. def delay[A](a: ⇒ A): SQLDataIO[A]

    Permalink

    Non-strict unit for capturing effects.

  11. final def eq(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  12. def equals(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  13. def finalize(): Unit

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  14. final def getClass(): Class[_]

    Permalink
    Definition Classes
    AnyRef → Any
  15. val getSQLTypeName: SQLDataIO[String]

    Permalink

  16. def hashCode(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  17. def interpK[M[_]](implicit arg0: Catchable[M], arg1: Suspendable[M]): ~>[SQLDataOp, [γ$3$]Kleisli[M, SQLData, γ$3$]]

    Permalink

    Natural transformation from SQLDataOp to Kleisli for the given M, consuming a java.sql.SQLData.

  18. final def isInstanceOf[T0]: Boolean

    Permalink
    Definition Classes
    Any
  19. def lift[Op[_], A, J](j: J, action: Free[Op, A])(implicit mod: Aux[Op, J]): SQLDataIO[A]

    Permalink

    Lift a different type of program that has a default Kleisli interpreter.

  20. final def ne(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  21. final def notify(): Unit

    Permalink
    Definition Classes
    AnyRef
  22. final def notifyAll(): Unit

    Permalink
    Definition Classes
    AnyRef
  23. def raw[A](f: (SQLData) ⇒ A): SQLDataIO[A]

    Permalink

    Backdoor for arbitrary computations on the underlying SQLData.

  24. def readSQL(a: SQLInput, b: String): SQLDataIO[Unit]

    Permalink

  25. final def synchronized[T0](arg0: ⇒ T0): T0

    Permalink
    Definition Classes
    AnyRef
  26. def toString(): String

    Permalink
    Definition Classes
    AnyRef → Any
  27. def trans[M[_]](c: SQLData)(implicit arg0: Catchable[M], arg1: Suspendable[M]): ~>[SQLDataIO, M]

    Permalink

    Natural transformation from SQLDataIO to M, given a java.sql.SQLData.

  28. def transK[M[_]](implicit arg0: Catchable[M], arg1: Suspendable[M]): ~>[SQLDataIO, [γ$4$]Kleisli[M, SQLData, γ$4$]]

    Permalink

    Natural transformation from SQLDataIO to Kleisli for the given M, consuming a java.sql.SQLData.

  29. final def wait(): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  30. final def wait(arg0: Long, arg1: Int): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  31. final def wait(arg0: Long): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  32. def writeSQL(a: SQLOutput): SQLDataIO[Unit]

    Permalink

Inherited from SQLDataIOInstances

Inherited from AnyRef

Inherited from Any

Algebra

Constructors (Lifting)

Constructors (Primitives)

Typeclass Instances

Ungrouped