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

com.rojoma.json.v3.io.ReaderUtils.scala Maven / Gradle / Ivy

package com.rojoma.json.v3
package io

private[io] object ReaderUtils {
  private val intMaxLength = Int.MaxValue.toString.length

  // finds the exponent, if there is one, then returns isBigDecimalizableExponent
  // from there.  Requires the number be well-formed
  def isBigDecimalizable(s: String): Boolean = {
    var i = 0
    val len = s.length
    while(i != len) {
      val c = s.charAt(i)
      if(c == 'e' || c == 'E') return isBigDecimalizableExponent(s, i + 1)
      i += 1
    }
    true
  }

  // Ensures that the absolute value of the number represented by this string
  // starting at this offset fits in 31 bits.
  def isBigDecimalizableExponent(s: String, offset: Int = 0): Boolean = {
    def isSigned = {
      val c = s.charAt(offset)
      c == '+' || c == '-'
    }
    if(isSigned) isBigDecimalizableUnsignedExponent(s, offset + 1)
    else isBigDecimalizableUnsignedExponent(s, offset)
  }

  def isBigDecimalizableUnsignedExponent(s: String, offset: Int) = {
    val lenInChars = s.length - offset
    val isNeg = s.charAt(offset-1) == '-'
    lenInChars < intMaxLength || (lenInChars == intMaxLength && (if(isNeg) {
                                                                   s.substring(offset).toLong <= (Int.MaxValue+1L)
                                                                 } else {
                                                                   s.substring(offset).toLong <= Int.MaxValue
                                                                 }))
  }

  def isValidIdentifier(s: String): Boolean = {
    exactlyOneToken(s) match {
      case Some(TokenIdentifier(_)) => true
      case _ => false
    }
  }

  def isValidNumber(s: String): Boolean = {
    exactlyOneToken(s) match {
      case Some(TokenNumber(_)) => true
      case _ => false
    }
  }

  private def exactlyOneToken(n: String): Option[JsonToken] =
    JsonTokenGenerator.newGenerator(n) match {
      case JsonTokenGenerator.Token(t, _, ri) if ri.isEmpty => Some(t)
      case JsonTokenGenerator.More(cont) =>
        cont.endOfInput() match {
          case JsonTokenGenerator.FinalToken(t, _) => Some(t)
          case _ => None
        }
      case _ => None
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy