commonMain.kotlinx.io.core.Output.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of kotlinx-io-js Show documentation
Show all versions of kotlinx-io-js Show documentation
IO support libraries for Kotlin
package kotlinx.io.core
import kotlinx.io.core.internal.*
/**
* This shouldn't be implemented directly. Inherit [AbstractOutput] instead.
*/
expect interface Output : Appendable, Closeable {
@Deprecated(
"Implementing this interface is highly experimental. Extend AbstractOutput instead.",
level = DeprecationLevel.HIDDEN
)
val doNotImplementOutputButExtendAbstractOutputInstead: Nothing
/**
* Byte order (Endianness) to be used by future write functions calls on this builder instance. Doesn't affect any
* previously written values.
* @default [ByteOrder.BIG_ENDIAN]
*/
@Deprecated("Write with writeXXXLittleEndian or do X.reverseByteOrder() and then writeXXX instead.")
var byteOrder: ByteOrder
fun writeByte(v: Byte)
fun writeShort(v: Short)
fun writeInt(v: Int)
fun writeLong(v: Long)
fun writeFloat(v: Float)
fun writeDouble(v: Double)
fun writeFully(src: ByteArray, offset: Int, length: Int)
fun writeFully(src: ShortArray, offset: Int, length: Int)
fun writeFully(src: IntArray, offset: Int, length: Int)
fun writeFully(src: LongArray, offset: Int, length: Int)
fun writeFully(src: FloatArray, offset: Int, length: Int)
fun writeFully(src: DoubleArray, offset: Int, length: Int)
fun writeFully(src: IoBuffer, length: Int)
fun append(csq: CharArray, start: Int, end: Int): Appendable
fun fill(n: Long, v: Byte)
fun flush()
override fun close()
}
@Suppress("EXTENSION_SHADOWED_BY_MEMBER")
fun Output.append(csq: CharSequence, start: Int = 0, end: Int = csq.length): Appendable {
return append(csq, start, end)
}
@Suppress("EXTENSION_SHADOWED_BY_MEMBER")
fun Output.append(csq: CharArray, start: Int = 0, end: Int = csq.size): Appendable {
return append(csq, start, end)
}
@Suppress("EXTENSION_SHADOWED_BY_MEMBER")
fun Output.writeFully(src: ByteArray, offset: Int = 0, length: Int = src.size - offset) {
writeFully(src, offset, length)
}
@Suppress("EXTENSION_SHADOWED_BY_MEMBER")
fun Output.writeFully(src: ShortArray, offset: Int = 0, length: Int = src.size - offset) {
writeFully(src, offset, length)
}
@Suppress("EXTENSION_SHADOWED_BY_MEMBER")
fun Output.writeFully(src: IntArray, offset: Int = 0, length: Int = src.size - offset) {
writeFully(src, offset, length)
}
@Suppress("EXTENSION_SHADOWED_BY_MEMBER")
fun Output.writeFully(src: LongArray, offset: Int = 0, length: Int = src.size - offset) {
writeFully(src, offset, length)
}
@Suppress("EXTENSION_SHADOWED_BY_MEMBER")
fun Output.writeFully(src: FloatArray, offset: Int = 0, length: Int = src.size - offset) {
writeFully(src, offset, length)
}
@Suppress("EXTENSION_SHADOWED_BY_MEMBER")
fun Output.writeFully(src: DoubleArray, offset: Int = 0, length: Int = src.size - offset) {
writeFully(src, offset, length)
}
@Suppress("EXTENSION_SHADOWED_BY_MEMBER")
fun Output.writeFully(src: IoBuffer, length: Int = src.readRemaining) {
writeFully(src, length)
}
@Suppress("EXTENSION_SHADOWED_BY_MEMBER")
fun Output.fill(n: Long, v: Byte = 0) {
fill(n, v)
}
/**
* Append number of chunks invoking [block] function while the returned value is true.
* Depending on the output underlying implementation it could invoke [block] function with the same buffer several times
* however it is guaranteed that it is always non-empty.
*/
@Deprecated("This is going to become internal. Write directly to output instead.")
inline fun Output.writeWhile(block: (IoBuffer) -> Boolean) {
var tail: IoBuffer = prepareWriteHead(1, null)
try {
while (true) {
if (!block(tail)) break
tail = prepareWriteHead(1, tail)
}
} finally {
afterHeadWrite(tail)
}
}
/**
* Append number of chunks invoking [block] function while the returned value is positive.
* If returned value is positive then it will be invoked again with a buffer having at least requested number of
* bytes space (could be the same buffer as before if it complies to the restriction).
* @param initialSize for the first buffer passed to [block] function
*/
@Deprecated("This is going to become internal. Write directly to output instead.")
inline fun Output.writeWhileSize(initialSize: Int = 1, block: (IoBuffer) -> Int) {
var tail = prepareWriteHead(initialSize, null)
try {
var size: Int
while (true) {
size = block(tail)
if (size <= 0) break
tail = prepareWriteHead(size, tail)
}
} finally {
afterHeadWrite(tail)
}
}
fun Output.writePacket(packet: ByteReadPacket) {
@Suppress("DEPRECATION_ERROR")
if (this is BytePacketBuilderBase) {
writePacket(packet)
return
}
packet.takeWhile { from ->
writeFully(from)
true
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy