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

parsley.internal.machine.stacks.Stack.scala Maven / Gradle / Ivy

There is a newer version: 5.0.0-M6
Show newest version
/* SPDX-FileCopyrightText: © 2021 Parsley Contributors 
 * SPDX-License-Identifier: BSD-3-Clause
 */
package parsley.internal.machine.stacks

private [machine] abstract class Stack[T] {
    protected type ElemTy
    final def isEmpty(xs: T): Boolean = xs == null
    // $COVERAGE-OFF$
    protected def head(xs: T): ElemTy
    protected def tail(xs: T): T
    protected def show(x: ElemTy): String
    // $COVERAGE-ON$
}
private [machine] object Stack {
    @inline def empty[T >: Null]: T = null
    implicit class StackExt[T](val xs: T) extends AnyVal {
        // $COVERAGE-OFF$
        def mkString(sep: String)(implicit inst: Stack[T]): String = {
            var ys = xs // scalastyle:ignore var.local
            val str = new StringBuilder
            str ++= "["
            while (!inst.isEmpty(ys)) {
                str ++= inst.show(inst.head(ys))
                ys = inst.tail(ys)
                if (!inst.isEmpty(ys)) str ++= sep
            }
            str ++= "]"
            str.result()
        }
        def size(implicit inst: Stack[T]): Int = {
            var ys = xs
            var sz = 0
            while (!inst.isEmpty(ys)) {
                sz += 1
                ys = inst.tail(ys)
            }
            sz
        }
        // $COVERAGE-ON$
        @inline def isEmpty(implicit inst: Stack[T]): Boolean = inst.isEmpty(xs)
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy