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

caseapp.core.Indexed.scala Maven / Gradle / Ivy

package caseapp.core

import caseapp.core.argparser.{ArgParser, Consumed}

final case class Indexed[+T](
  index: Int,
  length: Int,
  value: T
)

object Indexed {

  def apply[T](value: T): Indexed[T] =
    Indexed(-1, 0, value)

  def list[T](seq: List[T], startIdx: Int): List[Indexed[T]] =
    seq.zipWithIndex.map {
      case (elem, idx) =>
        Indexed(startIdx + idx, 1, elem)
    }

  def seq[T](seq: Seq[T], startIdx: Int): Seq[Indexed[T]] =
    seq.zipWithIndex.map {
      case (elem, idx) =>
        Indexed(startIdx + idx, 1, elem)
    }

  implicit def argParser[T: ArgParser]: ArgParser[Indexed[T]] =
    new ArgParser[Indexed[T]] {
      private val underlying = ArgParser[T]
      def apply(current: Option[Indexed[T]], index: Int, span: Int, value: String) =
        underlying(current.map(_.value), index, span, value)
          .map(t => Indexed(index, span, t))
      override def apply(current: Option[Indexed[T]], index: Int) =
        underlying(current.map(_.value), index)
          .map(t => Indexed(index, 1, t))
      override def optional(current: Option[Indexed[T]], index: Int, span: Int, value: String) = {
        val (consumed, res) = underlying.optional(current.map(_.value), index, span, value)
        val len             = if (consumed.value) span else 1
        (consumed, res.map(t => Indexed(index, len, t)))
      }
      override def isFlag = underlying.isFlag
      def description     = underlying.description
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy