All Downloads are FREE. Search and download functionalities are using the official Maven repository.

parsley.expr.Levels.scala Maven / Gradle / Ivy

/*
 * Copyright 2020 Parsley Contributors 
 *
 * SPDX-License-Identifier: BSD-3-Clause
 */
package parsley.expr

import parsley.Parsley

/** This class is the base type for precedence tables.
  *
  * For more complex expression parser types `Prec` can be used to
  * describe the precedence table whilst preserving the intermediate
  * structure between each level.
  *
  * The base of the table will always be an `Atoms`, and each layer
  * built on top of the last using either the `:+` or `+:` methods.
  *
  * @tparam A the type of structure produced by the list of levels.
  * @since 4.0.0
  * @group Table
  */
sealed abstract class Prec[+A] private [expr] {
    /** This method adds a new layer to this precedence table on the right, in a tightest-to-weakest ordering.
      *
      * This method associates to the left, so left-most applications are tighter binding (closer to the atoms)
      * than those to the right. It should not be mixed with `+:`, which would be confusing and less predictable.
      *
      * @tparam Aʹ a weakened version of the type generated by this table, to increase flexibility.
      * @tparam B the result type of the new table.
      * @param ops the operators that make up the new level on the table.
      * @return a new table that incorporates the operators and atoms in this table, along with extra `ops`.
      */
    final def :+[Aʹ >: A, B](ops: Ops[Aʹ, B]): Prec[B] = new Level(this, ops)
    /** This method adds a new layer to this precedence table on the left, in a weakest-to-tightest ordering.
      *
      * This method associates to the right (with this table on the right!), so right-most applications are
      * tighter binding (closer to the atoms) than those to the left. It should not be mixed with `:+`,
      * which would be confusing and less predictable.
      *
      * @tparam Aʹ a weakened version of the type generated by this table, to increase flexibility.
      * @tparam B the result type of the new table.
      * @param ops the operators that make up the new level on the table.
      * @return a new table that incorporates the operators and atoms in this table, along with extra `ops`.
      */
    final def +:[Aʹ >: A, B](ops: Ops[Aʹ, B]): Prec[B] = new Level(this, ops)
}
private [expr] case class Level[A, B](lvls: Prec[A], ops: Ops[A, B]) extends Prec[B]

/** This class is the base of a precedence table.
  *
  * Forms the base of a precedence table, requiring at least one atom to be
  * provided. This first atom will be parsed first.
  *
  * @tparam A the type of the atoms.
  * @param atom0 the first atom found at the root of the precedence table.
  * @param atoms any remaining atoms found at the root of the precedence table.
  * @since 4.0.0
  * @group Table
  */
case class Atoms[+A](atom0: Parsley[A], atoms: Parsley[A]*) extends Prec[A]




© 2015 - 2025 Weber Informatics LLC | Privacy Policy