From 16cebf7b58c7380e48c5740270cea035bf49f7e5 Mon Sep 17 00:00:00 2001 From: Ostrzyciel Date: Tue, 12 Sep 2023 18:31:18 +0200 Subject: [PATCH] Optimization: inline the header check in ProtoEncoder This should slightly boost perf, especially on JVMs with less aggressive JIT inlining. --- .../ostrzyciel/jelly/core/ProtoEncoder.scala | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) diff --git a/core/src/main/scala/eu/ostrzyciel/jelly/core/ProtoEncoder.scala b/core/src/main/scala/eu/ostrzyciel/jelly/core/ProtoEncoder.scala index ed0f14b0..58f4165d 100644 --- a/core/src/main/scala/eu/ostrzyciel/jelly/core/ProtoEncoder.scala +++ b/core/src/main/scala/eu/ostrzyciel/jelly/core/ProtoEncoder.scala @@ -81,7 +81,7 @@ abstract class ProtoEncoder[TNode, TTriple, TQuad, TQuoted](val options: RdfStre * @return iterable of stream rows (always of length 1) */ final def endGraph(): Iterable[RdfStreamRow] = - if !emittedCompressionOptions then + if !emittedOptions then throw new RdfProtoSerializationError("Cannot end a delimited graph before starting one") ProtoEncoder.graphEnd @@ -181,7 +181,7 @@ abstract class ProtoEncoder[TNode, TTriple, TQuad, TQuoted](val options: RdfStre // ************************************* private var extraRowsBuffer = new ListBuffer[RdfStreamRow]() private val iriEncoder = new NameEncoder(options) - private var emittedCompressionOptions = false + private var emittedOptions = false private val lastSubject: LastNodeHolder[TNode] = new LastNodeHolder() private val lastPredicate: LastNodeHolder[TNode] = new LastNodeHolder() @@ -231,12 +231,14 @@ abstract class ProtoEncoder[TNode, TTriple, TQuad, TQuoted](val options: RdfStre o = nodeToProto(getQuotedO(quoted)), ) - private def handleHeader(): Unit = + private inline def handleHeader(): Unit = extraRowsBuffer = new ListBuffer[RdfStreamRow]() - if !emittedCompressionOptions then - emittedCompressionOptions = true - extraRowsBuffer.append( - RdfStreamRow(RdfStreamRow.Row.Options(options)) - ) + if !emittedOptions then emitOptions() + + private def emitOptions(): Unit = + emittedOptions = true + extraRowsBuffer.append( + RdfStreamRow(RdfStreamRow.Row.Options(options)) + )