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

com.rojoma.json.v3.util.JsonUtil.scala Maven / Gradle / Ivy

package com.rojoma.json.v3
package util

import java.io.{Reader, InputStreamReader, FileInputStream, FileOutputStream, OutputStreamWriter, Writer, FilterWriter, BufferedWriter, IOException, File, OutputStream, FilterOutputStream, InputStream, BufferedInputStream, BufferedOutputStream, FilterInputStream}
import java.nio.charset.Charset
import scala.io.Codec

import io._
import codec._

object JsonUtil {
  private class CloseBlockingWriter(writer: Writer) extends FilterWriter(writer) {
    override def close() {}
    override def flush() {}
  }

  private class CloseBlockingOutputStream(stream: OutputStream) extends FilterOutputStream(stream) {
    override def close() {}
    override def flush() {}

    // FilterOutputStream overrides bulk-write to use single-byte write
    override def write(buf: Array[Byte]) = out.write(buf)
    override def write(buf: Array[Byte], off: Int, len: Int) = out.write(buf, off, len)
  }

  private class CloseBlockingInputStream(stream: InputStream) extends FilterInputStream(stream) {
    override def close() {}
  }

  @throws(classOf[IOException])
  @throws(classOf[JsonParseException])
  def readJson[T : JsonDecode](reader: Reader, buffer: Boolean = true): Either[DecodeError, T] = {
    val jvalue =
      if(buffer) JsonReader.fromEvents(new FusedBlockJsonEventIterator(reader))
      else JsonReader.fromTokens(new JsonTokenIterator(reader))
    JsonDecode.fromJValue[T](jvalue)
  }

  @throws(classOf[IOException])
  @throws(classOf[JsonParseException])
  def readJsonBytes[T : JsonDecode](stream: InputStream, charset: Charset, buffer: Boolean = true): Either[DecodeError, T] = {
    val barrier = new CloseBlockingInputStream(stream)
    val buffered = if(buffer) new BufferedInputStream(barrier) else barrier
    readJson[T](new InputStreamReader(buffered, charset), buffer = buffer)
  }

  @throws(classOf[IOException])
  @throws(classOf[JsonParseException])
  def readJsonFile[T : JsonDecode](filename: String, charset: Charset): Either[DecodeError, T] = {
    val stream = new FileInputStream(filename)
    try {
      readJson[T](new InputStreamReader(stream, charset), buffer = true)
    } finally {
      stream.close()
    }
  }

  @throws(classOf[IOException])
  @throws(classOf[JsonParseException])
  def readJsonFile[T : JsonDecode](filename: String, codec: Codec): Either[DecodeError, T] = readJsonFile(filename, codec.charSet)

  @deprecated(message = "Provide a Codec or Charset", since = "3.5.0")
  @throws(classOf[IOException])
  @throws(classOf[JsonParseException])
  def readJsonFile[T : JsonDecode](filename: String): Either[DecodeError, T] = readJsonFile[T](filename, Codec.default.charSet)

  @throws(classOf[IOException])
  @throws(classOf[JsonParseException])
  def readJsonFile[T : JsonDecode](filename: File, charset: Charset): Either[DecodeError, T] = {
    val stream = new FileInputStream(filename)
    try {
      readJson[T](new InputStreamReader(stream, charset), buffer = true)
    } finally {
      stream.close()
    }
  }

  @throws(classOf[IOException])
  @throws(classOf[JsonParseException])
  def readJsonFile[T : JsonDecode](filename: File, codec: Codec): Either[DecodeError, T] = readJsonFile(filename, codec.charSet)

  @deprecated(message = "Provide a Codec or Charset", since = "3.5.0")
  @throws(classOf[IOException])
  @throws(classOf[JsonParseException])
  def readJsonFile[T : JsonDecode](filename: File): Either[DecodeError, T] = readJsonFile[T](filename, Codec.default.charSet)

  @throws(classOf[JsonParseException])
  def parseJson[T : JsonDecode](string: String): Either[DecodeError, T] = JsonDecode.fromJValue[T](JsonReader.fromString(string))

  @throws(classOf[IOException])
  def writeJson[T : JsonEncode](writer: Writer, jsonable: T, pretty: Boolean = false, buffer: Boolean = true): Unit = {
    val json = JsonEncode.toJValue(jsonable)

    def write(finalWriter: Writer) {
      if(pretty) PrettyJsonWriter.toWriter(finalWriter, json)
      else CompactJsonWriter.toWriter(finalWriter, json)
    }

    if(buffer) {
      val barrier = new CloseBlockingWriter(writer)
      val buffer = new BufferedWriter(barrier)
      write(buffer)
      buffer.flush()
    } else {
      write(writer)
    }
  }

  @throws(classOf[IOException])
  def writeJsonBytes[T : JsonEncode](stream: OutputStream, charset: Charset, jsonable: T, pretty: Boolean = false, buffer: Boolean = true): Unit = {
    val barrier = new CloseBlockingOutputStream(stream)
    val buffered = if(buffer) new BufferedOutputStream(barrier) else barrier
    val writer = new OutputStreamWriter(buffered, charset)
    writeJson(writer, jsonable, pretty = pretty, buffer = false)
    writer.flush()
  }

  @throws(classOf[IOException])
  def writeJsonFile[T : JsonEncode](filename: String, charset: Charset, jsonable: T, pretty: Boolean): Unit = {
    val stream = new FileOutputStream(filename)
    try {
      val writer = new OutputStreamWriter(stream, charset)
      try {
        writeJson(writer, jsonable, buffer = true, pretty = pretty)
      } finally {
        writer.close()
      }
    } finally {
      stream.close()
    }
  }
  @throws(classOf[IOException])
  def writeJsonFile[T : JsonEncode](filename: String, charset: Charset, jsonable: T): Unit =
    writeJsonFile(filename, charset, jsonable, false)

  @throws(classOf[IOException])
  def writeJsonFile[T : JsonEncode](filename: String, codec: Codec, jsonable: T, pretty: Boolean): Unit =
    writeJsonFile(filename, codec.charSet, jsonable, pretty = pretty)
  @throws(classOf[IOException])
  def writeJsonFile[T : JsonEncode](filename: String, codec: Codec, jsonable: T): Unit =
    writeJsonFile(filename, codec, jsonable, false)

  @throws(classOf[IOException])
  def writeJsonFile[T : JsonEncode](filename: File, charset: Charset, jsonable: T, pretty: Boolean): Unit = {
    val stream = new FileOutputStream(filename)
    try {
      val writer = new OutputStreamWriter(stream, charset)
      try {
        writeJson(writer, jsonable, buffer = true, pretty = pretty)
      } finally {
        writer.close()
      }
    } finally {
      stream.close()
    }
  }
  @throws(classOf[IOException])
  def writeJsonFile[T : JsonEncode](filename: File, charset: Charset, jsonable: T): Unit =
    writeJsonFile(filename, charset, jsonable, false)

  @throws(classOf[IOException])
  def writeJsonFile[T : JsonEncode](filename: File, codec: Codec, jsonable: T, pretty: Boolean): Unit =
    writeJsonFile(filename, codec.charSet, jsonable, pretty = pretty)
  @throws(classOf[IOException])
  def writeJsonFile[T : JsonEncode](filename: File, codec: Codec, jsonable: T): Unit =
    writeJsonFile(filename, codec, jsonable, false)

  def renderJson[T : JsonEncode](jsonable: T, pretty: Boolean = false) = {
    val json = JsonEncode.toJValue(jsonable)
    if(pretty) PrettyJsonWriter.toString(json)
    else CompactJsonWriter.toString(json)
  }
}





© 2015 - 2025 Weber Informatics LLC | Privacy Policy