SOps

parsley.expr.SOps$
object SOps

This helper object builds values of Ops[A, B] where A <: B, for subtyped heterogeneous precedence parsing.

Attributes

Since:

3.0.0

Source:
SmartOps.scala
Graph
Supertypes
class Object
trait Matchable
class Any
Self type
SOps.type

Members list

Concise view

Value members

Concrete methods

def apply[B, A <: B](fixity: Fixity)(ops: Parsley[Op[A, B]]*): Ops[A, B]

This function builds an Ops object representing many operators found at the same precedence level, with a given fixity.

This function builds an Ops object representing many operators found at the same precedence level, with a given fixity.

The operators found on the level constructed by this function are heterogeneous: the type of the level below may vary from the types of the values produced at this level. It is constrained, however, such that values of the layer below must be upcastable into types generated by this layer: one layer must be a subtype of the other.

Using path-dependent typing, the given fixity describes the shape of the operators expected. For more information see the Parsley wiki.

Attributes

A

the base type consumed by the operators.

B

the type produced/consumed by the operators, must be a supertype of A.

fixity

the fixity of the operators described.

ops

the operators themselves, provided variadically.

See also:
Since:

3.0.0

Note:

currently a bug in scaladoc incorrect displays this functions type, it should be: fixity.Op[A, B], NOT Op[A, B].

the order of types in this method is reversed compared with GOps.apply, this is due to a Scala typing issue.

Source:
SmartOps.scala