kotlinx.io.charsets.Encoding.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of kotlinx-io-jvm Show documentation
Show all versions of kotlinx-io-jvm Show documentation
IO support libraries for Kotlin
package kotlinx.io.charsets
import kotlinx.io.core.*
expect abstract class Charset {
abstract fun newEncoder(): CharsetEncoder
abstract fun newDecoder(): CharsetDecoder
companion object {
fun forName(name: String): Charset
}
}
expect val Charset.name: String
// ----------------------------- ENCODER -------------------------------------------------------------------------------
expect abstract class CharsetEncoder
expect val CharsetEncoder.charset: Charset
fun CharsetEncoder.encode(input: CharSequence, fromIndex: Int, toIndex: Int, dst: Output) {
var start = fromIndex
if (start >= toIndex) return
dst.writeWhileSize(1) { view: IoBuffer ->
val rc = encodeImpl(input, start, toIndex, view)
check(rc >= 0)
start += rc
when {
start >= toIndex -> 0
rc == 0 -> 8
else -> 1
}
}
encodeCompleteImpl(dst)
}
private val EmptyByteArray = ByteArray(0)
expect fun CharsetEncoder.encodeToByteArray(input: CharSequence,
fromIndex: Int = 0,
toIndex: Int = input.length): ByteArray
@Suppress("Don't use it")
fun CharsetEncoder.encodeToByteArrayImpl(input: CharSequence,
fromIndex: Int = 0,
toIndex: Int = input.length): ByteArray {
var start = fromIndex
if (start >= toIndex) return EmptyByteArray
val single = IoBuffer.Pool.borrow()
try {
IoBuffer.NoPool
val rc = encodeImpl(input, start, toIndex, single)
start += rc
if (start == toIndex) {
val result = ByteArray(single.readRemaining)
single.readFully(result)
return result
}
val builder = BytePacketBuilder(0, IoBuffer.Pool)
builder.last(single.makeView())
encode(input, start, toIndex, builder)
return builder.build().readBytes()
} finally {
single.release(IoBuffer.Pool)
}
}
expect fun CharsetEncoder.encodeUTF8(input: ByteReadPacket, dst: Output)
private fun CharsetEncoder.encodeCompleteImpl(dst: Output) {
var size = 1
dst.writeWhile { view ->
if (encodeComplete(view)) {
size = 0
} else {
size++
}
size > 0
}
}
fun CharsetEncoder.encode(input: CharSequence, fromIndex: Int = 0, toIndex: Int = input.length) = buildPacket {
encode(input, fromIndex, toIndex, this)
}
fun CharsetEncoder.encodeUTF8(input: ByteReadPacket) = buildPacket {
encodeUTF8(input, this)
}
internal expect fun CharsetEncoder.encodeImpl(input: CharSequence, fromIndex: Int, toIndex: Int, dst: IoBuffer): Int
internal expect fun CharsetEncoder.encodeComplete(dst: IoBuffer): Boolean
// ----------------------------- DECODER -------------------------------------------------------------------------------
expect abstract class CharsetDecoder
expect val CharsetDecoder.charset: Charset
fun CharsetDecoder.decode(input: Input, max: Int = Int.MAX_VALUE): String = buildString(minOf(max.toLong(), input.sizeEstimate()).toInt()) {
decode(input, this, max)
}
internal fun Input.sizeEstimate(): Long = when (this) {
is ByteReadPacket -> remaining
is ByteReadPacketBase -> maxOf(remaining, 16)
else -> 16
}
expect fun CharsetDecoder.decode(input: Input, dst: Appendable, max: Int): Int
expect fun CharsetDecoder.decodeExactBytes(input: Input, inputLength: Int): String
// ----------------------------- REGISTRY ------------------------------------------------------------------------------
expect object Charsets {
val UTF_8: Charset
}
expect class MalformedInputException(message: String) : Throwable
© 2015 - 2025 Weber Informatics LLC | Privacy Policy