PrimSchema
Schema constructor that wraps a value of an underlying GADT of allowed primitive types.
The underlying GADT defines a set of types via GADT constructors; see morphling.protocol.SType for an example. This set of types defines what types may be treated as primitive (and have parsing/ serialization/etc deferred to an external handler) when interpreting a schema value. For example, one might want to construct a GADT for for the Scala primitive types as such:
sealed trait SType[I]
case object SNullT extends SType[Unit]
case object SBoolT extends SType[Boolean]
case object SByteT extends SType[Byte]
case object SShortT extends SType[Short]
case object SIntT extends SType[Int]
case object SLongT extends SType[Long]
case object SFloatT extends SType[Float]
case object SDoubleT extends SType[Double]
case object SCharT extends SType[Char]
case object SStrT extends SType[String]
This example treats String values as primitive as well, even though
strictly speaking they're reference types, just because virtually
any interpreter for a schema algebra will not want to represent
strings in terms of sum or product types. The same might hold true
for, for example, scala.Array but for the purposes of this example
issues related to ClassManifest
instances would introduce excessive
complexity.
- Type parameters:
- F
The functor through which the structure of the schema will be interpreted. This will almost always be a fixpoint type such as morphling.HFix.HCofree, which is used to introduce the ability to create recursive (tree-structured) schema.
- I
The type of the Scala value to be produced (or consumed) by an interpreter of the schema. Also known as the "index" type of the schema.
- P
The GADT type constructor for a sum type which defines the set of primitive types used in the schema.
- Value parameters:
- prim
value identifying a primitive type.